From cbd55e5c0135a860e3e9555443a74ed8e1bc574a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Florian=20Omn=C3=A8s?= <26088210+flomnes@users.noreply.github.com> Date: Mon, 11 Dec 2023 16:47:58 +0100 Subject: [PATCH] Normalize simulation mode Expansion, fix logs (#1771) * Fix expansion logs, clean up & refactor * Use enum class SimulationMode instead of enum StudyMode * Do not force MPS export when Expansion mode is enabled --- src/libs/antares/CMakeLists.txt | 1 - src/libs/antares/constants.h | 1 - src/libs/antares/exception/LoadingError.cpp | 2 +- .../antares/exception/LoadingError.hpp | 4 +- src/libs/antares/study/area/list.cpp | 2 +- src/libs/antares/study/area/scratchpad.cpp | 2 +- src/libs/antares/study/fwd.h | 18 ++--- src/libs/antares/study/load-options.cpp | 8 +- src/libs/antares/study/load-options.h | 2 +- src/libs/antares/study/output.cpp | 6 +- src/libs/antares/study/output.h | 2 +- src/libs/antares/study/parameters.cpp | 73 ++++++------------- src/libs/antares/study/parameters.h | 17 ++--- .../study/parameters/adq-patch-params.cpp | 10 +-- .../study/parameters/adq-patch-params.h | 4 +- src/libs/antares/study/runtime/runtime.cpp | 2 +- src/libs/antares/study/runtime/runtime.h | 2 +- src/libs/antares/study/study.cpp | 15 ++-- src/libs/antares/study/study.h | 2 +- src/libs/antares/xpansion.h | 4 - src/solver/application.cpp | 5 +- src/solver/hydro/management/management.cpp | 6 +- src/solver/hydro/management/management.h | 2 +- .../opt_optimisation_lineaire.cpp | 3 +- src/solver/simulation/common-eco-adq.cpp | 2 +- .../simulation/sim_calcul_economique.cpp | 2 +- src/solver/variable/commons/rowBalance.h | 2 +- src/solver/variable/state.cpp | 6 +- src/solver/variable/state.h | 4 +- src/solver/variable/state.hxx | 18 ++--- .../variable/surveyresults/surveyresults.cpp | 16 ++-- .../antares/study/output-folder/study.cpp | 8 +- .../solver/optimisation/adequacy_patch.cpp | 6 +- src/ui/simulator/application/main/refresh.cpp | 24 +++--- .../windows/inspector/accumulator.hxx | 15 ++-- .../simulator/windows/inspector/constants.cpp | 5 +- .../simulator/windows/inspector/constants.h | 2 +- src/ui/simulator/windows/inspector/frame.cpp | 4 +- src/ui/simulator/windows/inspector/frame.h | 2 +- .../windows/inspector/property.update.cpp | 8 +- .../windows/output/panel/area-link.cpp | 11 +-- .../windows/output/provider/outputs.cpp | 11 +-- src/ui/simulator/windows/simulation/run.cpp | 4 +- 43 files changed, 146 insertions(+), 197 deletions(-) delete mode 100644 src/libs/antares/xpansion.h diff --git a/src/libs/antares/CMakeLists.txt b/src/libs/antares/CMakeLists.txt index 02d9254105..a0ef1e2adb 100644 --- a/src/libs/antares/CMakeLists.txt +++ b/src/libs/antares/CMakeLists.txt @@ -26,7 +26,6 @@ set(SRC config.h constants.h constants.cpp - xpansion.h # Misc locale.h diff --git a/src/libs/antares/constants.h b/src/libs/antares/constants.h index f82f0372de..acb9d975cb 100644 --- a/src/libs/antares/constants.h +++ b/src/libs/antares/constants.h @@ -28,7 +28,6 @@ #ifndef __ANTARES_LIBS_CONSTANTS_H__ #define __ANTARES_LIBS_CONSTANTS_H__ -#include "xpansion.h" #include /*! Name of the app to use into logs */ diff --git a/src/libs/antares/exception/LoadingError.cpp b/src/libs/antares/exception/LoadingError.cpp index 92c6f26bfa..1e989c5dd2 100644 --- a/src/libs/antares/exception/LoadingError.cpp +++ b/src/libs/antares/exception/LoadingError.cpp @@ -132,7 +132,7 @@ CommandLineArguments::CommandLineArguments(uint errors) : { } -IncompatibleStudyModeForAdqPatch::IncompatibleStudyModeForAdqPatch() : +IncompatibleSimulationModeForAdqPatch::IncompatibleSimulationModeForAdqPatch() : LoadingError("Adequacy Patch can only be used with Economy Simulation Mode") { } diff --git a/src/libs/antares/exception/antares/exception/LoadingError.hpp b/src/libs/antares/exception/antares/exception/LoadingError.hpp index d3b7e15b74..d4609e664e 100644 --- a/src/libs/antares/exception/antares/exception/LoadingError.hpp +++ b/src/libs/antares/exception/antares/exception/LoadingError.hpp @@ -179,10 +179,10 @@ class CommandLineArguments : public LoadingError explicit CommandLineArguments(uint errors); }; -class IncompatibleStudyModeForAdqPatch : public LoadingError +class IncompatibleSimulationModeForAdqPatch : public LoadingError { public: - IncompatibleStudyModeForAdqPatch(); + IncompatibleSimulationModeForAdqPatch(); }; class NoAreaInsideAdqPatchMode : public LoadingError diff --git a/src/libs/antares/study/area/list.cpp b/src/libs/antares/study/area/list.cpp index 9e6a324e26..c732091d4a 100644 --- a/src/libs/antares/study/area/list.cpp +++ b/src/libs/antares/study/area/list.cpp @@ -937,7 +937,7 @@ static bool AreaListLoadFromFolderSingleArea(Study& study, ret = area.thermal.list.loadEconomicCosts(study, buffer) && ret; // In adequacy mode, all thermal clusters must be in 'mustrun' mode - if (study.usedByTheSolver && study.parameters.mode == stdmAdequacy) + if (study.usedByTheSolver && study.parameters.mode == SimulationMode::Adequacy) area.thermal.list.enableMustrunForEveryone(); } diff --git a/src/libs/antares/study/area/scratchpad.cpp b/src/libs/antares/study/area/scratchpad.cpp index 26595ae28d..2ed6a1bbbd 100644 --- a/src/libs/antares/study/area/scratchpad.cpp +++ b/src/libs/antares/study/area/scratchpad.cpp @@ -72,7 +72,7 @@ AreaScratchpad::AreaScratchpad(const StudyRuntimeInfos& rinfos, Area& area) sum += area.miscGen[w][h]; miscGenSum[h] = sum; } - if (mode == Data::stdmAdequacy) + if (mode == Data::SimulationMode::Adequacy) { for (uint h = 0; h != area.miscGen.height; ++h) miscGenSum[h] -= area.reserves[Data::fhrPrimaryReserve][h]; diff --git a/src/libs/antares/study/fwd.h b/src/libs/antares/study/fwd.h index 8e3dca76d1..839cb4d04e 100644 --- a/src/libs/antares/study/fwd.h +++ b/src/libs/antares/study/fwd.h @@ -97,21 +97,19 @@ enum StudyError }; /*! -** \brief Types of Study +** \brief Types of Simulation */ -enum StudyMode +enum class SimulationMode { - stdmUnknown = -1, //! Economic - stdmEconomy, + Economy, //! Adequacy (subset of the economy mode) - stdmAdequacy, + Adequacy, //! Expansion - stdmExpansion, - //! Max - stdmMax - -}; // enum StudyMode + Expansion, + //! Unknown simulation mode + Unknown +}; /* ** \brief Simplex optimizations diff --git a/src/libs/antares/study/load-options.cpp b/src/libs/antares/study/load-options.cpp index ed9e57eded..4cd7281af2 100644 --- a/src/libs/antares/study/load-options.cpp +++ b/src/libs/antares/study/load-options.cpp @@ -44,7 +44,7 @@ StudyLoadOptions::StudyLoadOptions() : simplexOptimizationRange(sorUnknown), mpsToExport(false), ignoreConstraints(false), - forceMode(stdmUnknown), + forceMode(SimulationMode::Unknown), enableParallel(false), forceParallel(false), maxNbYearsInParallel(0), @@ -74,11 +74,11 @@ void StudyLoadOptions::checkForceSimulationMode() throw Error::InvalidSimulationMode(); } if (forceExpansion) - forceMode = stdmExpansion; + forceMode = SimulationMode::Expansion; else if (forceEconomy) - forceMode = stdmEconomy; + forceMode = SimulationMode::Economy; else if (forceAdequacy) - forceMode = stdmAdequacy; + forceMode = SimulationMode::Adequacy; } } // namespace Data } // namespace Antares diff --git a/src/libs/antares/study/load-options.h b/src/libs/antares/study/load-options.h index 6c2dd5f644..bce161bfda 100644 --- a/src/libs/antares/study/load-options.h +++ b/src/libs/antares/study/load-options.h @@ -76,7 +76,7 @@ class StudyLoadOptions //! Ignore all constraints bool ignoreConstraints; //! Simulation mode - StudyMode forceMode; + SimulationMode forceMode; //! Enables the parallel computation of MC years bool enableParallel; diff --git a/src/libs/antares/study/output.cpp b/src/libs/antares/study/output.cpp index ad35c6519c..0cb8abd810 100644 --- a/src/libs/antares/study/output.cpp +++ b/src/libs/antares/study/output.cpp @@ -89,7 +89,7 @@ class OutputFolderIterator : public IO::Directory::IIterator } // anonymous namespace Output::Output(const AnyString& folder) : - version(0), timestamp(0), mode(Data::stdmEconomy), menuID(-1), viewMenuID(-1), outputViewerID(-1) + version(0), timestamp(0), mode(Data::SimulationMode::Economy), menuID(-1), viewMenuID(-1), outputViewerID(-1) { loadFromFolder(folder); } @@ -110,7 +110,7 @@ bool Output::loadFromFolder(const AnyString& folder) name.clear(); path.clear(); version = 0; - mode = Data::stdmUnknown; + mode = Data::SimulationMode::Unknown; // Load the INI file in memory IniFile ini; @@ -152,7 +152,7 @@ bool Output::loadFromFolder(const AnyString& folder) { if (p->key == "mode") { - StringToStudyMode(mode, p->value); + StringToSimulationMode(mode, p->value); } else { diff --git a/src/libs/antares/study/output.h b/src/libs/antares/study/output.h index 5b3615c4a1..3d26b54dc3 100644 --- a/src/libs/antares/study/output.h +++ b/src/libs/antares/study/output.h @@ -91,7 +91,7 @@ class Output final //! Date/time when the simulation has been launched int64_t timestamp; //! Mode (economy/adequacy/other) - Data::StudyMode mode; + Data::SimulationMode mode; //! Tag for storing a wx menu id int menuID; //! Tag for storing a wx menu id (from the menu `output`) diff --git a/src/libs/antares/study/parameters.cpp b/src/libs/antares/study/parameters.cpp index c686e6a3cc..0a3be6df4f 100644 --- a/src/libs/antares/study/parameters.cpp +++ b/src/libs/antares/study/parameters.cpp @@ -137,7 +137,7 @@ static void ParametersSaveResultFormat(IniFile::Section* section, ResultFormat f } } -bool StringToStudyMode(StudyMode& mode, CString<20, false> text) +bool StringToSimulationMode(SimulationMode& mode, CString<20, false> text) { if (!text) return false; @@ -151,38 +151,37 @@ bool StringToStudyMode(StudyMode& mode, CString<20, false> text) if (text == "economy" || text == "economic") { // The term `economic` was mis-used in previous versions of antares (<3.4) - mode = stdmEconomy; + mode = SimulationMode::Economy; return true; } // Adequacy if (text == "adequacy") { - mode = stdmAdequacy; + mode = SimulationMode::Adequacy; return true; } // Expansion if (text == "expansion") { - mode = stdmExpansion; + mode = SimulationMode::Expansion; return true; } return false; } -const char* StudyModeToCString(StudyMode mode) +const char* SimulationModeToCString(SimulationMode mode) { switch (mode) { - case stdmEconomy: + case SimulationMode::Economy: return "Economy"; - case stdmAdequacy: + case SimulationMode::Adequacy: return "Adequacy"; - case stdmMax: - case stdmExpansion: - case stdmUnknown: + case SimulationMode::Expansion: + return "Expansion"; + default: return "Unknown"; } - return "Unknown"; } Parameters::Parameters() : noOutput(false) @@ -193,12 +192,12 @@ Parameters::~Parameters() = default; bool Parameters::economy() const { - return mode == stdmEconomy; + return mode == SimulationMode::Economy; } bool Parameters::adequacy() const { - return mode == stdmAdequacy; + return mode == SimulationMode::Adequacy; } void Parameters::resetSeeds() @@ -230,9 +229,7 @@ void Parameters::resetPlayedYears(uint nbOfYears) void Parameters::reset() { // Mode - mode = stdmEconomy; - // Expansion - expansion = false; + mode = SimulationMode::Economy; // Calendar horizon.clear(); @@ -447,7 +444,7 @@ static bool SGDIntLoadFamily_General(Parameters& d, return value.to(d.leapYear); if (key == "mode") - return StringToStudyMode(d.mode, value); + return StringToSimulationMode(d.mode, value); if (key == "nbyears") { @@ -1039,29 +1036,14 @@ bool Parameters::loadFromINI(const IniFile& ini, uint version, const StudyLoadOp } // Simulation mode - // ... Expansion - if (mode == stdmExpansion) - { - mode = stdmEconomy; - expansion = true; - } - // ... Enforcing simulation mode - if (options.forceMode != stdmUnknown) + if (options.forceMode != SimulationMode::Unknown) { - if (options.forceMode == stdmExpansion) - { - mode = stdmEconomy; - expansion = true; - } - else - mode = options.forceMode; - - logs.info() << " forcing the simulation mode " << StudyModeToCString(mode); - assert(mode != stdmMax && "Invalid simulation mode"); + mode = options.forceMode; + logs.info() << " forcing the simulation mode " << SimulationModeToCString(mode); } else - logs.info() << " simulation mode: " << StudyModeToCString(mode); + logs.info() << " simulation mode: " << SimulationModeToCString(mode); if (options.forceDerated) derated = true; @@ -1357,17 +1339,16 @@ void Parameters::prepareForSimulation(const StudyLoadOptions& options) switch (mode) { - case stdmEconomy: - case stdmAdequacy: + case SimulationMode::Economy: + case SimulationMode::Adequacy: + case SimulationMode::Expansion: { // The year-by-year mode might have been requested from the command line if (options.forceYearByYear) yearByYear = true; break; } - case stdmUnknown: - case stdmExpansion: - case stdmMax: + case SimulationMode::Unknown: { // The mode year-by-year can not be enabled in adequacy yearByYear = false; @@ -1437,7 +1418,7 @@ void Parameters::prepareForSimulation(const StudyLoadOptions& options) exportTimeSeriesInInput = 0; } - if (expansion) + if (mode == SimulationMode::Expansion) logs.info() << " :: enabling expansion"; if (yearByYear) logs.info() << " :: enabling the 'year-by-year' mode"; @@ -1504,13 +1485,7 @@ void Parameters::saveToINI(IniFile& ini) const auto* section = ini.addSection("general"); // Mode - if (expansion && mode == stdmEconomy) - section->add("mode", "Expansion"); - else - { - section->add("mode", StudyModeToCString(mode)); - expansion = false; - } + section->add("mode", SimulationModeToCString(mode)); // Calendar section->add("horizon", horizon); diff --git a/src/libs/antares/study/parameters.h b/src/libs/antares/study/parameters.h index 325a62862b..ba951766de 100644 --- a/src/libs/antares/study/parameters.h +++ b/src/libs/antares/study/parameters.h @@ -201,14 +201,9 @@ class Parameters final //! \name Mode //@{ //! Mode of the study (adequacy, economy...) - StudyMode mode; + SimulationMode mode; //@} - //! \name Expansion - //@{ - //! Expansion flag - mutable bool expansion; - //! \name Horizon //@{ //! Horizon year @@ -542,18 +537,18 @@ class Parameters final }; // class Parameters /*! -** \brief Convert a study mode (enum) into a human readable C-String +** \brief Convert a simulation mode (enum) into a human readable C-String */ -const char* StudyModeToCString(StudyMode mode); +const char* SimulationModeToCString(SimulationMode mode); /*! -** \brief Convert a C-String (lowercase) into a study mode if possible +** \brief Convert a C-String (lowercase) into a simulation mode if possible ** -** \param[out] mode The study mode. It will remain untouched if the conversion failed +** \param[out] mode The simulation mode. It will remain untouched if the conversion failed ** \param Text An arbitrary Text (case insensitive) ** \return True if the conversion succeeded, false otherwise */ -bool StringToStudyMode(StudyMode& mode, Yuni::CString<20, false> text); +bool StringToSimulationMode(SimulationMode& mode, Yuni::CString<20, false> text); } // namespace Antares::Data diff --git a/src/libs/antares/study/parameters/adq-patch-params.cpp b/src/libs/antares/study/parameters/adq-patch-params.cpp index 4b6d9b33fa..2e012ff37d 100644 --- a/src/libs/antares/study/parameters/adq-patch-params.cpp +++ b/src/libs/antares/study/parameters/adq-patch-params.cpp @@ -169,11 +169,11 @@ void AdqPatchParams::saveToINI(IniFile& ini) const curtailmentSharing.addProperties(section); } -bool AdqPatchParams::checkAdqPatchParams(const StudyMode studyMode, +bool AdqPatchParams::checkAdqPatchParams(const SimulationMode simulationMode, const AreaList& areas, const bool includeHurdleCostParameters) const { - checkAdqPatchStudyModeEconomyOnly(studyMode); + checkAdqPatchSimulationModeEconomyOnly(simulationMode); checkAdqPatchContainsAdqPatchArea(areas); checkAdqPatchIncludeHurdleCost(includeHurdleCostParameters); checkAdqPatchDisabledLocalMatching(); @@ -182,10 +182,10 @@ bool AdqPatchParams::checkAdqPatchParams(const StudyMode studyMode, } // Adequacy Patch can only be used with Economy Study/Simulation Mode. -void AdqPatchParams::checkAdqPatchStudyModeEconomyOnly(const StudyMode studyMode) const +void AdqPatchParams::checkAdqPatchSimulationModeEconomyOnly(const SimulationMode simulationMode) const { - if (studyMode != StudyMode::stdmEconomy) - throw Error::IncompatibleStudyModeForAdqPatch(); + if (simulationMode != SimulationMode::Economy) + throw Error::IncompatibleSimulationModeForAdqPatch(); } // When Adequacy Patch is on at least one area must be inside Adequacy patch mode. diff --git a/src/libs/antares/study/parameters/adq-patch-params.h b/src/libs/antares/study/parameters/adq-patch-params.h index 560f8f9d62..8362d66765 100644 --- a/src/libs/antares/study/parameters/adq-patch-params.h +++ b/src/libs/antares/study/parameters/adq-patch-params.h @@ -116,12 +116,12 @@ struct AdqPatchParams void addExcludedVariables(std::vector&) const; bool updateFromKeyValue(const Yuni::String& key, const Yuni::String& value); void saveToINI(IniFile& ini) const; - bool checkAdqPatchParams(const StudyMode studyMode, + bool checkAdqPatchParams(const SimulationMode simulationMode, const AreaList& areas, const bool includeHurdleCostParameters) const; - void checkAdqPatchStudyModeEconomyOnly(const StudyMode studyMode) const; + void checkAdqPatchSimulationModeEconomyOnly(const SimulationMode simulationMode) const; void checkAdqPatchContainsAdqPatchArea(const Antares::Data::AreaList& areas) const; void checkAdqPatchIncludeHurdleCost(const bool includeHurdleCost) const; void checkAdqPatchDisabledLocalMatching() const; diff --git a/src/libs/antares/study/runtime/runtime.cpp b/src/libs/antares/study/runtime/runtime.cpp index 1a58a14f73..039dbea843 100644 --- a/src/libs/antares/study/runtime/runtime.cpp +++ b/src/libs/antares/study/runtime/runtime.cpp @@ -143,7 +143,7 @@ void StudyRuntimeInfos::initializeRangeLimits(const Study& study, StudyRangeLimi // We have here too much hours, the interval will be reduced // Log Entry logs.info() << " Partial week detected. Not allowed in " - << StudyModeToCString(study.parameters.mode); + << SimulationModeToCString(study.parameters.mode); logs.info() << " Time interval that has been requested: " << (1 + a) << ".." << (1 + b); // Reducing diff --git a/src/libs/antares/study/runtime/runtime.h b/src/libs/antares/study/runtime/runtime.h index a499f47483..bd44257269 100644 --- a/src/libs/antares/study/runtime/runtime.h +++ b/src/libs/antares/study/runtime/runtime.h @@ -96,7 +96,7 @@ class StudyRuntimeInfos StudyRangeLimits rangeLimits; //! Mode of the simulation - StudyMode mode; + SimulationMode mode; //! The number of interconnections uint interconnectionsCount() const; diff --git a/src/libs/antares/study/study.cpp b/src/libs/antares/study/study.cpp index dfaf427287..7e9337b93b 100644 --- a/src/libs/antares/study/study.cpp +++ b/src/libs/antares/study/study.cpp @@ -621,7 +621,7 @@ static std::string getOutputSuffix(ResultFormat fmt) } } -YString StudyCreateOutputPath(StudyMode mode, +YString StudyCreateOutputPath(SimulationMode mode, ResultFormat fmt, const YString& outputRoot, const YString& label, @@ -638,15 +638,16 @@ YString StudyCreateOutputPath(StudyMode mode, switch (mode) { - case stdmEconomy: + case SimulationMode::Economy: folderOutput += "eco"; break; - case stdmAdequacy: + case SimulationMode::Adequacy: folderOutput += "adq"; break; - case stdmUnknown: - case stdmExpansion: - case stdmMax: + case SimulationMode::Expansion: + folderOutput += "exp"; + break; + case SimulationMode::Unknown: break; } @@ -731,7 +732,7 @@ void Study::saveAboutTheStudy(Solver::IResultWriter& resultWriter) f << "[general]"; f << "\nversion = " << (uint)Data::versionLatest; f << "\nname = " << simulationComments.name; - f << "\nmode = " << StudyModeToCString(parameters.mode); + f << "\nmode = " << SimulationModeToCString(parameters.mode); f << "\ndate = " << startTimeStr; f << "\ntitle = " << startTimeStr; f << "\ntimestamp = " << pStartTime; diff --git a/src/libs/antares/study/study.h b/src/libs/antares/study/study.h index d52b587604..746df97db6 100644 --- a/src/libs/antares/study/study.h +++ b/src/libs/antares/study/study.h @@ -709,7 +709,7 @@ class Study: public Yuni::NonCopyable, public IObject, public LayerData */ extern YString StudyIconFile; -YString StudyCreateOutputPath(StudyMode mode, +YString StudyCreateOutputPath(SimulationMode mode, ResultFormat fmt, const YString& folder, const YString& label, diff --git a/src/libs/antares/xpansion.h b/src/libs/antares/xpansion.h deleted file mode 100644 index 5405eee1f7..0000000000 --- a/src/libs/antares/xpansion.h +++ /dev/null @@ -1,4 +0,0 @@ -#pragma once - -/*! Enable / Disable the expansion mode */ -#define STUDY_MODE_EXPANSION 0 diff --git a/src/solver/application.cpp b/src/solver/application.cpp index a2aa4e3dbd..feb369601e 100644 --- a/src/solver/application.cpp +++ b/src/solver/application.cpp @@ -231,10 +231,11 @@ void Application::execute() // Run the simulation switch (pStudy->runtime->mode) { - case Data::stdmEconomy: + case Data::SimulationMode::Economy: + case Data::SimulationMode::Expansion: runSimulationInEconomicMode(); break; - case Data::stdmAdequacy: + case Data::SimulationMode::Adequacy: runSimulationInAdequacyMode(); break; default: diff --git a/src/solver/hydro/management/management.cpp b/src/solver/hydro/management/management.cpp index 785961f750..f61bf1f4ce 100644 --- a/src/solver/hydro/management/management.cpp +++ b/src/solver/hydro/management/management.cpp @@ -376,7 +376,7 @@ bool HydroManagement::checkMinGeneration(uint year) const return ret; } -void HydroManagement::prepareNetDemand(uint numSpace, uint year, Data::StudyMode mode) +void HydroManagement::prepareNetDemand(uint numSpace, uint year, Data::SimulationMode mode) { areas_.each([this, &year, &numSpace, &mode](const Data::Area& area) { uint z = area.index; @@ -403,7 +403,7 @@ void HydroManagement::prepareNetDemand(uint numSpace, uint year, Data::StudyMode netdemand = + loadSeries[hour] - windSeries[hour] - scratchpad.miscGenSum[hour] - solarSeries[hour] - ror[hour] - - ((mode != Data::stdmAdequacy) ? scratchpad.mustrunSum[hour] + - ((mode != Data::SimulationMode::Adequacy) ? scratchpad.mustrunSum[hour] : scratchpad.originalMustrunSum[hour]); } @@ -412,7 +412,7 @@ void HydroManagement::prepareNetDemand(uint numSpace, uint year, Data::StudyMode { netdemand = loadSeries[hour] - scratchpad.miscGenSum[hour] - ror[hour] - - ((mode != Data::stdmAdequacy) ? scratchpad.mustrunSum[hour] + - ((mode != Data::SimulationMode::Adequacy) ? scratchpad.mustrunSum[hour] : scratchpad.originalMustrunSum[hour]); area.renewable.list.each([&](const Antares::Data::RenewableCluster& cluster) { diff --git a/src/solver/hydro/management/management.h b/src/solver/hydro/management/management.h index 909da320c8..0166aa41ae 100644 --- a/src/solver/hydro/management/management.h +++ b/src/solver/hydro/management/management.h @@ -135,7 +135,7 @@ class HydroManagement final //! check minimum generation is lower than available inflows bool checkMinGeneration(uint year) const; //! Prepare the net demand for each area - void prepareNetDemand(uint numSpace, uint year, Data::StudyMode mode); + void prepareNetDemand(uint numSpace, uint year, Data::SimulationMode mode); //! Prepare the effective demand for each area void prepareEffectiveDemand(); //! Monthly Optimal generations diff --git a/src/solver/optimisation/opt_optimisation_lineaire.cpp b/src/solver/optimisation/opt_optimisation_lineaire.cpp index b124098e98..131dd2bb0c 100644 --- a/src/solver/optimisation/opt_optimisation_lineaire.cpp +++ b/src/solver/optimisation/opt_optimisation_lineaire.cpp @@ -110,8 +110,7 @@ bool runWeeklyOptimization(const OptimizationOptions& options, writer)) return false; - if (problemeHebdo->ExportMPS != Data::mpsExportStatus::NO_EXPORT - || problemeHebdo->Expansion) + if (problemeHebdo->ExportMPS != Data::mpsExportStatus::NO_EXPORT) { double optimalSolutionCost = OPT_ObjectiveFunctionResult(problemeHebdo, numeroDeLIntervalle, optimizationNumber); diff --git a/src/solver/simulation/common-eco-adq.cpp b/src/solver/simulation/common-eco-adq.cpp index c550b05610..332e7ae493 100644 --- a/src/solver/simulation/common-eco-adq.cpp +++ b/src/solver/simulation/common-eco-adq.cpp @@ -118,7 +118,7 @@ static void RecalculDesEchangesMoyens(Data::Study& study, void PrepareDataFromClustersInMustrunMode(Data::Study& study, uint numSpace, uint year) { - bool inAdequacy = (study.parameters.mode == Data::stdmAdequacy); + bool inAdequacy = (study.parameters.mode == Data::SimulationMode::Adequacy); for (uint i = 0; i < study.areas.size(); ++i) { diff --git a/src/solver/simulation/sim_calcul_economique.cpp b/src/solver/simulation/sim_calcul_economique.cpp index 4ea8e6d150..28df3dba9f 100644 --- a/src/solver/simulation/sim_calcul_economique.cpp +++ b/src/solver/simulation/sim_calcul_economique.cpp @@ -83,7 +83,7 @@ void SIM_InitialisationProblemeHebdo(Data::Study& study, auto& parameters = study.parameters; - problem.Expansion = parameters.expansion; + problem.Expansion = (parameters.mode == Data::SimulationMode::Expansion); problem.firstWeekOfSimulation = false; problem.hydroHotStart diff --git a/src/solver/variable/commons/rowBalance.h b/src/solver/variable/commons/rowBalance.h index f085932f75..ad1a3b4674 100644 --- a/src/solver/variable/commons/rowBalance.h +++ b/src/solver/variable/commons/rowBalance.h @@ -166,7 +166,7 @@ class RowBalance : public Variable::IVariable, NextT, VCardRow area->miscGen.entry[Data::fhhRowBalance], sizeof(double) * height); - if (study->parameters.mode == Data::stdmAdequacy) + if (study->parameters.mode == Data::SimulationMode::Adequacy) { for (unsigned int h = 0; h != height; ++h) pValuesForTheCurrentYear.hour[h] diff --git a/src/solver/variable/state.cpp b/src/solver/variable/state.cpp index 3dc8ee3635..ec50b49940 100644 --- a/src/solver/variable/state.cpp +++ b/src/solver/variable/state.cpp @@ -63,7 +63,7 @@ void ThermalState::StateForAnArea::initializeFromArea(const Data::Area& area) State::State(Data::Study& s) : hourInTheSimulation(0u), dispatchableMargin(nullptr), - studyMode(s.parameters.mode), + simulationMode(s.parameters.mode), unitCommitmentMode(s.parameters.unitCommitment.ucMode), study(s), thermal(s.areas), @@ -108,7 +108,7 @@ void State::initFromThermalClusterIndex(const uint clusterAreaWideIndex) { // otherwise from the solver (most of the time) - if (studyMode != Data::stdmAdequacy) // Economy + if (simulationMode != Data::SimulationMode::Adequacy) // Economy { thermalClusterPMinOfAGroup = problemeHebdo->PaliersThermiquesDuPays[area->index] @@ -145,7 +145,7 @@ void State::initFromThermalClusterIndex(const uint clusterAreaWideIndex) } initFromThermalClusterIndexProduction(clusterAreaWideIndex); - if (studyMode != Data::stdmAdequacy) + if (simulationMode != Data::SimulationMode::Adequacy) { // Minimum power of a group of the cluster, one per year for each cluster - from the // solver diff --git a/src/solver/variable/state.h b/src/solver/variable/state.h index 7969a41906..78ef3690b7 100644 --- a/src/solver/variable/state.h +++ b/src/solver/variable/state.h @@ -206,8 +206,8 @@ class State //! Probleme Hebdo PROBLEME_HEBDO* problemeHebdo; - //! Study mode: economy / adequacy - Data::StudyMode studyMode; + //! Simulation mode: economy / adequacy / expansion + Data::SimulationMode simulationMode; //! Study unit commitment mode: fast(ucHeuristic) / accurate(ucMILP) Data::UnitCommitmentMode unitCommitmentMode; //! Reference to the original study diff --git a/src/solver/variable/state.hxx b/src/solver/variable/state.hxx index dca9b0a9b5..9e8c82ff69 100644 --- a/src/solver/variable/state.hxx +++ b/src/solver/variable/state.hxx @@ -74,23 +74,17 @@ inline void State::initFromAreaIndex(const unsigned int areaIndex, uint numSpace scratchpad = &area->scratchpad[numSpace]; thermalCluster = nullptr; - switch (studyMode) + switch (simulationMode) { - case Data::stdmEconomy: + case Data::SimulationMode::Adequacy: + case Data::SimulationMode::Economy: + case Data::SimulationMode::Expansion: { hourlyResults = &problemeHebdo->ResultatsHoraires[areaIndex]; break; } - case Data::stdmAdequacy: - { - hourlyResults = &problemeHebdo->ResultatsHoraires[areaIndex]; - break; - } - case Data::stdmUnknown: - break; - case Data::stdmExpansion: - break; - case Data::stdmMax: + + case Data::SimulationMode::Unknown: break; } } diff --git a/src/solver/variable/surveyresults/surveyresults.cpp b/src/solver/variable/surveyresults/surveyresults.cpp index 052e7ab383..e12d73049d 100644 --- a/src/solver/variable/surveyresults/surveyresults.cpp +++ b/src/solver/variable/surveyresults/surveyresults.cpp @@ -197,23 +197,17 @@ void SurveyResultsData::initialize(uint maxVariables) switch (study.parameters.mode) { - case Data::stdmEconomy: + case Data::SimulationMode::Adequacy: + case Data::SimulationMode::Economy: + case Data::SimulationMode::Expansion: { matrix.resize(study.areas.size(), study.areas.size()); // The initialization will be done later //::MatrixFill(&matrix, std::numeric_limits::quiet_NaN()); break; } - case Data::stdmAdequacy: - { - matrix.resize(study.areas.size(), study.areas.size()); - // The initialization will be done later - //::MatrixFill(&matrix, std::numeric_limits::quiet_NaN()); - break; - } - case Data::stdmUnknown: - case Data::stdmExpansion: - case Data::stdmMax: + + case Data::SimulationMode::Unknown: break; } } diff --git a/src/tests/src/libs/antares/study/output-folder/study.cpp b/src/tests/src/libs/antares/study/output-folder/study.cpp index 9f55894126..f4df8e3e00 100644 --- a/src/tests/src/libs/antares/study/output-folder/study.cpp +++ b/src/tests/src/libs/antares/study/output-folder/study.cpp @@ -51,7 +51,7 @@ BOOST_AUTO_TEST_SUITE(s) BOOST_FIXTURE_TEST_CASE(economy_legacyfiles_emptylabel, Fixture) { - StudyMode mode = stdmEconomy; + SimulationMode mode = SimulationMode::Economy; ResultFormat fmt = legacyFilesDirectories; const YString label = ""; const int64_t startTime = 1; @@ -63,7 +63,7 @@ BOOST_FIXTURE_TEST_CASE(economy_legacyfiles_emptylabel, Fixture) BOOST_FIXTURE_TEST_CASE(economy_legacyfiles_label_now, Fixture) { - StudyMode mode = stdmEconomy; + SimulationMode mode = SimulationMode::Economy; ResultFormat fmt = legacyFilesDirectories; const YString label = "test"; const int64_t startTime = 1672391667; @@ -75,7 +75,7 @@ BOOST_FIXTURE_TEST_CASE(economy_legacyfiles_label_now, Fixture) BOOST_FIXTURE_TEST_CASE(adequacy_legacyfiles_label_now, Fixture) { - StudyMode mode = stdmAdequacy; + SimulationMode mode = SimulationMode::Adequacy; ResultFormat fmt = legacyFilesDirectories; const YString label = "test"; const int64_t startTime = 1672391667; @@ -93,7 +93,7 @@ BOOST_FIXTURE_TEST_CASE(adequacy_legacyfiles_label_now, Fixture) BOOST_FIXTURE_TEST_CASE(adequacy_zip_label_now, Fixture) { - StudyMode mode = stdmAdequacy; + SimulationMode mode = SimulationMode::Adequacy; ResultFormat fmt = zipArchive; const YString label = "test"; const int64_t startTime = 1672391667; diff --git a/src/tests/src/solver/optimisation/adequacy_patch.cpp b/src/tests/src/solver/optimisation/adequacy_patch.cpp index 2c6c0a5a4d..fcc06b4fd2 100644 --- a/src/tests/src/solver/optimisation/adequacy_patch.cpp +++ b/src/tests/src/solver/optimisation/adequacy_patch.cpp @@ -487,7 +487,7 @@ BOOST_AUTO_TEST_CASE(calculateAreaFlowBalanceForOneTimeStep_outside_inside_Inclu BOOST_AUTO_TEST_CASE(check_valid_adq_param) { auto p = createParams(); - BOOST_CHECK_NO_THROW(p.checkAdqPatchStudyModeEconomyOnly(Antares::Data::stdmEconomy)); + BOOST_CHECK_NO_THROW(p.checkAdqPatchSimulationModeEconomyOnly(Antares::Data::SimulationMode::Economy)); BOOST_CHECK_NO_THROW(p.checkAdqPatchIncludeHurdleCost(true)); BOOST_CHECK_NO_THROW(p.checkAdqPatchDisabledLocalMatching()); } @@ -495,8 +495,8 @@ BOOST_AUTO_TEST_CASE(check_valid_adq_param) BOOST_AUTO_TEST_CASE(check_adq_param_wrong_mode) { auto p = createParams(); - BOOST_CHECK_THROW(p.checkAdqPatchStudyModeEconomyOnly(Antares::Data::stdmAdequacy), - Error::IncompatibleStudyModeForAdqPatch); + BOOST_CHECK_THROW(p.checkAdqPatchSimulationModeEconomyOnly(Antares::Data::SimulationMode::Adequacy), + Error::IncompatibleSimulationModeForAdqPatch); } BOOST_AUTO_TEST_CASE(check_adq_param_wrong_hurdle_cost) diff --git a/src/ui/simulator/application/main/refresh.cpp b/src/ui/simulator/application/main/refresh.cpp index fd07e11408..dc5e6dca75 100644 --- a/src/ui/simulator/application/main/refresh.cpp +++ b/src/ui/simulator/application/main/refresh.cpp @@ -41,9 +41,9 @@ namespace Antares { namespace Forms { -struct CompareByStudyMode final +struct CompareBySimulationMode final { - bool operator()(const Data::StudyMode a, const Data::StudyMode b) const + bool operator()(const Data::SimulationMode a, const Data::SimulationMode b) const { return b < a; } @@ -117,14 +117,14 @@ void ApplWnd::refreshMenuOutput() // NOTE : in some rare cases, it may happen that two simulations have the // same timestamp - using StudyModeT = Data::StudyMode; + using SimulationModeT = Data::SimulationMode; using TemporalMap = std::map; - using Map = std::map; + using Map = std::map; // Getting the list of all available outputs const Data::Output::List& list = ListOfOutputsForTheCurrentStudy; - // The last study mode - Data::StudyMode lastMode = Data::stdmUnknown; + // The last simulation mode + Data::SimulationMode lastMode = Data::SimulationMode::Unknown; // Informations about the outputs Map map; @@ -219,7 +219,7 @@ void ApplWnd::refreshMenuOutput() #ifndef YUNI_OS_WINDOWS (!more ? "images/16x16/minibullet_sel.png" : "images/16x16/minibullet.png"), #else - (((*i)->mode == Data::stdmEconomy) ? "images/misc/economy.png" + (((*i)->mode == Data::SimulationMode::Economy) ? "images/misc/economy.png" : "images/misc/adequacy.png"), #endif s, @@ -273,14 +273,14 @@ void ApplWnd::refreshMenuOutput() // AppendTooManyItems(menu, more); more = 0; } - // if (lastMode != Data::stdmUnknown) + // if (lastMode != Data::SimulationMode::Unknown) // Menu::CreateEmptyItem(menu); lastMode = (*i)->mode; - if (lastMode == Data::stdmUnknown) - lastMode = Data::stdmEconomy; + if (lastMode == Data::SimulationMode::Unknown) + lastMode = Data::SimulationMode::Economy; Menu::CreateGroupItem(menu, - wxStringFromUTF8(StudyModeToCString(lastMode)), + wxStringFromUTF8(SimulationModeToCString(lastMode)), "images/16x16/empty.png"); total = 0; } @@ -308,7 +308,7 @@ void ApplWnd::refreshMenuOutput() #ifndef YUNI_OS_WINDOWS "images/16x16/minibullet.png", #else - (((*i)->mode == Data::stdmEconomy) + (((*i)->mode == Data::SimulationMode::Economy) ? "images/misc/economy.png" : "images/misc/adequacy.png"), #endif diff --git a/src/ui/simulator/windows/inspector/accumulator.hxx b/src/ui/simulator/windows/inspector/accumulator.hxx index 53ea80a8b2..4cc79ca91d 100644 --- a/src/ui/simulator/windows/inspector/accumulator.hxx +++ b/src/ui/simulator/windows/inspector/accumulator.hxx @@ -187,25 +187,24 @@ struct PAreaColor } }; -struct PStudyMode +struct PSimulationMode { - using Type = Data::StudyMode; + using Type = Data::SimulationMode; static Type Value(const Data::Study::Ptr& study) { - return (!(!study) ? study->parameters.mode : Data::stdmEconomy); + return (!(!study) ? study->parameters.mode : Data::SimulationMode::Economy); } static wxString ConvertToString(const Type v) { switch (v) { - case Data::stdmEconomy: + case Data::SimulationMode::Economy: return wxT("Economy"); - case Data::stdmAdequacy: + case Data::SimulationMode::Adequacy: return wxT("Adequacy"); - case Data::stdmExpansion: + case Data::SimulationMode::Expansion: return wxT("Expansion"); - case Data::stdmUnknown: - case Data::stdmMax: + case Data::SimulationMode::Unknown: return wxEmptyString; } return wxEmptyString; diff --git a/src/ui/simulator/windows/inspector/constants.cpp b/src/ui/simulator/windows/inspector/constants.cpp index 67aebf6bd5..f7c7d08244 100644 --- a/src/ui/simulator/windows/inspector/constants.cpp +++ b/src/ui/simulator/windows/inspector/constants.cpp @@ -1,4 +1,3 @@ -#include #include "constants.h" namespace Antares @@ -267,11 +266,9 @@ const wxChar* const calendarWeeks[] = {wxT("MON - SUN"), wxT("SUN - SAT"), nullptr}; -const wxChar* const studyMode[] = {wxT("Economy"), +const wxChar* const simulationMode[] = {wxT("Economy"), wxT("Adequacy"), -#if STUDY_MODE_EXPANSION wxT("Expansion"), -#endif nullptr}; const wxChar* const adequacyPatchMode[] = {wxT("virtual area"), diff --git a/src/ui/simulator/windows/inspector/constants.h b/src/ui/simulator/windows/inspector/constants.h index 34b7c238bf..ef8302c3b5 100644 --- a/src/ui/simulator/windows/inspector/constants.h +++ b/src/ui/simulator/windows/inspector/constants.h @@ -44,7 +44,7 @@ extern const wxChar* const playlist[]; extern const wxChar* const geographicTrimming[]; extern const wxChar* const thematicTrimming[]; -extern const wxChar* const studyMode[]; +extern const wxChar* const simulationMode[]; extern const wxChar* const adequacyPatchMode[]; } // namespace Inspector } // namespace Window diff --git a/src/ui/simulator/windows/inspector/frame.cpp b/src/ui/simulator/windows/inspector/frame.cpp index 22b9ad28c9..d03fdfce09 100644 --- a/src/ui/simulator/windows/inspector/frame.cpp +++ b/src/ui/simulator/windows/inspector/frame.cpp @@ -340,7 +340,7 @@ Frame::Frame(wxWindow* parent, bool allowAnyObject) : // --- STUDIES --- pPGStudyTitle = Group(pg, wxT("GENERAL PARAMETERS"), wxT("study.title")); pPGStudyGrpSimulation = Category(pg, wxT("Simulation"), wxT("study.context")); - pPGStudyMode = P_ENUM("Mode", "study.mode", studyMode); + pPGSimulationMode = P_ENUM("Mode", "study.mode", simulationMode); pPGStudyCalendarBegin = P_UINT("First day", "study.cal.begin"); pPGStudyCalendarEnd = P_UINT("Last day", "study.cal.end"); pg->SetPropertyEditor(pPGStudyCalendarBegin, wxPG_EDITOR(StudyCalendarBtnEditor)); @@ -743,7 +743,7 @@ void Frame::apply(const InspectorData::Ptr& data) if (!hide) { // Context - Accumulator::Apply(pPGStudyMode, data->studies); + Accumulator::Apply(pPGSimulationMode, data->studies); Accumulator::Apply(pPGStudyHorizon, data->studies); Accumulator::Apply(pPGStudyCalendarMonth, data->studies); Accumulator::Apply(pPGStudyCalendarWeek, data->studies); diff --git a/src/ui/simulator/windows/inspector/frame.h b/src/ui/simulator/windows/inspector/frame.h index 2d49c0bd8e..9905b0c29b 100644 --- a/src/ui/simulator/windows/inspector/frame.h +++ b/src/ui/simulator/windows/inspector/frame.h @@ -149,7 +149,7 @@ class Frame final : public Antares::Component::Panel, public Yuni::IEventObserve wxPGProperty* pPGStudyGrpCalendar; wxPGProperty* pPGStudyMCScenarios; wxPGProperty* pPGStudyOutputProfile; - wxPGProperty* pPGStudyMode; + wxPGProperty* pPGSimulationMode; wxPGProperty* pPGStudyYears; wxPGProperty* pPGStudyCalendarBegin; wxPGProperty* pPGStudyCalendarEnd; diff --git a/src/ui/simulator/windows/inspector/property.update.cpp b/src/ui/simulator/windows/inspector/property.update.cpp index 4ae3778c54..063f3e94d1 100644 --- a/src/ui/simulator/windows/inspector/property.update.cpp +++ b/src/ui/simulator/windows/inspector/property.update.cpp @@ -1185,13 +1185,13 @@ bool InspectorGrid::onPropertyChanging_S(wxPGProperty*, wxStringToString(value.GetString(), s); s.toLower(); - Data::StudyMode mode = Data::stdmUnknown; + Data::SimulationMode mode = Data::SimulationMode::Unknown; if (s == "economy" || s == "0") - mode = Data::stdmEconomy; + mode = Data::SimulationMode::Economy; else if (s == "adequacy" || s == "1") - mode = Data::stdmAdequacy; + mode = Data::SimulationMode::Adequacy; else - mode = Data::stdmEconomy; + mode = Data::SimulationMode::Economy; for (; i != end; ++i) { diff --git a/src/ui/simulator/windows/output/panel/area-link.cpp b/src/ui/simulator/windows/output/panel/area-link.cpp index cfc10e1db1..c2aec0916b 100644 --- a/src/ui/simulator/windows/output/panel/area-link.cpp +++ b/src/ui/simulator/windows/output/panel/area-link.cpp @@ -669,15 +669,16 @@ void Panel::loadDataFromFile() // Economy switch (output.mode) { - case Data::stdmEconomy: + case Data::SimulationMode::Economy: filename << output.path << SEP << "economy" << SEP; break; - case Data::stdmAdequacy: + case Data::SimulationMode::Adequacy: filename << output.path << SEP << "adequacy" << SEP; break; - case Data::stdmExpansion: - case Data::stdmUnknown: - case Data::stdmMax: + case Data::SimulationMode::Expansion: + filename << output.path << SEP << "expansion" << SEP; + break; + case Data::SimulationMode::Unknown: filename << output.path << SEP << "unknown" << SEP; break; } diff --git a/src/ui/simulator/windows/output/provider/outputs.cpp b/src/ui/simulator/windows/output/provider/outputs.cpp index aa95581337..a8b1d7ee6a 100644 --- a/src/ui/simulator/windows/output/provider/outputs.cpp +++ b/src/ui/simulator/windows/output/provider/outputs.cpp @@ -173,15 +173,16 @@ void Outputs::search(Spotlight::IItem::Vector& out, switch (output->mode) { - case Data::stdmEconomy: + case Data::SimulationMode::Economy: item->addTag("ECO", 162, 178, 197); break; - case Data::stdmAdequacy: + case Data::SimulationMode::Adequacy: item->addTag("ADQ", 220, 192, 245); break; - case Data::stdmUnknown: - case Data::stdmExpansion: - case Data::stdmMax: + case Data::SimulationMode::Expansion: + item->addTag("EXP", 220, 192, 245); + break; + case Data::SimulationMode::Unknown: item->addTag("...", 213, 213, 213); } int imgIndex = pComponent.imageIndexForOutput(output); diff --git a/src/ui/simulator/windows/simulation/run.cpp b/src/ui/simulator/windows/simulation/run.cpp index c6a68e868c..59d8e63864 100644 --- a/src/ui/simulator/windows/simulation/run.cpp +++ b/src/ui/simulator/windows/simulation/run.cpp @@ -217,7 +217,7 @@ Run::Run(wxWindow* parent, bool preproOnly) : "images/32x32/run.png", wxString(wxT("For the study `")) << wxStringFromUTF8(study.header.caption) << wxT("`, ") - << wxStringFromUTF8(Data::StudyModeToCString(study.parameters.mode))), + << wxStringFromUTF8(Data::SimulationModeToCString(study.parameters.mode))), 0, wxALL | wxEXPAND | wxFIXED_MINSIZE); @@ -242,7 +242,7 @@ Run::Run(wxWindow* parent, bool preproOnly) : } { auto* lblMode = Antares::Component::CreateLabel( - pBigDaddy, wxStringFromUTF8(Data::StudyModeToCString(study.parameters.mode))); + pBigDaddy, wxStringFromUTF8(Data::SimulationModeToCString(study.parameters.mode))); wxFont f = lblMode->GetFont(); f.SetWeight(wxFONTWEIGHT_BOLD); lblMode->SetFont(f);