MeteoIODoc  MeteoIODoc-2.9.0
WindComponents.h
Go to the documentation of this file.
1 // SPDX-License-Identifier: LGPL-3.0-or-later
2 /***********************************************************************************/
3 /* Copyright 2018 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 WINDCOMPONENTS_H
20 #define WINDCOMPONENTS_H
21 
23 
24 namespace mio {
25 
38  public:
39  WindComponents(const std::vector< std::pair<std::string, std::string> >& vecArgs, const std::string& i_algo, const std::string& i_section, const double& TZ)
40  : GeneratorAlgorithm(vecArgs, i_algo, i_section, TZ), where( section+"::"+algo ) { parse_args(vecArgs); }
41  bool generate(const size_t& param, MeteoData& md);
42  bool create(const size_t& param, const size_t& ii_min, const size_t& ii_max, std::vector<MeteoData>& vecMeteo);
43  private:
44  static std::string findUComponent(const MeteoData& md);
45  static std::string findVComponent(const MeteoData& md);
46  void parse_args(const std::vector< std::pair<std::string, std::string> >& vecArgs);
47  const std::string where;
48 };
49 
50 } //end namespace mio
51 
52 #endif
mio::WindComponents::generate
bool generate(const size_t &param, MeteoData &md)
Definition: WindComponents.cc:49
mio::GeneratorAlgorithm
Interface class for the generator models.
Definition: GeneratorAlgorithms.h:111
mio::GeneratorAlgorithm::section
const std::string section
Definition: GeneratorAlgorithms.h:151
mio::WindComponents
Compute VW and/or DW from the U, V wind components.
Definition: WindComponents.h:37
mio::MeteoData
A class to represent a singular measurement received from one station at a certain time (represented ...
Definition: MeteoData.h:106
mio::GeneratorAlgorithm::algo
const std::string algo
Definition: GeneratorAlgorithms.h:151
mio::WindComponents::WindComponents
WindComponents(const std::vector< std::pair< std::string, std::string > > &vecArgs, const std::string &i_algo, const std::string &i_section, const double &TZ)
Definition: WindComponents.h:39
mio::WindComponents::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: WindComponents.cc:75
GeneratorAlgorithms.h
mio
Definition: Config.cc:29