ASL  0.1.7
Advanced Simulation Library
aslPositionFunction.h
Go to the documentation of this file.
1 /*
2  * Advanced Simulation Library <http://asl.org.il>
3  *
4  * Copyright 2015 Avtech Scientific <http://avtechscientific.com>
5  *
6  *
7  * This file is part of Advanced Simulation Library (ASL).
8  *
9  * ASL is free software: you can redistribute it and/or modify it
10  * under the terms of the GNU Affero General Public License as
11  * published by the Free Software Foundation, version 3 of the License.
12  *
13  * ASL is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU Affero General Public License for more details.
17  *
18  * You should have received a copy of the GNU Affero General Public License
19  * along with ASL. If not, see <http://www.gnu.org/licenses/>.
20  *
21  */
22 
23 
24 #ifndef ASLPOSITIONFUNCTION_H
25 #define ASLPOSITIONFUNCTION_H
26 
28 #include "utilities/aslUValue.h"
29 
30 namespace acl
31 {
32  class KernelConfiguration;
33 }
34 
35 namespace asl {
36 
37  template <typename T> class AVec;
38  class Block;
39 
40  class AbstractDataWithGhostNodes;
41  typedef std::shared_ptr<AbstractDataWithGhostNodes> SPAbstractDataWithGhostNodes;
42 
45 
49  {
50  protected:
52  public:
53  virtual ~PositionFunction();
55  };
56 
58  typedef std::shared_ptr<PositionFunction> SPPositionFunction;
59 
62  {
63  protected:
66  public:
68  };
69 
72  {
73  protected:
75  public:
77  };
78 
81  {
82  public:
85  };
86 
89  {
90  public:
93  };
94 
97  {
98  public:
101  };
102 
105  {
106  public:
109  };
110 
113  {
114  private:
116  public:
119  };
120 
123  {
124  private:
125  acl::VectorOfElements gradient;
127  public:
130  };
131 
134  {
135  private:
138  public:
143  acl::VectorOfElements center);
145  };
146 
148  class PFSign: public PFUnaryOperation
149  {
150  public:
153  };
154 
158  template <typename T>
160 
167  const AVec<double> & c);
168 
169 
180 
183  SPPositionFunction df,
184  unsigned int gN,
185  acl::TypeID t);
186 
187 
194  const acl::KernelConfiguration & k);
195 
196 
197 //---------------------------- Implementation --------------------------------
198 
199 
201  {
202  return SPPositionFunction(new PFOperationPlus(a,b));
203  }
204 
206  {
207  return SPPositionFunction(new PFOperationMinus(a,b));
208  }
209 
211  {
213  }
214 
216  {
217  return SPPositionFunction(new PFOperationProduct(a,b));
218  }
219 
221  {
222  return SPPositionFunction(new PFSign(a));
223  }
224 
225 }// asl
226 
227 #endif // ASLPositionFunction
asl::PFOperationProduct::PFOperationProduct
PFOperationProduct(SPPositionFunction a, SPPositionFunction b)
asl::generateDataContainer_SP
SPDataWrapperACL generateDataContainer_SP(const Block &b, const acl::VectorOfElements &a)
asl::PFLinear::PFLinear
PFLinear(acl::VectorOfElements g, acl::VectorOfElements p0)
asl::operator-
SPDistanceFunction operator-(SPDistanceFunction a)
asl::PositionFunction::~PositionFunction
virtual ~PositionFunction()
asl::PositionFunction::PositionFunction
PositionFunction()
asl::PFOperationMinus::PFOperationMinus
PFOperationMinus(SPPositionFunction a, SPPositionFunction b)
asl::PositionFunction::value
virtual acl::VectorOfElements value(acl::VectorOfElements &pos)=0
asl::PFSign
Definition: aslPositionFunction.h:149
asl::PFBinaryOperation
Definition: aslPositionFunction.h:62
asl::PFRotationField::PFRotationField
PFRotationField(acl::VectorOfElements rotationAxis, acl::VectorOfElements center)
asl::PFOperationPlus::PFOperationPlus
PFOperationPlus(SPPositionFunction a, SPPositionFunction b)
asl::UValue
Updatable value. This class stores value and its TimeStamp.
Definition: aslUValue.h:35
asl::PFOperationProduct
Definition: aslPositionFunction.h:97
asl::PFConstant::value
virtual acl::VectorOfElements value(acl::VectorOfElements &pos)
asl::PFOperationPlus::value
virtual acl::VectorOfElements value(acl::VectorOfElements &pos)
asl::PFConstant
Definition: aslPositionFunction.h:113
asl::PositionFunction
Definition: aslPositionFunction.h:49
asl::PFSign::value
virtual acl::VectorOfElements value(acl::VectorOfElements &pos)
acl::VectorOfElements
The class represents several Element.
Definition: aclVectorOfElementsDef.h:92
asl::Block
Definition: aslBlocks.h:57
asl::PFRotationField::value
virtual acl::VectorOfElements value(acl::VectorOfElements &pos)
asl::PFOperationInversion::PFOperationInversion
PFOperationInversion(SPPositionFunction a)
asl::generatePFRotationField
SPPositionFunction generatePFRotationField(const AVec< double > &axis, const AVec< double > &c)
asl::PFRotationField
creates function corresponding to a velocity field
Definition: aslPositionFunction.h:134
asl::initData
void initData(SPAbstractData d, double a)
asl::operator*
SPPositionFunction operator*(SPPositionFunction a, SPPositionFunction b)
Definition: aslPositionFunction.h:215
asl::generatePFConstant
SPPositionFunction generatePFConstant(const AVec< double > &a)
asl::PFBinaryOperation::e2
SPPositionFunction e2
Definition: aslPositionFunction.h:65
acl::KernelConfiguration
ACL Kernel configuration class.
Definition: aclKernelConfiguration.h:35
asl::generatePFLinear
SPPositionFunction generatePFLinear(const AVec< double > &g, double p0)
asl::PFOperationProduct::value
virtual acl::VectorOfElements value(acl::VectorOfElements &pos)
aslUValue.h
aclVectorOfElementsDef.h
asl::PFUnaryOperation::e1
SPPositionFunction e1
Definition: aslPositionFunction.h:74
asl::PFUnaryOperation
Definition: aslPositionFunction.h:72
asl::PFOperationPlus
Definition: aslPositionFunction.h:81
asl::SPPositionFunction
std::shared_ptr< PositionFunction > SPPositionFunction
Definition: aslPositionFunction.h:58
asl::PFBinaryOperation::e1
SPPositionFunction e1
Definition: aslPositionFunction.h:64
asl::PFBinaryOperation::PFBinaryOperation
PFBinaryOperation(SPPositionFunction a, SPPositionFunction b)
asl::PFSign::PFSign
PFSign(SPPositionFunction a)
asl::PFUnaryOperation::PFUnaryOperation
PFUnaryOperation(SPPositionFunction a)
asl::PFConstant::PFConstant
PFConstant(acl::VectorOfElements v)
asl::PFOperationInversion::value
virtual acl::VectorOfElements value(acl::VectorOfElements &pos)
asl::PFLinear
Definition: aslPositionFunction.h:123
asl::PFOperationMinus::value
virtual acl::VectorOfElements value(acl::VectorOfElements &pos)
asl::operator+
const AMatr< T > operator+(const AMatr< T > &a, const AMatr< T > &b)
Definition: aslMatrices.h:252
acl::TypeID
TypeID
Definition: aclTypes.h:39
asl::PFOperationMinus
Definition: aslPositionFunction.h:89
asl::sign
SPPositionFunction sign(SPPositionFunction a)
Definition: aslPositionFunction.h:220
asl::AVec< double >
asl::PFLinear::value
virtual acl::VectorOfElements value(acl::VectorOfElements &pos)
asl
Advanced Simulation Library.
Definition: aslDataInc.h:31
acl
Advanced Computational Language.
Definition: acl.h:41
asl::PFOperationInversion
Definition: aslPositionFunction.h:105
asl::SPAbstractDataWithGhostNodes
std::shared_ptr< AbstractDataWithGhostNodes > SPAbstractDataWithGhostNodes
Definition: aslGenerators.h:50