intervalRange.hpp
Go to the documentation of this file.
1 /*------------------------------- phasicFlow ---------------------------------
2  O C enter of
3  O O E ngineering and
4  O O M ultiscale modeling of
5  OOOOOOO F luid flow
6 ------------------------------------------------------------------------------
7  Copyright (C): www.cemf.ir
8  email: hamid.r.norouzi AT gmail.com
9 ------------------------------------------------------------------------------
10 Licence:
11  This file is part of phasicFlow code. It is a free software for simulating
12  granular and multiphase flows. You can redistribute it and/or modify it under
13  the terms of GNU General Public License v3 or any other later versions.
14 
15  phasicFlow is distributed to help others in their research in the field of
16  granular and multiphase flows, but WITHOUT ANY WARRANTY; without even the
17  implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
18 
19 -----------------------------------------------------------------------------*/
20 
21 
22 #ifndef __intervalRange_hpp__
23 #define __intervalRange_hpp__
24 
25 #include "types.hpp"
26 #include "typeInfo.hpp"
27 
28 
29 namespace pFlow
30 {
31 
32 template<typename T>
33 class
35 {
36 protected:
37 
38  T begin_;
39 
40  T end_;
41 
42  static inline const T maxVal = largestPositive<T>();
43  static inline const T minVal = largestNegative<T>();
44 public:
45 
46  TypeInfoTemplateNV("intervalRange",T);
47 
48  intervalRange(T begin, T end)
49  :
50  begin_(begin),
51  end_(end)
52  {}
53 
54  intervalRange(T beginEnd, bool openEnd )
55  :
56  begin_(openEnd?beginEnd:minVal),
57  end_(openEnd?maxVal:beginEnd)
58  {}
59 
60  // it should be in the form of begin:end or :end or begin:
61  intervalRange(const word& rangeString)
62  {
63  if(!parseRange(rangeString,begin_,end_))
64  {
66  "bad input for the range. It should have the form of begin:end or :end or begin: \n";
67  fatalExit;
68  }
69  }
70 
71 
72  inline
73  bool isMember(T val)const
74  {
75  if(val<begin_ || val>end_)return false;
76  return true;
77  }
78 
79  static
80  bool parseRange(const word& rangeString, T& begin, T& end)
81  {
82  if(std::count(
83  rangeString.begin(),
84  rangeString.end(),
85  ':') != 1)
86  return false;
87 
88  auto col1 = rangeString.find_first_of(":");
89  word beginCh;
90  if(col1 == 0)
91  {
92  begin = minVal;
93  }
94  else
95  {
96  auto beginCh = rangeString.substr(0,col1);
97  if(!readValue(beginCh,begin))return false;
98  }
99 
100  if(col1 == rangeString.size())
101  {
102  end = maxVal;
103  }
104  else
105  {
106  auto endCh = rangeString.substr(col1+1);
107  if(!readValue(endCh, end))return false;
108  }
109 
110 
111  return true;
112 
113  }
114 };
115 
116 }
117 
118 #endif //__stridedRange_hpp__
count
auto count(const Vector< T, Allocator > &vec, const T &val)
pFlow::intervalRange::parseRange
static bool parseRange(const word &rangeString, T &begin, T &end)
Definition: intervalRange.hpp:80
pFlow::readValue
bool readValue(const word &w, real &val)
Definition: bTypesFunctions.hpp:140
pFlow::intervalRange::intervalRange
intervalRange(T begin, T end)
Definition: intervalRange.hpp:48
fatalExit
#define fatalExit
Definition: error.hpp:57
pFlow::intervalRange::isMember
bool isMember(T val) const
Definition: intervalRange.hpp:73
types.hpp
pFlow::word
std::string word
Definition: builtinTypes.hpp:63
pFlow::intervalRange::begin_
T begin_
Definition: intervalRange.hpp:38
pFlow::intervalRange::intervalRange
intervalRange(T beginEnd, bool openEnd)
Definition: intervalRange.hpp:54
pFlow
Definition: demComponent.hpp:28
pFlow::intervalRange::intervalRange
intervalRange(const word &rangeString)
Definition: intervalRange.hpp:61
fatalErrorInFunction
#define fatalErrorInFunction
Definition: error.hpp:42
pFlow::intervalRange::end_
T end_
Definition: intervalRange.hpp:40
pFlow::intervalRange
Definition: intervalRange.hpp:33
TypeInfoTemplateNV
#define TypeInfoTemplateNV(tName, Type)
Definition: typeInfo.hpp:89
typeInfo.hpp