Antares Simulator
Power System Simulator
ReadLinearConstraintVisitor.h
1 /*
2  * Copyright 2007-2025, RTE (https://www.rte-france.com)
3  * See AUTHORS.txt
4  * SPDX-License-Identifier: MPL-2.0
5  * This file is part of Antares-Simulator,
6  * Adequacy and Performance assessment for interconnected energy networks.
7  *
8  * Antares_Simulator is free software: you can redistribute it and/or modify
9  * it under the terms of the Mozilla Public Licence 2.0 as published by
10  * the Mozilla Foundation, either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * Antares_Simulator is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * Mozilla Public Licence 2.0 for more details.
17  *
18  * You should have received a copy of the Mozilla Public Licence 2.0
19  * along with Antares_Simulator. If not, see <https://opensource.org/license/mpl-2-0/>.
20  */
21 
22 #pragma once
23 
24 #include <antares/expressions/visitors/NodeVisitor.h>
25 
26 #include "ReadLinearExpressionVisitor.h"
27 #include "TimeDependentLinearExpression.h"
28 
29 namespace Antares::Optimisation
30 {
31 class OptimEntityContainer;
32 } // namespace Antares::Optimisation
33 
39 namespace Antares::Optimisation
40 {
41 
50 {
52  std::vector<double> lb;
53  std::vector<double> ub;
54 };
55 
57 {
58 public:
59  ReadLinearConstraintVisitor() = delete;
61  const Optimisation::OptimEntityContainer& optimEntityContainer,
63  const ModelerStudy::SystemModel::Component& component);
64 
65  std::string name() const override;
66 
67 private:
68  LinearConstraint visit(const Expressions::Nodes::SumNode* node) override;
69  LinearConstraint visit(const Expressions::Nodes::SubtractionNode* node) override;
70  LinearConstraint visit(const Expressions::Nodes::MultiplicationNode* node) override;
71  LinearConstraint visit(const Expressions::Nodes::DivisionNode* node) override;
72  LinearConstraint visit(const Expressions::Nodes::EqualNode* node) override;
75  LinearConstraint visit(const Expressions::Nodes::NegationNode* node) override;
76  LinearConstraint visit(const Expressions::Nodes::VariableNode* node) override;
77  LinearConstraint visit(const Expressions::Nodes::ParameterNode* node) override;
78  LinearConstraint visit(const Expressions::Nodes::LiteralNode* node) override;
79  LinearConstraint visit(const Expressions::Nodes::PortFieldNode* node) override;
80  LinearConstraint visit(const Expressions::Nodes::PortFieldSumNode* node) override;
81  LinearConstraint visit(const Expressions::Nodes::TimeShiftNode* node) override;
82  LinearConstraint visit(const Expressions::Nodes::TimeIndexNode* node) override;
83  LinearConstraint visit(const Expressions::Nodes::TimeSumNode* node) override;
84  LinearConstraint visit(const Expressions::Nodes::AllTimeSumNode* node) override;
85  LinearConstraint visit(const Expressions::Nodes::FunctionNode* node) override;
86 
87  ReadLinearExpressionVisitor linear_expression_visitor_;
88 };
89 } // namespace Antares::Optimisation
Represents a AllTimeSumNode node in a syntax tree.
Definition: AllTimeSumNode.h:31
Represents a division node in a syntax tree.
Definition: DivisionNode.h:31
Represents an equality comparison node in a syntax tree.
Definition: EqualNode.h:31
AST node representing a function expression (max, min, pow, ...).
Definition: FunctionNode.h:63
Represents a greater than or equal comparison node in a syntax tree.
Definition: GreaterThanOrEqualNode.h:31
Represents a less than or equal comparison node in a syntax tree.
Definition: LessThanOrEqualNode.h:31
Represents a literal node in a syntax tree, storing a double value.
Definition: LiteralNode.h:11
Represents a multiplication node in a syntax tree.
Definition: MultiplicationNode.h:31
Represents a negation node in a syntax tree.
Definition: NegationNode.h:31
Represents a parameter node in a syntax tree, storing a string value.
Definition: ParameterNode.h:14
Represents a port field node in a syntax tree.
Definition: PortFieldNode.h:32
Represents a port field node where the expression is a sum.
Definition: PortFieldSumNode.h:32
Represents a subtraction node in a syntax tree.
Definition: SubtractionNode.h:31
Definition: SumNode.h:29
Definition: TimeIndexNode.h:28
Definition: TimeShiftNode.h:29
Definition: TimeSumNode.h:28
Represents a variable node in a syntax tree, storing a string value.
Definition: VariableNode.h:20
Context for filling linear problem data. Contains temporal information.
Definition: ILinearProblemData.h:35
Definition: OptimEntityContainer.h:46
Definition: ReadLinearConstraintVisitor.h:57
Definition: ReadLinearExpressionVisitor.h:46
Definition: TimeDependentLinearExpression.h:31
Definition: VariableNode.h:9
Definition: ReadLinearConstraintVisitor.h:50