Skip to content

Commit

Permalink
Add compatibility parameter for hydro pmax I/O [ANT-2278] (#2514)
Browse files Browse the repository at this point in the history
Co-authored-by: payetvin <[email protected]>
Co-authored-by: Vincent Payet <[email protected]>
  • Loading branch information
3 people authored Dec 6, 2024
1 parent a276477 commit 2fc0ada
Show file tree
Hide file tree
Showing 9 changed files with 113 additions and 9 deletions.
2 changes: 1 addition & 1 deletion simtest.json
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
{
"version": "v9.2.0f"
"version": "v9.2.0g"
}
2 changes: 1 addition & 1 deletion src/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ set(ANTARES_VERSION_REVISION 0)

# Beta release
set(ANTARES_BETA 0)
set(ANTARES_RC 6)
set(ANTARES_RC 7)

set(ANTARES_VERSION_YEAR 2024)

Expand Down
13 changes: 11 additions & 2 deletions src/libs/antares/study/area/list.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -950,20 +950,29 @@ static bool AreaListLoadFromFolderSingleArea(Study& study,
ret = area.hydro.series->loadGenerationTS(area.id, hydroSeries, studyVersion) && ret;
}

if (studyVersion < StudyVersion(9, 1))
switch (study.parameters.compatibility.hydroPmax)
{
case Parameters::Compatibility::HydroPmax::Daily:
{
HydroMaxTimeSeriesReader reader(area.hydro,
area.id.to<std::string>(),
area.name.to<std::string>());
ret = reader.read(pathHydro.string(), study.usedByTheSolver) && ret;
break;
}
else
case Parameters::Compatibility::HydroPmax::Hourly:
{
ret = area.hydro.series->LoadMaxPower(area.id, hydroSeries) && ret;
break;
}
default:
throw std::invalid_argument(
"Value not supported for study.parameters.compatibility.hydroPmax");
}

area.hydro.series->resizeTSinDeratedMode(study.parameters.derated,
studyVersion,
study.parameters.compatibility.hydroPmax,
study.usedByTheSolver);
}

Expand Down
15 changes: 15 additions & 0 deletions src/libs/antares/study/include/antares/study/parameters.h
Original file line number Diff line number Diff line change
Expand Up @@ -399,6 +399,18 @@ class Parameters final

} include;

struct Compatibility
{
enum class HydroPmax
{
Daily,
Hourly
};
HydroPmax hydroPmax = HydroPmax::Daily;
};

Compatibility compatibility;

// Shedding
struct
{
Expand Down Expand Up @@ -518,6 +530,9 @@ const char* SimulationModeToCString(SimulationMode mode);
*/
bool StringToSimulationMode(SimulationMode& mode, Yuni::CString<20, false> text);

const char* CompatibilityHydroPmaxToCString(Parameters::Compatibility::HydroPmax);
bool StringToCompatibilityHydroPmax(Parameters::Compatibility::HydroPmax&, const std::string& text);

} // namespace Antares::Data

#endif // __ANTARES_LIBS_STUDY_PARAMETERS_H__
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@

#include <antares/array/matrix.h>
#include <antares/series/series.h>
#include <antares/study/parameters.h>
#include <antares/study/version.h>

#include "../../fwd.h"
Expand Down Expand Up @@ -137,7 +138,10 @@ class DataSeriesHydro
uint TScount() const;

// Setting TS's when derated mode is on
void resizeTSinDeratedMode(bool derated, StudyVersion version, bool useBySolver);
void resizeTSinDeratedMode(bool derated,
StudyVersion version,
Parameters::Compatibility::HydroPmax hydroPmax,
bool useBySolver);
}; // class DataSeriesHydro
} // namespace Data
} // namespace Antares
Expand Down
53 changes: 52 additions & 1 deletion src/libs/antares/study/parameters.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -208,6 +208,39 @@ const char* SimulationModeToCString(SimulationMode mode)
}
}

const char* CompatibilityHydroPmaxToCString(Parameters::Compatibility::HydroPmax mode)
{
switch (mode)
{
case Parameters::Compatibility::HydroPmax::Daily:
return "daily";
case Parameters::Compatibility::HydroPmax::Hourly:
return "hourly";
default:
return "Unknown";
}
}

bool StringToCompatibilityHydroPmax(Parameters::Compatibility::HydroPmax& mode,
const std::string& text)
{
if (text.empty())
{
return false;
}
if (text == "daily")
{
mode = Parameters::Compatibility::HydroPmax::Daily;
return true;
}
if (text == "hourly")
{
mode = Parameters::Compatibility::HydroPmax::Hourly;
return true;
}
return false;
}

bool Parameters::economy() const
{
return mode == SimulationMode::Economy;
Expand Down Expand Up @@ -1053,6 +1086,19 @@ static bool SGDIntLoadFamily_SeedsMersenneTwister(Parameters& d,
return false;
}

static bool SGDIntLoadFamily_Compatibility(Parameters& d,
const String& key,
const String& value,
const String&)
{
if (key == "hydro-pmax")
{
return StringToCompatibilityHydroPmax(d.compatibility.hydroPmax, value);
}

return false;
}

static bool SGDIntLoadFamily_Legacy(Parameters& d,
const String& key,
const String& value,
Expand Down Expand Up @@ -1170,7 +1216,8 @@ bool Parameters::loadFromINI(const IniFile& ini, const StudyVersion& version)
{"advanced parameters", &SGDIntLoadFamily_AdvancedParameters},
{"playlist", &SGDIntLoadFamily_Playlist},
{"variables selection", &SGDIntLoadFamily_VariablesSelection},
{"seeds - mersenne twister", &SGDIntLoadFamily_SeedsMersenneTwister}};
{"seeds - mersenne twister", &SGDIntLoadFamily_SeedsMersenneTwister},
{"compatibility", &SGDIntLoadFamily_Compatibility}};

Callback handleAllKeysInSection;
// Foreach section on the ini file...
Expand Down Expand Up @@ -1967,6 +2014,10 @@ void Parameters::saveToINI(IniFile& ini) const
section->add(SeedToID((SeedIndex)sd), seed[sd]);
}
}
{
auto* section = ini.addSection("compatibility");
section->add("hydro-pmax", CompatibilityHydroPmaxToCString(compatibility.hydroPmax));
}
}

bool Parameters::loadFromFile(const std::filesystem::path& filename, const StudyVersion& version)
Expand Down
3 changes: 2 additions & 1 deletion src/libs/antares/study/parts/hydro/container.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,8 @@ bool PartHydro::LoadFromFolder(Study& study, const fs::path& folder)
area.hydro.pumpingEfficiency = 1.;
area.hydro.deltaBetweenFinalAndInitialLevels.resize(study.parameters.nbYears);

if (study.header.version >= StudyVersion(9, 1))
if (study.parameters.compatibility.hydroPmax
== Parameters::Compatibility::HydroPmax::Hourly)
{
// GUI part patch :
// We need to know, when estimating the RAM required by the solver, if the current
Expand Down
3 changes: 2 additions & 1 deletion src/libs/antares/study/parts/hydro/series.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -230,6 +230,7 @@ uint DataSeriesHydro::TScount() const

void DataSeriesHydro::resizeTSinDeratedMode(bool derated,
StudyVersion studyVersion,
Parameters::Compatibility::HydroPmax hydroPmax,
bool usedBySolver)
{
if (!(derated && usedBySolver))
Expand All @@ -243,7 +244,7 @@ void DataSeriesHydro::resizeTSinDeratedMode(bool derated,
{
mingen.averageTimeseries();

if (studyVersion >= StudyVersion(9, 1))
if (hydroPmax == Parameters::Compatibility::HydroPmax::Hourly)
{
maxHourlyGenPower.averageTimeseries();
maxHourlyPumpPower.averageTimeseries();
Expand Down
25 changes: 24 additions & 1 deletion src/tests/src/libs/antares/study/parameters/parameters-tests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,26 @@ BOOST_FIXTURE_TEST_CASE(invalidValues, Fixture)
BOOST_CHECK_EQUAL(p.renewableGeneration(), rgUnknown);
}

BOOST_FIXTURE_TEST_CASE(hydroPmax, Fixture)
{
BOOST_CHECK(p.compatibility.hydroPmax == Parameters::Compatibility::HydroPmax::Daily);

writeValidFile();
BOOST_CHECK(p.loadFromFile(path.string(), version));
p.validateOptions(options);
p.fixBadValues();

BOOST_CHECK(p.compatibility.hydroPmax == Parameters::Compatibility::HydroPmax::Hourly);

BOOST_CHECK_EQUAL(CompatibilityHydroPmaxToCString(p.compatibility.hydroPmax), "hourly");
BOOST_CHECK_EQUAL(CompatibilityHydroPmaxToCString(Parameters::Compatibility::HydroPmax::Daily),
"daily");

BOOST_CHECK(StringToCompatibilityHydroPmax(p.compatibility.hydroPmax, "daily"));
BOOST_CHECK(!StringToCompatibilityHydroPmax(p.compatibility.hydroPmax, ""));
BOOST_CHECK(!StringToCompatibilityHydroPmax(p.compatibility.hydroPmax, "abc"));
}

BOOST_AUTO_TEST_SUITE_END()

void Fixture::writeInvalidFile()
Expand Down Expand Up @@ -215,7 +235,10 @@ void Fixture::writeValidFile()
seed-spilled-energy-costs = 7005489
seed-thermal-costs = 8005489
seed-hydro-costs = 9005489
seed-initial-reservoir-levels = 10005489)";
seed-initial-reservoir-levels = 10005489
[compatibility]
hydro-pmax = hourly)";

outfile.close();
}

0 comments on commit 2fc0ada

Please sign in to comment.