OTB  10.0.0
Orfeo Toolbox
otbPathLengthFunctor.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2005-2024 Centre National d'Etudes Spatiales (CNES)
3  *
4  * This file is part of Orfeo Toolbox
5  *
6  * https://www.orfeo-toolbox.org/
7  *
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  * http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  */
20 
21 
22 #ifndef otbPathLengthFunctor_h
23 #define otbPathLengthFunctor_h
24 
25 #include "otbMath.h"
26 
27 namespace otb
28 {
29 
40 template <class TInput1>
42 {
43 public:
44  void SetThreshold(double threshold)
45  {
46  m_Threshold = threshold;
47  }
48  double GetThreshold(void) const
49  {
50  return m_Threshold;
51  }
52 
54  {
55  m_Threshold = 10;
56  }
58  {
59  }
60 
61  inline bool operator()(const TInput1& input)
62  {
63  double length = input->GetLength();
64 
65  if (length > m_Threshold)
66  {
67  return true;
68  }
69  else
70  {
71  return false;
72  }
73  }
74 
75 private:
76  double m_Threshold;
77 };
78 }
79 
80 #endif
Select paths according to their length.
double GetThreshold(void) const
bool operator()(const TInput1 &input)
void SetThreshold(double threshold)
The "otb" namespace contains all Orfeo Toolbox (OTB) classes.