www.cemf.ir
internalFieldAlgorithms.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 #ifndef __internalFieldAlgorithms_hpp__
21 #define __internalFieldAlgorithms_hpp__
22 
23 namespace pFlow
24 {
25 
26 template<class T, class MemorySpace>
27 inline
29 {
30  using exeSpace = typename internalField<T,MemorySpace>::execution_space;
31 
32  using policy = Kokkos::RangePolicy<
33  exeSpace,
34  Kokkos::IndexType<uint32> >;
35 
36  if constexpr(isDeviceAccessible<exeSpace>())
37  {
38  // this is a device view
39  auto maskD = iField.activePointsMaskDevice();
40  auto aRange = maskD.activeRange();
41  auto filed = iField.field().deviceViewAll();
42 
43  T minElement;
44 
45  Kokkos::parallel_reduce(
46  "min(internalField)",
47  policy(aRange.start(), aRange.end() ),
48  LAMBDA_HD(uint32 i, T& minUpdate)
49  {
50  if( maskD(i) )
51  if(filed[i] < minUpdate) minUpdate = filed[i];
52  },
53  Kokkos::Min<T>(minElement));
54  return minElement;
55  }
56  else
57  {
58  // this is a host view
59  auto maskH = iField.activePointsMaskHost();
60  auto aRange = maskH.activeRange();
61  auto filed = iField.field().deviceViewAll();
62  T minElement;
63  Kokkos::parallel_reduce(
64  "min(internalField)",
65  policy(aRange.start(), aRange.end()),
66  LAMBDA_HD(uint32 i, T& minUpdate)
67  {
68  if( maskH(i) )
69  if(filed[i] < minUpdate) minUpdate = filed[i];
70  },
71  Kokkos::Min<T>(minElement));
72 
73  return minElement;
74  }
75 }
76 
77 template<class T, class MemorySpace>
78 inline
80 {
81  using exeSpace = typename internalField<T,MemorySpace>::execution_space;
82 
83  using policy = Kokkos::RangePolicy<
84  exeSpace,
85  Kokkos::IndexType<uint32> >;
86 
87  if constexpr(isDeviceAccessible<exeSpace>())
88  {
89  // this is a device view
90  auto maskD = iField.activePointsMaskDevice();
91  auto aRange = maskD.activeRange();
92  auto filed = iField.field().deviceViewAll();
93 
94  T maxElement;
95 
96  Kokkos::parallel_reduce(
97  "max(internalField)",
98  policy(aRange.start(), aRange.end() ),
99  LAMBDA_HD(uint32 i, T& maxUpdate)
100  {
101  if( maskD(i) )
102  if( maxUpdate <filed[i]) maxUpdate = filed[i];
103  },
104  Kokkos::Max<T>(maxElement));
105  return maxElement;
106  }
107  else
108  {
109  // this is a host view
110  auto maskH = iField.activePointsMaskHost();
111  auto aRange = maskH.activeRange();
112  auto filed = iField.field().deviceViewAll();
113 
114  T maxElement;
115 
116  Kokkos::parallel_reduce(
117  "max(internalField)",
118  policy(aRange.start(), aRange.end() ),
119  LAMBDA_HD(uint32 i, T& maxUpdate)
120  {
121  if( maskH(i) )
122  if( maxUpdate <filed[i]) maxUpdate = filed[i];
123  },
124  Kokkos::Max<T>(maxElement));
125  return maxElement;
126  }
127 }
128 
129 
130 template<class T, class MemorySpace>
131 inline
133 {
134  using exeSpace = typename internalField<T,MemorySpace>::execution_space;
135 
136  using policy = Kokkos::RangePolicy<
137  exeSpace,
138  Kokkos::IndexType<uint32> >;
139 
140  if constexpr(isDeviceAccessible<exeSpace>())
141  {
142  // this is a device view
143  auto maskD = iField.activePointsMaskDevice();
144  auto aRange = maskD.activeRange();
145  auto filed = iField.field().deviceViewAll();
146 
147  T minElement;
148  T maxElement;
149 
150  Kokkos::parallel_reduce(
151  "minMax(internalField)",
152  policy(aRange.start(), aRange.end() ),
153  LAMBDA_HD(uint32 i, T& minUpdate, T& maxUpdate)
154  {
155  if( maskD(i) )
156  {
157  if(maxUpdate < filed[i]) maxUpdate = filed[i];
158  if(filed[i] < minUpdate) minUpdate = filed[i];
159  }
160 
161  },
162  Kokkos::Min<T>(minElement),
163  Kokkos::Max<T>(maxElement)
164  );
165  return {minElement, maxElement};
166  }
167  else
168  {
169  // this is a host view
170  auto maskH = iField.activePointsMaskHost();
171  auto aRange = maskH.activeRange();
172  auto filed = iField.field().deviceViewAll();
173 
174  T minElement;
175  T maxElement;
176 
177  Kokkos::parallel_reduce(
178  "minMax(internalField)",
179  policy(aRange.start(), aRange.end() ),
180  LAMBDA_HD(uint32 i, T& minUpdate, T& maxUpdate)
181  {
182  if( maskH(i) )
183  {
184  if(maxUpdate < filed[i]) maxUpdate = filed[i];
185  if(filed[i] < minUpdate) minUpdate = filed[i];
186  }
187 
188  },
189  Kokkos::Min<T>(minElement),
190  Kokkos::Max<T>(maxElement)
191  );
192  return {minElement, maxElement};
193  }
194 }
195 
196 template<class T, class MemorySpace>
197 inline
198 void fillSequence(internalField<T,MemorySpace>& iField, const T& startVal)
199 {
200  using exeSpace = typename internalField<T,MemorySpace>::execution_space;
201 
202  using policy = Kokkos::RangePolicy<
203  exeSpace,
204  Kokkos::IndexType<uint32> >;
205 
206  if constexpr(isDeviceAccessible<exeSpace>())
207  {
208  auto maskD = iField.activePointsMaskDevice();
209  auto aRange = maskD.activeRange();
210  auto field = iField.field().deviceViewAll();
211  auto aPoints = maskD.getActivePoints();
212  exclusiveScan(aPoints,0, aRange.end(), aPoints,0);
213 
214  Kokkos::parallel_for(
215  "internalField::fillSequence",
216  policy(aRange.start(), aRange.end() ),
217  LAMBDA_HD(uint32 i)
218  {
219  if(maskD(i))
220  {
221  field[i] = aPoints[i]+startVal;
222  }
223  });
224  Kokkos::fence();
225  }
226  else
227  {
228  // this is a host view
229  auto maskH = iField.activePointsMaskHost();
230  auto aRange = maskH.activeRange();
231  auto field = iField.field().deviceViewAll();
232  auto aPoints = maskH.getActivePoints();
233  exclusiveScan(aPoints,0, aRange.end(), aPoints,0);
234 
235  Kokkos::parallel_for(
236  "internalField::fillSequence",
237  policy(aRange.start(), aRange.end() ),
238  LAMBDA_HD(uint32 i)
239  {
240  if(maskH(i))
241  {
242  field[i] = aPoints[i]+startVal;
243  }
244  });
245  Kokkos::fence();
246  }
247 }
248 
249 }
250 
251 
252 
253 
254 
255 #endif
pFlow::minMax
Pair< T, T > minMax(const internalField< T, MemorySpace > &iField)
Definition: internalFieldAlgorithms.hpp:132
pFlow::Pair
Kokkos::pair< T1, T2 > Pair
Pair of two variables.
Definition: KokkosTypes.hpp:85
pFlow::uint32
unsigned int uint32
Definition: builtinTypes.hpp:56
pFlow::internalField::activePointsMaskDevice
const pFlagTypeDevice & activePointsMaskDevice() const
Definition: internalField.hpp:120
pFlow::max
T max(const internalField< T, MemorySpace > &iField)
Definition: internalFieldAlgorithms.hpp:79
pFlow
Definition: demGeometry.hpp:27
policy
Kokkos::RangePolicy< pFlow::DefaultExecutionSpace, Kokkos::Schedule< Kokkos::Static >, Kokkos::IndexType< pFlow::uint32 > > policy
Definition: grainParticlesKernels.cpp:25
pFlow::internalField::field
const FieldType & field() const
Definition: internalField.hpp:109
pFlow::internalField::execution_space
typename FieldType::execution_space execution_space
Definition: internalField.hpp:51
pFlow::min
T min(const internalField< T, MemorySpace > &iField)
Definition: internalFieldAlgorithms.hpp:28
pFlow::pointFlag::activeRange
const INLINE_FUNCTION_HD auto & activeRange() const
Definition: pointFlag.hpp:179
pFlow::internalField
Definition: internalField.hpp:34
LAMBDA_HD
#define LAMBDA_HD
Definition: pFlowMacros.hpp:58
pFlow::fillSequence
void fillSequence(internalField< T, MemorySpace > &iField, const T &startVal)
Definition: internalFieldAlgorithms.hpp:198
pFlow::internalField::activePointsMaskHost
const pFlagTypeHost & activePointsMaskHost() const
Definition: internalField.hpp:125
pFlow::exclusiveScan
void exclusiveScan(const ViewType1D< Type, properties... > &view, uint32 start, uint32 end, ViewType1D< Type, dProperties... > &dView, uint32 dStart)
Definition: ViewAlgorithms.hpp:439