Antares Simulator
Power System Simulator
RenewableTSNumberData.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 // Created by marechaljas on 03/07/23.
23 //
24 
25 #pragma once
26 
27 #include "TSnumberData.h"
28 
29 namespace Antares::Data::ScenarioBuilder
30 {
32 {
33 public:
34  renewableTSNumberData() = default;
35 
36  virtual ~renewableTSNumberData()
37  {
38  }
39 
40  bool reset(const Study& study) override;
41 #ifdef BUILD_UI
42  void saveToINIFile(const Study& study, Yuni::IO::File::Stream& file) const override;
43 #endif
44 
45  void attachArea(const Area* area)
46  {
47  pArea = area;
48  }
49 
50  void setTSnumber(const Antares::Data::RenewableCluster* cluster, const uint year, uint value);
51  uint get(const Antares::Data::RenewableCluster* cluster, const uint year) const;
52  bool apply(Study& study) override;
53  CString<512, false> get_prefix() const override;
54  uint get_tsGenCount(const Study& study) const override;
55 
56 private:
58  const Area* pArea = nullptr;
59 };
60 
61 inline uint renewableTSNumberData::get(const Antares::Data::RenewableCluster* cluster,
62  const uint year) const
63 {
64  assert(cluster != nullptr);
65  if (year < pTSNumberRules.height && cluster->areaWideIndex < pTSNumberRules.width)
66  {
67  const uint index = cluster->areaWideIndex;
68  return pTSNumberRules[index][year];
69  }
70  return 0;
71 }
72 
73 inline CString<512, false> renewableTSNumberData::get_prefix() const
74 {
75  return "r,";
76 }
77 } // namespace Antares::Data::ScenarioBuilder
Definition for a single area.
Definition: area.h:51
unsigned int areaWideIndex
The index of the cluster from the area's point of view.
Definition: cluster.h:117
Definition: cluster.h:40
Rules for TS numbers, for all years and a single timeseries.
Definition: TSnumberData.h:32
MatrixType pTSNumberRules
All TS number overlay (0 if auto)
Definition: TSnumberData.h:77
Definition: RenewableTSNumberData.h:32
bool reset(const Study &study) override
Reset data from the study.
Definition: RenewableTSNumberData.cpp:110
bool apply(Study &study) override
Apply the changes to the study corresponding data (time series, hydro levels, ...)
Definition: RenewableTSNumberData.cpp:42
Definition: study.h:57
uint width
Width of the matrix.
Definition: matrix.h:441