ASL  0.1.7
Advanced Simulation Library
aslFDAdvectionDiffusionInhomogeneous.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 ASLFDADVECTIONDIFFUSIONINHOMOGENEOUS_H
25 #define ASLFDADVECTIONDIFFUSIONINHOMOGENEOUS_H
26 
27 #include "aslNumMethod.h"
28 
29 
30 namespace acl
31 {
32  class Kernel;
33  class VectorOfElementsData;
34 }
35 
36 namespace asl
37 {
38  class VectorTemplate;
39  template <typename V> class DataWithGhostNodes;
40  typedef DataWithGhostNodes<acl::VectorOfElementsData> DataWithGhostNodesACLData;
41  typedef std::shared_ptr<DataWithGhostNodesACLData> SPDataWithGhostNodesACLData;
42  class AbstractDataWithGhostNodes;
43  typedef std::shared_ptr<AbstractDataWithGhostNodes> SPAbstractDataWithGhostNodes;
44 
46 
51  {
52  public:
55  private:
56  std::unique_ptr<acl::Kernel> kernel;
57 
58  std::vector<Data> cData;
59  std::vector<Data> cInternalData;
60 
61  const VectorTemplate* vectorTemplate;
62 
63  int t;
64  std::vector<ScalarField> diffusivity;
65  public:
70  virtual void init();
71  virtual void execute();
72  void addComponent(Data c, ScalarField dC);
73  };
74 
75  typedef std::shared_ptr<FDAdvectionDiffusionInhomogeneous> SPFDAdvectionDiffusionInhomogeneous;
76 
77 
78 } // asl
79 #endif // ASLFDADVECTIONDIFFUSIONINHOMOGENEOUS_H
Advanced Simulation Library.
Definition: aslDataInc.h:30
Advanced Computational Language.
Definition: acl.h:40
std::shared_ptr< DataWithGhostNodesACLData > SPDataWithGhostNodesACLData
Definition: aslGenerators.h:47
DataWithGhostNodes< acl::VectorOfElementsData > DataWithGhostNodesACLData
Definition: aslGenerators.h:45
void addComponent(Data c, ScalarField dC)
std::shared_ptr< FDAdvectionDiffusionInhomogeneous > SPFDAdvectionDiffusionInhomogeneous
Numerical method which computes multicomponent transport processes.
virtual void init()
Builds the necesery internal data and kernels.
std::shared_ptr< AbstractDataWithGhostNodes > SPAbstractDataWithGhostNodes
Definition: aslGenerators.h:50
void setVectorTemplate(VectorTemplate *vT)
virtual void execute()
Executes the numerical procedure.
Defines set of vectros with several properties.
Definition: aslTemplates.h:87