53 using namespace soplex;
80 void displayQuality()
const
89 m_solver.qualConstraintViolation(maxviol, sumviol);
92 << std::setw(16) << maxviol <<
" "
93 << std::setw(16) << sumviol << std::endl; )
95 qualConstraintViolation(maxviol, sumviol);
98 << std::setw(16) << maxviol <<
" "
99 << std::setw(16) << sumviol << std::endl; )
101 m_solver.qualBoundViolation(maxviol, sumviol);
104 << std::setw(16) << maxviol <<
" "
105 << std::setw(16) << sumviol << std::endl; )
107 qualBoundViolation(maxviol, sumviol);
110 << std::setw(16) << maxviol <<
" "
111 << std::setw(16) << sumviol << std::endl; )
115 m_solver.qualSlackViolation(maxviol, sumviol);
118 << std::setw(16) << maxviol <<
" "
119 << std::setw(16) << sumviol << std::endl; )
121 m_solver.qualRedCostViolation(maxviol, sumviol);
124 << std::setw(16) << maxviol <<
" "
125 << std::setw(16) << sumviol << std::endl; )
129 << std::setprecision(20)
130 << m_solver.provedDualbound() << std::endl; )
138 m_solver.qualConstraintViolation(maxviol, sumviol);
141 << std::setw(16) << maxviol <<
" "
142 << std::setw(16) << sumviol << std::endl; )
144 qualConstraintViolation(maxviol, sumviol);
147 << std::setw(16) << maxviol <<
" "
148 << std::setw(16) << sumviol << std::endl; )
150 m_solver.qualBoundViolation(maxviol, sumviol);
153 << std::setw(16) << maxviol <<
" "
154 << std::setw(16) << sumviol << std::endl; )
156 qualBoundViolation(maxviol, sumviol);
159 << std::setw(16) << maxviol <<
" "
160 << std::setw(16) << sumviol << std::endl; )
164 m_solver.qualSlackViolation(maxviol, sumviol);
167 << std::setw(16) << maxviol <<
" "
168 << std::setw(16) << sumviol << std::endl; )
170 m_solver.qualRedCostViolation(maxviol, sumviol);
173 << std::setw(16) << maxviol <<
" "
174 << std::setw(16) << sumviol << std::endl; )
178 << std::setprecision(20)
179 << m_solver.provedDualbound() << std::endl; )
185 void displayInfeasibility()
const
192 if( m_solver.isProvenInfeasible() )
193 MSG_INFO1(
spxout <<
"IEXAMP13 Infeasibility is proven." << std::endl; )
195 MSG_INFO1(
spxout <<
"IEXAMP13 Infeasibility could not be proven!" << std::endl; )
199 if ( m_solver.isProvenInfeasible() )
205 MSG_INFO1(
spxout <<
"Infeasibility could not be proven!" << std::endl; )
220 const char* banner1 =
221 "************************************************************************\n"
223 "* SoPlex --- the Sequential object-oriented simPlex. *\n"
226 const char* banner2 =
228 "* Copyright (C) 1996-2012 Konrad-Zuse-Zentrum *\n"
229 "* fuer Informationstechnik Berlin *\n"
231 "* SoPlex is distributed under the terms of the ZIB Academic Licence. *\n"
232 "* You should have received a copy of the ZIB Academic License *\n"
233 "* along with SoPlex; If not email to soplex@zib.de. *\n"
235 "************************************************************************\n"
239 std::cout << banner1;
241 #if (SOPLEX_SUBVERSION > 0)
243 std::cout <<
"* Version ";
245 std::cout <<
"SoPlex version ";
251 << std::setw(13) << std::setiosflags(std::ios::left) <<
getGitHash();
253 std::cout <<
" *\n" << banner2 << std::endl;
258 std::cout <<
"* Release ";
260 std::cout <<
"SoPlex release ";
265 << std::setw(13) << std::setiosflags(std::ios::left) <<
getGitHash();
267 std::cout <<
" *\n" << banner2 << std::endl;
273 std::cout <<
"[NDEBUG:"
281 std::cout <<
"[WITH_WARNINGS:"
289 std::cout <<
"[ENABLE_ADDITIONAL_CHECKS:"
290 #ifdef ENABLE_ADDITIONAL_CHECKS
297 std::cout <<
"[ENABLE_CONSISTENCY_CHECKS:"
298 #ifdef ENABLE_CONSISTENCY_CHECKS
305 std::cout <<
"[SOPLEX_WITH_GMP:"
306 #ifdef SOPLEX_WITH_GMP
313 std::cout << std::endl;
318 void print_short_version_info()
320 const char* banner1 =
321 "************************************************************************\n"
322 "* SoPlex --- the Sequential object-oriented simPlex. ";
323 const char* banner2 =
324 "* Copyright (C) 1996-2012 Zuse Institute Berlin *\n"
325 "************************************************************************\n";
327 std::cout << banner1;
328 #if (SOPLEX_SUBVERSION > 0)
329 std::cout <<
"Version "
336 std::cout <<
"Release "
342 std::cout << banner2 << std::endl;
351 "[options] LPfile [Basfile]\n\n"
352 " LPfile can be either in MPS or LPF format\n\n"
353 "options: (*) indicates default\n"
354 " (!) indicates experimental features which may give wrong results\n"
355 " -e select entering algorithm (default is leaving)\n"
356 " -r select row wise representation (default is column)\n"
357 " -i select Eta-update (default is Forest-Tomlin)\n"
358 " -x output solution vector\n"
359 " -y output dual multipliers\n"
360 " -q display solution quality\n"
361 " -br read file with starting basis from Basfile\n"
362 " -bw write file with optimal basis to Basfile\n"
363 " -l set time limit in seconds\n"
364 " -L set iteration limit\n"
365 " -f set primal feasibility tolerance\n"
366 " -o set optimality, i.e., dual feasibility tolerance\n"
367 " -d set primal and dual feasibility tolerance to same value\n"
368 " -R set threshold for tolerances below which iterative refinement is applied\n"
369 " -zz set general zero tolerance\n"
370 " -zf set factorization zero tolerance\n"
371 " -zu set update zero tolerance\n"
372 " -v set verbosity Level: from 0 (ERROR) to 5 (INFO3), default 3 (INFO1)\n"
373 " -V show program version\n"
374 " -C check mode (for check scripts)\n"
375 " -h show this help\n\n"
376 "Simplifier: Scaler: Starter: Pricer: Ratiotester:\n"
377 " -s0 none -g0 none -c0 none* -p0 Textbook -t0 Textbook\n"
378 " -s1 Main* -g1 uni-Equi -c1 Weight -p1 ParMult -t1 Harris\n"
379 " -g2 bi-Equi* -c2 Sum -p2 Devex -t2 Fast*\n"
380 " -g3 bi-Equi+Geo1 -c3 Vector -p3 Hybrid! -t3 Bound Flipping\n"
381 " -g4 bi-Equi+Geo8 -p4 Steep*\n"
383 " -p6 SteepExactSetup\n"
386 std::cerr <<
"usage: " << argv[0] <<
" " << usage << std::endl;
409 <<
"IEXAMP12 Feastol = "
410 << std::setw(16) << work.
feastol() << std::endl
411 <<
"IEXAMP52 Opttol = "
412 << std::setw(16) << work.
opttol() << std::endl
413 <<
"IEXAMP53 Irthreshold = "
414 << std::setw(16) << work.
irthreshold() << std::endl
415 <<
"IEXAMP13 Epsilon Zero = "
417 <<
"IEXAMP37 Epsilon Factor = "
419 <<
"IEXAMP38 Epsilon Update = "
423 <<
" algorithm" << std::endl
426 <<
" representation" << std::endl
429 <<
" update" << std::endl; )
434 <<
"SoPlex parameters: " << std::endl
436 << std::setw(16) << work.
feastol() << std::endl
438 << std::setw(16) << work.
opttol() << std::endl
440 << std::setw(16) << work.
irthreshold() << std::endl
443 <<
"Epsilon Factor = "
445 <<
"Epsilon Update = "
450 <<
"representation = " << (representation ==
SPxSolver::ROW ?
"Row" :
"Column")
452 <<
"update = " << (update ==
SLUFactor::ETA ?
"Eta" :
"Forest-Tomlin")
491 #ifdef PARTIAL_PRICING
500 #ifdef PARTIAL_PRICING
534 assert(ratiotester != 0);
579 << ((prescaler != 0) ? prescaler->
getName() :
"no")
581 << ((postscaler != 0) ? postscaler->
getName() :
"no")
582 <<
" scaling" << std::endl; )
587 << ((prescaler != 0) ? prescaler->
getName() :
"no")
589 << ((postscaler != 0) ? postscaler->
getName() :
"no")
607 assert(simplifier == 0);
612 MSG_INFO1(
spxout <<
"IEXAMP20 " << ((simplifier == 0) ?
"no" : simplifier->
getName()) <<
" simplifier" << std::endl; )
614 MSG_INFO1(
spxout <<
"simplifier = " << ((simplifier == 0) ?
"no" : simplifier->
getName()) << std::endl; )
641 MSG_INFO1(
spxout <<
"IEXAMP21 " << ((starter == 0) ?
"no" : starter->
getName()) <<
" starter" << std::endl; )
649 #ifdef SEND_ALL_OUTPUT_TO_FILES
651 void redirect_output(
652 std::ostream& myerrstream,
653 std::ostream& myinfostream
656 myerrstream .setf( std::ios::scientific | std::ios::showpoint );
657 myinfostream.setf( std::ios::scientific | std::ios::showpoint );
670 const char* filename,
675 MSG_INFO1(
spxout <<
"IEXAMP22 loading LP file " << filename << std::endl; )
682 if ( ! work.
readFile(filename, &rownames, &colnames, 0) )
685 MSG_INFO1(
spxout <<
"EEXAMP23 error while reading file \"" << filename <<
"\"" << std::endl; )
687 MSG_INFO1(
spxout <<
"error while reading file \"" << filename <<
"\"" << std::endl; )
697 << work.
nRows() <<
" rows "
698 << work.
nCols() <<
" columns "
699 << work.
nNzos() <<
" nonzeros"
702 MSG_INFO1(
spxout <<
"IEXAMP41 LP reading time: " << timer.userTime() << std::endl; )
707 << work.
nRows() <<
" rows "
708 << work.
nCols() <<
" columns "
709 << work.
nNzos() <<
" nonzeros"
714 spxout <<
"LP reading time: " << std::fixed << std::setprecision(2) << timer.userTime();
715 spxout << std::scientific << std::setprecision(
int(prec)) << std::endl; )
723 const char* filename,
727 MSG_INFO1(
spxout <<
"Reading basis from file (disables simplifier)" << std::endl; )
731 MSG_INFO1(
spxout <<
"EEXAMP25 error while reading file \"" << filename <<
"\"" << std::endl; )
733 MSG_INFO1(
spxout <<
"Error while reading file \"" << filename <<
"\"" << std::endl; )
763 const bool print_quality,
764 const bool print_solution,
765 const bool print_dual,
766 const bool write_basis,
767 const char* basisname
779 MSG_INFO1(
spxout <<
"IEXAMP29 solution value is: " << std::setprecision( precision ) << work.
objValue() << std::endl; )
781 MSG_INFO1(
spxout <<
"Solution value is: " << std::setprecision( precision ) << work.
objValue() << std::endl; )
786 if ( print_solution )
792 MSG_INFO1(
spxout << std::endl <<
"Primal solution (name, id, value):" << std::endl; )
793 for(
int i = 0; i < work.
nCols(); ++i )
799 << std::setprecision( precision )
800 << objx[i] << std::endl; )
802 MSG_INFO1(
spxout <<
"All other variables are zero (within " << std::setprecision(1) << 0.001*work.
feastol() <<
")." << std::endl; )
812 MSG_INFO1(
spxout << std::endl <<
"Dual multipliers (name, id, value):" << std::endl; )
813 for(
int i = 0; i < work.
nRows(); ++i )
820 << std::setprecision( precision )
821 << objy[i] << std::endl; )
826 MSG_INFO1(
spxout <<
"All " << (allzero ?
"" :
"other ") <<
"dual values are zero (within "
827 << std::setprecision(1) << 0.001*work.
opttol() <<
")." << std::endl; )
833 MSG_INFO1(
spxout <<
"Minimizing: a positive/negative value corresponds to left-hand (>=) resp. right-hand (<=) side."
838 MSG_INFO1(
spxout <<
"Maximizing: a positive/negative value corresponds to right-hand (<=) resp. left-hand (>=) side."
846 MSG_INFO1(
spxout <<
"Writing basis of original problem to file " << basisname << std::endl; )
850 MSG_INFO1(
spxout <<
"EEXAMP30 error while writing file \"" << basisname <<
"\"" << std::endl; )
852 MSG_INFO1(
spxout <<
"Error while writing file \"" << basisname <<
"\"" << std::endl; )
862 if ( print_solution )
867 MSG_INFO1(
spxout << std::endl <<
"Primal solution (name, id, value):" << std::endl; )
868 for(
int i = 0; i < work.
nCols(); ++i )
874 << std::setprecision( precision )
875 << objx[i] << std::endl; )
877 MSG_INFO1(
spxout <<
"All other variables are zero (within " << std::setprecision(1) << 0.001*work.
feastol() <<
")." << std::endl; )
884 Real rayobjval = 0.0;
888 MSG_INFO1(
spxout << std::endl <<
"Primal ray (name, id, value):" << std::endl; )
889 for(
int i = 0; i < work.
nCols(); ++i )
893 rayobjval += ray[i] * objcoef[i];
898 << std::setprecision( precision )
899 << ray[i] << std::endl; )
902 MSG_INFO1(
spxout <<
"All other variables have zero value (within " << std::setprecision(1) << 0.001*work.
feastol() <<
")." << std::endl; )
903 MSG_INFO1(
spxout <<
"Objective change per unit along primal ray is " << rayobjval <<
"." << std::endl; )
912 if ( print_solution )
925 for(
int i = 0; i < work.
nRows(); ++i )
932 << std::setprecision( precision )
933 << farkasx[i] <<
"\t"; )
940 for(
int j = 0; j < row.rowVector().size(); ++j )
942 if( row.rowVector().value(j) > 0 )
947 << row.rowVector().value(j) <<
" "
948 << colnames[ work.
cId(row.rowVector().index(j)) ]
956 if( farkasx[i] > 0.0 )
958 lhs += farkasx[i] * row.lhs();
959 rhs += farkasx[i] * row.rhs();
963 lhs += farkasx[i] * row.rhs();
964 rhs += farkasx[i] * row.lhs();
972 MSG_INFO1(
spxout <<
"All other row multipliers are zero (within " << std::setprecision(1) << 0.001*work.
opttol() <<
")." << std::endl; )
976 bool nonzerofound =
false;
977 for(
int i = 0; i < work.
nCols(); ++i )
981 if( proofvec[i] > 0 )
1002 MSG_INFO1(
spxout <<
"EEXAMP30 error while writing file \"" << basisname <<
"\"" << std::endl; )
1004 MSG_INFO1(
spxout <<
"Error while writing file \"" << basisname <<
"\"" << std::endl; )
1009 MSG_INFO1(
spxout <<
"EEXAMP40 aborted due to cycling" << std::endl; )
1015 MSG_INFO1(
spxout <<
"IEXAMP33 aborted due to time limit" << std::endl; )
1021 MSG_INFO1(
spxout <<
"IEXAMP34 aborted due to iteration limit" << std::endl; )
1027 MSG_INFO1(
spxout <<
"IEXAMP35 aborted due to objective value limit" << std::endl; )
1029 MSG_INFO1(
spxout <<
"Aborted due to objective value limit" << std::endl; )
1039 MSG_INFO1(
spxout <<
"EEXAMP36 An error occurred during " <<
"the solution process" << std::endl; )
1041 MSG_INFO1(
spxout <<
"An error occurred during " <<
"the solution process" << std::endl; )
1059 if ( prescaler != 0 )
1064 if ( postscaler != 0 )
1069 if ( simplifier != 0 )
1080 assert( pricer != 0 );
1084 assert( ratiotester != 0 );
1088 if ( basisname != 0 )
1089 delete [] basisname;
1099 const char* filename;
1100 char* basisname = 0;
1118 int simplifying = 1;
1120 Real timelimit = -1.0;
1129 bool print_solution =
false;
1130 bool print_dual =
false;
1131 bool print_quality =
false;
1132 bool read_basis =
false;
1133 bool write_basis =
false;
1137 for(optidx = 1; optidx < argc; optidx++)
1139 if (*argv[optidx] !=
'-')
1142 switch(argv[optidx][1])
1146 if (argv[optidx][2] ==
'r')
1148 if (argv[optidx][2] ==
'w')
1153 starting = atoi(&argv[optidx][2]);
1157 delta = atof(&argv[optidx][2]);
1161 feastol = atof(&argv[optidx][2]);
1165 opttol = atof(&argv[optidx][2]);
1169 irthreshold = atof(&argv[optidx][2]);
1176 scaling = atoi(&argv[optidx][2]);
1182 if (argv[optidx][2] ==
'\0' )
1184 timelimit = atof(&argv[optidx][2]);
1187 if (argv[optidx][2] ==
'\0' )
1189 iterlimit = atoi(&argv[optidx][2]);
1193 pricing = atoi(&argv[optidx][2]);
1196 print_quality =
true;
1203 simplifying = atoi(&argv[optidx][2]);
1207 ratiotest = atoi(&argv[optidx][2]);
1211 if (argv[optidx][2] >=
'0' && argv[optidx][2] <=
'9')
1212 verbose = argv[optidx][2] -
'0';
1218 print_solution =
true;
1226 switch(argv[optidx][2])
1229 epsilon = atof(&argv[optidx][3]);
1232 epsilon_factor = atof(&argv[optidx][3]);
1235 epsilon_update = atof(&argv[optidx][3]);
1257 if ((argc - optidx) < 1 + (read_basis ? 1 : 0) + (write_basis ? 1 : 0))
1259 filename = argv[optidx];
1267 if ( read_basis || write_basis )
1268 basisname = strcpy(
new char[strlen(argv[optidx]) + 1], argv[optidx] );
1277 precision = int(-log10(std::min(feastol, opttol))) + 1;
1279 std::cout.setf( std::ios::scientific | std::ios::showpoint );
1280 std::cerr.setf( std::ios::scientific | std::ios::showpoint );
1282 #ifdef SEND_ALL_OUTPUT_TO_FILES
1285 std::ofstream myerrstream (
"errwarn.txt" );
1286 std::ofstream myinfostream(
"infos.txt" );
1287 redirect_output(myerrstream, myinfostream);
1291 MySoPlex work( type, representation );
1293 work.
setFeastol ( std::min(feastol, delta) );
1294 work.
setOpttol ( std::min(opttol, delta) );
1326 print_solution, print_dual, write_basis, basisname);
1329 clean_up(prescaler, postscaler, simplifier, starter, pricer, ratiotester, basisname);
1334 std::cout <<
"exception caught : " << x.
what() << std::endl;
1335 delete [] basisname;