WSL/SLF GitLab Repository

FilterMinMax.cc 2.55 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
/***********************************************************************************/
/*  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/>.
*/
18
#include <meteoio/meteofilters/FilterMinMax.h>
19
20
21
22
23

using namespace std;

namespace mio {

24
25
26
FilterMinMax::FilterMinMax(const std::vector<std::string>& vec_args)
             : FilterBlock("MIN_MAX"), min_val(0.), max_val(0.), min_soft(0.), max_soft(0.), is_soft(true)

27
28
{
	parse_args(vec_args);
29
	properties.stage = ProcessingProperties::both; //for the rest: default values
30
31
}

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

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

void FilterMinMax::parse_args(std::vector<std::string> vec_args)
{
	vector<double> filter_args;
59
	is_soft = false;
60
61

	if (vec_args.size() > 2){
62
		is_soft = ProcessingBlock::is_soft(vec_args);
63
	}
64

65
	convert_args(2, 4, vec_args, filter_args);
66
67

	if (filter_args.size() == 3)
68
		throw InvalidArgumentException("Wrong number of arguments for filter " + getName(), AT);
69
70
71

	if (filter_args.size() >= 2){
		if (filter_args[0] > filter_args[1])
72
73
			throw InvalidArgumentException("Minimum should be smaller than maximum for filter " + getName(), AT);

74
75
76
77
78
79
80
81
82
83
84
85
86
		min_val = filter_args[0];
		max_val = filter_args[1];
	}

	if (filter_args.size() == 4){
		min_soft = filter_args[2];
		max_soft = filter_args[3];
	} else {
		min_soft = min_val;
		max_soft = max_val;
	}
}

87
} //end namespace