MeteoIODoc  2.10.0
ClearSkyLWGenerator.h
Go to the documentation of this file.
1 // SPDX-License-Identifier: LGPL-3.0-or-later
2 /***********************************************************************************/
3 /* Copyright 2013 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 CLEARSKYLWGENERATOR_H
20 #define CLEARSKYLWGENERATOR_H
21 
23 
24 namespace mio {
25 
61  public:
62  ClearSkyLWGenerator(const std::vector< std::pair<std::string, std::string> >& vecArgs, const std::string& i_algo, const std::string& i_section, const double& TZ)
63  : GeneratorAlgorithm(vecArgs, i_algo, i_section, TZ), model(BRUTSAERT) { parse_args(vecArgs); }
64  bool generate(const size_t& param, MeteoData& md);
65  bool create(const size_t& param, const size_t& ii_min, const size_t& ii_max, std::vector<MeteoData>& vecMeteo);
66  private:
67  void parse_args(const std::vector< std::pair<std::string, std::string> >& vecArgs);
68  typedef enum PARAMETRIZATION {
69  BRUTSAERT,
70  DILLEY,
71  PRATA,
72  CLARK,
73  TANG,
74  IDSO
75  } parametrization;
76  parametrization model;
77 };
78 
79 } //end namespace mio
80 
81 #endif
ILWR clear sky parametrization.
Definition: ClearSkyLWGenerator.h:60
bool generate(const size_t &param, MeteoData &md)
Definition: ClearSkyLWGenerator.cc:50
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: ClearSkyLWGenerator.cc:74
ClearSkyLWGenerator(const std::vector< std::pair< std::string, std::string > > &vecArgs, const std::string &i_algo, const std::string &i_section, const double &TZ)
Definition: ClearSkyLWGenerator.h:62
Interface class for the generator models.
Definition: GeneratorAlgorithms.h:111
A class to represent a singular measurement received from one station at a certain time (represented ...
Definition: MeteoData.h:107
Definition: Config.cc:30