Skip to content

Commit

Permalink
Add missing parameter to command built by batchrun for OR-Tools (#1984)
Browse files Browse the repository at this point in the history
  • Loading branch information
flomnes authored Mar 13, 2024
1 parent 0711321 commit 9d9c7f6
Showing 1 changed file with 160 additions and 148 deletions.
308 changes: 160 additions & 148 deletions src/tools/batchrun/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -144,18 +144,17 @@ int main(int argc, char* argv[])
"force-parallel",
"Override the max number of years computed simultaneously");

// add option for ortools use
// --use-ortools
options.addFlag(ortoolsUsed, ' ', "use-ortools", "Use ortools library to launch solver");

//--ortools-solver
options.add(ortoolsSolver,
' ',
"ortools-solver",
"Ortools solver used for simulation (only available with use-ortools "
"option)\nAvailable solver list : "
+ availableOrToolsSolversString());
// add option for ortools use
// --use-ortools
options.addFlag(ortoolsUsed, ' ', "use-ortools", "Use ortools library to launch solver");

//--ortools-solver
options.add(ortoolsSolver,
' ',
"ortools-solver",
"Ortools solver used for simulation (only available with use-ortools "
"option)\nAvailable solver list : "
+ availableOrToolsSolversString());

options.remainingArguments(optInput);
// Version
Expand Down Expand Up @@ -190,166 +189,179 @@ int main(int argc, char* argv[])
logs.error() << "contradictory options: --economy and --adequacy";
return EXIT_FAILURE;
}
}

// Source Folder
logs.debug() << "Folder : `" << optInput << '`';

String solver;
if (optSolver.empty())
{
Solver::FindLocation(solver);
if (solver.empty())
{
logs.fatal() << "The solver has not been found";
return EXIT_FAILURE;
}
}
else
{
String tmp;
IO::MakeAbsolute(tmp, *optSolver);
IO::Normalize(solver, tmp);
if (not IO::File::Exists(solver))
if (ortoolsUsed)
{
logs.fatal() << "The solver has not been found. specify --solver=" << solver;
return EXIT_FAILURE;
const auto availableSolvers = getAvailableOrtoolsSolverName();
if (auto it
= std::find(availableSolvers.begin(), availableSolvers.end(), ortoolsSolver);
it == availableSolvers.end())
{
logs.error() << "Please specify a solver using --ortools-solver. Available solvers "
<< availableOrToolsSolversString() << "";
return EXIT_FAILURE;
}
}
}

logs.info() << " Solver: '" << solver << "'";
logs.info();
logs.info();
logs.info() << "Searching for studies...";
logs.info();
MyStudyFinder finder;
finder.lookup(optInput);
finder.wait();
// Source Folder
logs.debug() << "Folder : `" << optInput << '`';

if (not finder.list.empty())
{
if (finder.list.size() > 1)
logs.info() << "Found " << finder.list.size() << " studyies";
String solver;
if (optSolver.empty())
{
Solver::FindLocation(solver);
if (solver.empty())
{
logs.fatal() << "The solver has not been found";
return EXIT_FAILURE;
}
}
else
logs.info() << "Found 1 study";
logs.info() << "Starting...";

if (!(!optName))
{
String name;
name = *optName;
name.replace("\"", "\\\"");
*optName = name;
String tmp;
IO::MakeAbsolute(tmp, *optSolver);
IO::Normalize(solver, tmp);
if (not IO::File::Exists(solver))
{
logs.fatal() << "The solver has not been found. specify --solver=" << solver;
return EXIT_FAILURE;
}
}

// The folder that contains the solver
String dirname;
IO::parent_path(dirname, solver);

String cmd;
logs.info() << " Solver: '" << solver << "'";
logs.info();
logs.info();
logs.info() << "Searching for studies...";
logs.info();
MyStudyFinder finder;
finder.lookup(optInput);
finder.wait();

uint studyIndx = 0;
foreach (auto& studypath, finder.list)
if (not finder.list.empty())
{
++studyIndx;

logs.info();
if (optVerbose)
logs.info();

logs.checkpoint() << "Running simulation: `" << studypath << "` (" << studyIndx << '/'
<< (uint)finder.list.size() << ')';
if (optVerbose)
logs.debug();

cmd.clear();
if (not System::windows)
cmd << "nice ";
if (finder.list.size() > 1)
logs.info() << "Found " << finder.list.size() << " studyies";
else
cmd << "call "; // why is it required for working ???
cmd << "\"" << solver << "\"";
if (optForce)
cmd << " --force";
if (optForceExpansion)
cmd << " --economy";
if (optForceEconomy)
cmd << " --economy";
if (optForceAdequacy)
cmd << " --adequacy";
logs.info() << "Found 1 study";
logs.info() << "Starting...";

if (!(!optName))
cmd << " --name=\"" << *optName << "\"";
if (!(!optYears))
cmd << " --year=" << *optYears;
if (optNoOutput)
cmd << " --no-output";
if (optYearByYear)
cmd << " --year-by-year";
if (optNoTSImport)
cmd << " --no-ts-import";
if (optIgnoreAllConstraints)
cmd << " --no-constraints";
if (optParallel)
cmd << " --parallel";
if (optForceParallel)
cmd << " --force-parallel=" << *optForceParallel;
if (ortoolsUsed)
cmd << " --ortools-solver=" << ortoolsSolver;

cmd << " \"" << studypath << "\"";
if (!optVerbose)
cmd << sendToNull();

// Changing the current working directory
IO::Directory::Current::Set(dirname);
// Executing the converter
if (optVerbose)
logs.info() << "Executing " << cmd;
{
String name;
name = *optName;
name.replace("\"", "\\\"");
*optName = name;
}

// Execute the command
int cmd_return_code = system(cmd.c_str());
// The folder that contains the solver
String dirname;
IO::parent_path(dirname, solver);

if (cmd_return_code != 0)
logs.error() << "An error occured.";
else
logs.info() << "Success.";
String cmd;

if (cmd_return_code == -1)
uint studyIndx = 0;
foreach (auto& studypath, finder.list)
{
#ifdef YUNI_OS_WINDOWS
switch (errno)
++studyIndx;

logs.info();
if (optVerbose)
logs.info();

logs.checkpoint() << "Running simulation: `" << studypath << "` (" << studyIndx
<< '/' << (uint)finder.list.size() << ')';
if (optVerbose)
logs.debug();

cmd.clear();
if (not System::windows)
cmd << "nice ";
else
cmd << "call "; // why is it required for working ???
cmd << "\"" << solver << "\"";
if (optForce)
cmd << " --force";
if (optForceExpansion)
cmd << " --economy";
if (optForceEconomy)
cmd << " --economy";
if (optForceAdequacy)
cmd << " --adequacy";
if (!(!optName))
cmd << " --name=\"" << *optName << "\"";
if (!(!optYears))
cmd << " --year=" << *optYears;
if (optNoOutput)
cmd << " --no-output";
if (optYearByYear)
cmd << " --year-by-year";
if (optNoTSImport)
cmd << " --no-ts-import";
if (optIgnoreAllConstraints)
cmd << " --no-constraints";
if (optParallel)
cmd << " --parallel";
if (optForceParallel)
cmd << " --force-parallel=" << *optForceParallel;
if (ortoolsUsed)
cmd << " --use-ortools --ortools-solver=" << ortoolsSolver;

cmd << " \"" << studypath << "\"";
if (!optVerbose)
cmd << sendToNull();

// Changing the current working directory
IO::Directory::Current::Set(dirname);
// Executing the converter
if (optVerbose)
logs.info() << "Executing " << cmd;

// Execute the command
int cmd_return_code = system(cmd.c_str());

if (cmd_return_code != 0)
logs.error() << "An error occured.";
else
logs.info() << "Success.";

if (cmd_return_code == -1)
{
case E2BIG:
logs.error() << "Argument list (which is system dependent) is too big";
break;
case ENOENT:
logs.error() << "Command interpreter cannot be found";
break;
case ENOEXEC:
logs.error()
<< "Command-interpreter file has invalid format and is not executable";
break;
case ENOMEM:
logs.error() << "Not enough memory is available to execute command";
break;
}
#ifdef YUNI_OS_WINDOWS
switch (errno)
{
case E2BIG:
logs.error() << "Argument list (which is system dependent) is too big";
break;
case ENOENT:
logs.error() << "Command interpreter cannot be found";
break;
case ENOEXEC:
logs.error()
<< "Command-interpreter file has invalid format and is not executable";
break;
case ENOMEM:
logs.error() << "Not enough memory is available to execute command";
break;
}
#endif
}
}
}

logs.info() << "Done.";
logs.info() << "Done.";

// Time interval
if (optVerbose)
// Time interval
if (optVerbose)
{
logs.debug();
logs.debug();
}
}
else
{
logs.debug();
logs.debug();
logs.fatal() << "No study has been found.";
return 4;
}
}
else
{
logs.fatal() << "No study has been found.";
return 4;
}

return 0;
return 0;
}
}

0 comments on commit 9d9c7f6

Please sign in to comment.