From 072dc7be91cbf1dc4e3c87661283aac4eb254106 Mon Sep 17 00:00:00 2001 From: Florian OMNES Date: Tue, 7 Jan 2025 14:59:14 +0100 Subject: [PATCH] Better handling of variable bounds for BOOL variables --- .../optim-model-filler/ComponentFiller.cpp | 31 ++++++++++++++++--- 1 file changed, 27 insertions(+), 4 deletions(-) diff --git a/src/solver/optim-model-filler/ComponentFiller.cpp b/src/solver/optim-model-filler/ComponentFiller.cpp index 49a66cda11..b8c059eaf4 100644 --- a/src/solver/optim-model-filler/ComponentFiller.cpp +++ b/src/solver/optim-model-filler/ComponentFiller.cpp @@ -43,10 +43,33 @@ void ComponentFiller::addVariables(Solver::Modeler::Api::ILinearProblem& pb, auto evaluator = std::make_unique(evaluationContext_); for (const auto& variable: component_.getModel()->Variables() | std::views::values) { - pb.addVariable(evaluator->dispatch(variable.LowerBound().RootNode()), - evaluator->dispatch(variable.UpperBound().RootNode()), - variable.Type() != Study::SystemModel::ValueType::FLOAT, - component_.Id() + "." + variable.Id()); + const auto variableID = component_.Id() + "." + variable.Id(); + switch (variable.Type()) + { + case Study::SystemModel::ValueType::BOOL: + { + pb.addVariable(0., 1., true, variableID); + break; + } + case Study::SystemModel::ValueType::INTEGER: + { + pb.addVariable(evaluator->dispatch(variable.LowerBound().RootNode()), + evaluator->dispatch(variable.UpperBound().RootNode()), + true, + variableID); + break; + } + case Study::SystemModel::ValueType::CONTINUOUS: + { + pb.addVariable(evaluator->dispatch(variable.LowerBound().RootNode()), + evaluator->dispatch(variable.UpperBound().RootNode()), + false, + variableID); + break; + } + default: + throw std::invalid_argument("Invalid type for variable"); + } } }