|
SoPlex Doxygen Documentation
|
Go to the documentation of this file.
29 METHOD( "SPxSolver::shiftFvec()" );
40 for ( int i = dim() - 1; i >= 0; --i)
83 METHOD( "SPxSolver::shiftPvec()" );
95 for (i = dim() - 1; i >= 0; --i)
105 (*theCoLbound)[i] = (*theCoUbound)[i];
115 (*theCoUbound)[i] = (*theCoLbound)[i];
120 for (i = coDim() - 1; i >= 0; --i)
130 (*theLbound)[i] = (*theUbound)[i];
140 (*theUbound)[i] = (*theLbound)[i];
160 METHOD( "SPxSolver::perturbMin()" );
161 assert(uvec. dim() == p_low. dim());
162 assert(uvec. dim() == p_up. dim());
167 Random mult(10.0 * delta, 100.0 * delta);
174 for (i = uvec. dim() - start - 1; i >= 0; i -= incr)
179 if (p_up[i] <= vec[i] + eps)
181 p_up[i] = vec[i] + Real(mult);
184 if (p_low[i] >= vec[i] - eps)
186 p_low[i] = vec[i] - Real(mult);
192 for (j = uvec. delta(). size() - start - 1; j >= 0; j -= incr)
201 if (u != l && vec[i] >= u - eps)
203 p_up[i] = vec[i] + Real(mult);
209 if (u != l && vec[i] <= l + eps)
211 p_low[i] = vec[i] - Real(mult);
216 #endif // !FULL_SHIFT
228 METHOD( "SPxSolver::perturbMax()" );
229 assert(uvec. dim() == p_low. dim());
230 assert(uvec. dim() == p_up. dim());
235 Random mult(10.0 * delta, 100.0 * delta);
241 for (i = uvec. dim() - start - 1; i >= 0; i -= incr)
245 if (p_up[i] <= vec[i] + eps)
247 p_up[i] = vec[i] + Real(mult);
250 if (p_low[i] >= vec[i] - eps)
252 p_low[i] = vec[i] - Real(mult);
258 for (j = uvec. delta(). size() - start - 1; j >= 0; j -= incr)
266 if (u != l && vec[i] >= u - eps)
268 p_up[i] = vec[i] + Real(mult);
274 if (u != l && vec[i] <= l + eps)
276 p_low[i] = vec[i] - Real(mult);
281 #endif // !FULL_SHIFT
286 METHOD( "SPxSolver::perturbMinEnter()" );
296 METHOD( "SPxSolver::perturbMaxEnter()" );
314 METHOD( "SPxSolver::perturbMin()" );
315 assert(uvec. dim() == p_low. dim());
316 assert(uvec. dim() == p_up. dim());
321 Random mult(10*p_delta, 100*p_delta);
328 for (i = uvec. dim() - start - 1; i >= 0; i -= incr)
332 if (p_up[i] <= vec[i] + eps && rep()*stat[i] < 0)
334 p_up[i] = vec[i] + Real(mult);
335 l_theShift += p_up[i] - u;
337 if (p_low[i] >= vec[i] - eps && rep()*stat[i] < 0)
339 p_low[i] = vec[i] - Real(mult);
340 l_theShift -= p_low[i] - l;
345 for (j = uvec. delta(). size() - start - 1; j >= 0; j -= incr)
353 if (u != l && vec[i] >= u - eps && rep()*stat[i] < 0)
355 p_up[i] = vec[i] + Real(mult);
356 l_theShift += p_up[i] - u;
361 if (u != l && vec[i] <= l + eps && rep()*stat[i] < 0)
363 p_low[i] = vec[i] - Real(mult);
364 l_theShift -= p_low[i] - l;
368 #endif // !FULL_SHIFT
382 METHOD( "SPxSolver::perturbMax()" );
383 assert(uvec. dim() == p_low. dim());
384 assert(uvec. dim() == p_up. dim());
389 Random mult(10*p_delta, 100*p_delta);
396 for (i = uvec. dim() - start - 1; i >= 0; i -= incr)
400 if (p_up[i] <= vec[i] + eps && rep()*stat[i] < 0)
402 p_up[i] = vec[i] + Real(mult);
403 l_theShift += p_up[i] - u;
405 if (p_low[i] >= vec[i] - eps && rep()*stat[i] < 0)
407 p_low[i] = vec[i] - Real(mult);
408 l_theShift -= p_low[i] - l;
413 for (j = uvec. delta(). size() - start - 1; j >= 0; j -= incr)
421 if (u != l && vec[i] >= u - eps && rep()*stat[i] < 0)
423 p_up[i] = vec[i] + Real(mult);
424 l_theShift += p_up[i] - u;
429 if (u != l && vec[i] <= l + eps && rep()*stat[i] < 0)
431 p_low[i] = vec[i] - Real(mult);
432 l_theShift -= p_low[i] - l;
436 #endif // !FULL_SHIFT
443 METHOD( "SPxSolver::perturbMinLeave()" );
450 desc().coStatus(), 0, 1);
457 METHOD( "SPxSolver::perturbMaxLeave()" );
464 desc().coStatus(), 0, 1);
471 METHOD( "SPxSolver::unShift()" );
472 MSG_INFO3( spxout << "DSHIFT07 = " << "unshifting ..." << std::endl; );
487 for (i = dim(); i-- > 0;)
500 t_low = lower(l_num);
504 if ((* theFvec)[i] < t_up - eps)
508 if ((* theFvec)[i] > t_low + eps)
510 else if ((* theFvec)[i] < t_low)
521 for (i = nRows(); i-- > 0;)
533 for (i = nCols(); i-- > 0;)
549 for (i = dim(); i-- > 0;)
573 if ((* theFvec)[i] < t_up - eps)
578 if ((* theFvec)[i] > t_low + eps)
580 else if ((* theFvec)[i] < t_low)
584 for (i = nRows(); i-- > 0;)
596 for (i = nCols(); i-- > 0;)
618 for (i = nRows(); i-- > 0;)
646 for (i = nCols(); i-- > 0;)
648 t_up = t_low = - maxObj(i);
652 if ((* thePvec)[i] < -t_up - eps)
660 if ((* thePvec)[i] > -t_low + eps)
678 for (i = nRows(); i-- > 0;)
692 if ((* thePvec)[i] < t_up - eps)
696 if ((* thePvec)[i] > t_low + eps)
706 for (i = nCols(); i-- > 0;)
|