MeteoIODoc  MeteoIODoc-2.9.0
ESOLIPGenerator.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 ESOLIPGENERATOR_H
20 #define ESOLIPGENERATOR_H
21 
23 
24 namespace mio {
25 
48  public:
49  ESOLIPGenerator(const std::vector< std::pair<std::string, std::string> >& vecArgs, const std::string& i_algo, const std::string& i_section, const double& TZ)
50  : GeneratorAlgorithm(vecArgs, i_algo, i_section, TZ) { parse_args(vecArgs); }
51  bool generate(const size_t& param, MeteoData& md);
52  bool create(const size_t& param, const size_t& ii_min, const size_t& ii_max, std::vector<MeteoData>& vecMeteo);
53 
54  private:
55  static double newSnowDensity(const MeteoData& md);
56 };
57 
58 } //end namespace mio
59 
60 #endif
mio::GeneratorAlgorithm
Interface class for the generator models.
Definition: GeneratorAlgorithms.h:111
mio::MeteoData
A class to represent a singular measurement received from one station at a certain time (represented ...
Definition: MeteoData.h:106
mio::ESOLIPGenerator
Generate precipitation from changes in snow height.
Definition: ESOLIPGenerator.h:47
mio::ESOLIPGenerator::ESOLIPGenerator
ESOLIPGenerator(const std::vector< std::pair< std::string, std::string > > &vecArgs, const std::string &i_algo, const std::string &i_section, const double &TZ)
Definition: ESOLIPGenerator.h:49
mio::ESOLIPGenerator::generate
bool generate(const size_t &param, MeteoData &md)
Definition: ESOLIPGenerator.cc:26
GeneratorAlgorithms.h
mio::ESOLIPGenerator::create
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: ESOLIPGenerator.cc:33
mio::GeneratorAlgorithm::parse_args
virtual void parse_args(const std::vector< std::pair< std::string, std::string > > &)
Definition: GeneratorAlgorithms.h:146
mio
Definition: Config.cc:29