Antares Simulator
Power System Simulator
VariabilityVisitor.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 #pragma once
22 
23 #include "antares/expressions/visitors/NodeVisitor.h"
24 #include "antares/modeler-optimisation-container/EvaluationContext.h"
25 #include "antares/modeler-optimisation-container/OptimEntityContainer.h"
26 #include "antares/study/system-model/component.h"
27 
28 namespace Antares::Expressions::Visitors
29 {
34 class VariabilityVisitor: public NodeVisitor<Optimisation::VariabilityType>
35 {
36 public:
37  explicit VariabilityVisitor(const Optimisation::OptimEntityContainer& optimEntityContainer,
38  const ModelerStudy::SystemModel::Component& component);
39 
40  std::string name() const override;
41 
42 private:
43  Optimisation::VariabilityType processParentNode(const Nodes::ParentNode* node);
44  Optimisation::VariabilityType visit(const Nodes::SumNode* add) override;
45  Optimisation::VariabilityType visit(const Nodes::SubtractionNode* add) override;
47  Optimisation::VariabilityType visit(const Nodes::DivisionNode* add) override;
48  Optimisation::VariabilityType visit(const Nodes::EqualNode* add) override;
51  Optimisation::VariabilityType visit(const Nodes::NegationNode* neg) override;
52  Optimisation::VariabilityType visit(const Nodes::VariableNode* param) override;
53  Optimisation::VariabilityType visit(const Nodes::ParameterNode* param) override;
54  Optimisation::VariabilityType visit(const Nodes::LiteralNode* lit) override;
55  Optimisation::VariabilityType visit(const Nodes::PortFieldNode* port_field_node) override;
56  Optimisation::VariabilityType visit(const Nodes::PortFieldSumNode* port_field_node) override;
57  Optimisation::VariabilityType visit(const Nodes::TimeShiftNode* timeShiftNode) override;
58  Optimisation::VariabilityType visit(const Nodes::TimeIndexNode* timeIndexNode) override;
59  Optimisation::VariabilityType visit(const Nodes::TimeSumNode* timeSumNode) override;
60  Optimisation::VariabilityType visit(const Nodes::AllTimeSumNode* timeSumNode) override;
61  Optimisation::VariabilityType handleReducedCost(const Nodes::FunctionNode* node);
62  Optimisation::VariabilityType handleDual(const Nodes::FunctionNode* node);
64  Optimisation::VariabilityType visit(const Nodes::FunctionNode* node) override;
65 
66  std::vector<const ModelerStudy::SystemModel::Component*> getConnectedComponents();
67 
68  const Optimisation::OptimEntityContainer& optimEntityContainer_;
69  const ModelerStudy::SystemModel::Component& component_;
70  const Optimisation::EvaluationContext& context_;
71 };
72 } // namespace Antares::Expressions::Visitors
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
Definition: ParentNode.h:41
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
Represents a visitor for determining the time and scenario dependency of nodes in a syntax tree.
Definition: VariabilityVisitor.h:35
Represents the context for evaluating expressions.
Definition: EvaluationContext.h:25
Definition: OptimEntityContainer.h:46
VariabilityType
Represents the time and scenario variation of a value.
Definition: variabilityType.h:29