MeteoIODoc  2.10.0
AllSkyLWGenerator.h
Go to the documentation of this file.
1 // SPDX-License-Identifier: LGPL-3.0-or-later
2 /***********************************************************************************/
3 /* Copyright 2013-2021 WSL Institute for Snow and Avalanche Research SLF-DAVOS */
4 /***********************************************************************************/
5 /* This file is part of MeteoIO.
6  MeteoIO is free software: you can redistribute it and/or modify
7  it under the terms of the GNU Lesser General Public License as published by
8  the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  MeteoIO is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU Lesser General Public License for more details.
15 
16  You should have received a copy of the GNU Lesser General Public License
17  along with MeteoIO. If not, see <http://www.gnu.org/licenses/>.
18 */
19 #ifndef ALLSKYGENERATOR_H
20 #define ALLSKYGENERATOR_H
21 
24 #include <meteoio/meteoLaws/Sun.h>
25 
26 #include <map>
27 
28 namespace mio {
29 
81  public:
82  AllSkyLWGenerator(const std::vector< std::pair<std::string, std::string> >& vecArgs, const std::string& i_algo, const std::string& i_section, const double& TZ, const Config &i_cfg);
83  bool generate(const size_t& param, MeteoData& md);
84  bool create(const size_t& param, const size_t& ii_min, const size_t& ii_max, std::vector<MeteoData>& vecMeteo);
85  private:
86  void parse_args(const std::vector< std::pair<std::string, std::string> >& vecArgs);
87 
88  typedef enum PARAMETRIZATION {
89  LHOMME,
90  CARMONA,
91  CRAWFORD,
92  KONZELMANN,
93  OMSTEDT,
94  UNSWORTH
95  } parametrization;
96 
97  SunObject sun;
98  parametrization model;
99 };
100 
101 } //end namespace mio
102 
103 #endif
ILWR all sky parametrization.
Definition: AllSkyLWGenerator.h:80
AllSkyLWGenerator(const std::vector< std::pair< std::string, std::string > > &vecArgs, const std::string &i_algo, const std::string &i_section, const double &TZ, const Config &i_cfg)
Definition: AllSkyLWGenerator.cc:29
bool create(const size_t &param, const size_t &ii_min, const size_t &ii_max, std::vector< MeteoData > &vecMeteo)
Fill one time series of MeteoData for one station.
Definition: AllSkyLWGenerator.cc:136
bool generate(const size_t &param, MeteoData &md)
Definition: AllSkyLWGenerator.cc:68
A class that reads a key/value file. These files (typically named *.ini) follow the INI file format s...
Definition: Config.h:79
A class to represent a singular measurement received from one station at a certain time (represented ...
Definition: MeteoData.h:107
A class to calculate Solar radiation characteristics This is largely based on M. Iqbal,...
Definition: Sun.h:37
Atmospheric transmissivity generator.
Definition: TauCLDGenerator.h:80
Definition: Config.cc:30