WSL/SLF GitLab Repository

FilterMax.cc 2.14 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/***********************************************************************************/
/*  Copyright 2009 WSL Institute for Snow and Avalanche Research    SLF-DAVOS      */
/***********************************************************************************/
/* This file is part of MeteoIO.
    MeteoIO is free software: you can redistribute it and/or modify
    it under the terms of the GNU Lesser General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    MeteoIO is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public License
    along with MeteoIO.  If not, see <http://www.gnu.org/licenses/>.
*/
#include <meteoio/meteofilters/FilterMax.h>

using namespace std;

namespace mio {

24
25
26
FilterMax::FilterMax(const std::vector<std::string>& vec_args)
          : FilterBlock("MAX"), max_val(0.), max_soft(0.), is_soft(true)
{
27
	parse_args(vec_args);
28
	properties.stage = ProcessingProperties::both; //for the rest: default values
29
30
}

31
void FilterMax::process(const unsigned int& param, const std::vector<MeteoData>& ivec,
32
33
                        std::vector<MeteoData>& ovec)
{
34
35
	ovec = ivec;
	for (size_t ii=0; ii<ovec.size(); ii++){
36
		double& tmp = ovec[ii](param);
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
		if (tmp == IOUtils::nodata) continue; //preserve nodata values

		if (tmp > max_val){
			if (is_soft){
				tmp = max_soft;
			} else {
				tmp = IOUtils::nodata;
			}
		}
	}
}


void FilterMax::parse_args(std::vector<std::string> vec_args) {
	vector<double> filter_args;

53
	is_soft = false;
54
	if (vec_args.size() > 1){
55
		is_soft = ProcessingBlock::is_soft(vec_args);
56
	}
57

58
	convert_args(1, 2, vec_args, filter_args);
59
60

	if (filter_args.size() > 2)
61
		throw InvalidArgumentException("Wrong number of arguments for filter " + getName(), AT);
62
63
64
65
66
67
68
69
70
71
72

	max_val = filter_args[0];

	if (filter_args.size() == 2){
		max_soft = filter_args[1];
	} else {
		max_soft = max_val;
	}
}

} //end namespace