ASL  0.1.7
Advanced Simulation Library
aslFDAdvectionDiffusion2.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 ASLFDADVECTIONDIFFUSION2_H
25 #define ASLFDADVECTIONDIFFUSION2_H
26 
27 #include "aslNumMethod.h"
28 
29 
30 namespace acl{
31  class Kernel;
32  class VectorOfElementsData;
33 }
34 
35 namespace asl
36 {
37  class VectorTemplate;
38  template <typename V> class DataWithGhostNodes;
39  typedef DataWithGhostNodes<acl::VectorOfElementsData> DataWithGhostNodesACLData;
40  typedef std::shared_ptr<DataWithGhostNodesACLData> SPDataWithGhostNodesACLData;
41  class AbstractDataWithGhostNodes;
42  typedef std::shared_ptr<AbstractDataWithGhostNodes> SPAbstractDataWithGhostNodes;
43 
45 
60  {
61  public:
64  private:
65  std::unique_ptr<acl::Kernel> kernel;
66  std::vector<Data> cData;
67  std::vector<Data> cInternalData;
68 
69  bool electricField;
70  ScalarField efPhi;
71  ScalarField efFactor1;
72  ScalarField efFactor2;
73  std::vector<ScalarField> efChargeAnd;
74 
75  const VectorTemplate* vectorTemplate;
76 
77  int t;
78  std::vector<double> diffusionCoefficient;
79  public:
81  FDAdvectionDiffusion2(Data c, double dC, const VectorTemplate* vT);
82  void setDiffusionCoefficient(double d, unsigned int i=0);
83  double getDiffusionCoefficient(unsigned int i=0);
87  virtual void init();
88  virtual void execute();
89  void addComponent(Data c, double dC);
90  void addComponent(Data c, double dC, ScalarField qAnd);
91 
92  };
93 
94  typedef std::shared_ptr<FDAdvectionDiffusion2> SPFDAdvectionDiffusion2;
95 
96 
97 } // asl
98 #endif // ASLFDADVECTIONDIFFUSION2_H
Numerical method which computes multicomponent transport processes; .
Advanced Simulation Library.
Definition: aslDataInc.h:30
SPDataWithGhostNodesACLData Data
Advanced Computational Language.
Definition: acl.h:40
std::shared_ptr< DataWithGhostNodesACLData > SPDataWithGhostNodesACLData
Definition: aslGenerators.h:47
void setVectorTemplate(VectorTemplate *vT)
DataWithGhostNodes< acl::VectorOfElementsData > DataWithGhostNodesACLData
Definition: aslGenerators.h:45
virtual void init()
Builds the necesery internal data and kernels.
void addComponent(Data c, double dC)
void setDiffusionCoefficient(double d, unsigned int i=0)
virtual void execute()
Executes the numerical procedure.
std::shared_ptr< FDAdvectionDiffusion2 > SPFDAdvectionDiffusion2
void setElectricFieldParameters(ScalarField phi, ScalarField f1, ScalarField f2, ScalarField qAnd)
std::shared_ptr< AbstractDataWithGhostNodes > SPAbstractDataWithGhostNodes
Definition: aslGenerators.h:50
SPAbstractDataWithGhostNodes ScalarField
Defines set of vectros with several properties.
Definition: aslTemplates.h:87
double getDiffusionCoefficient(unsigned int i=0)