Feellgood
solver.h
Go to the documentation of this file.
1 #ifndef solver_h
2 #define solver_h
3 
11 #include <eigen3/Eigen/Dense>
12 #include "mesh.h"
13 #include "algebra/algebra.h"
14 
20 template <int DIM_PROBLEM>
21 class solver
22  {
23  public:
25  explicit solver(Mesh::mesh & _msh ,
26  const std::vector<Tetra::prm> & _pTetra ,
28  const std::vector<Triangle::prm> & _pTri ,
30  const std::string& name ,
31  const double _tol ,
32  const bool v ,
33  const int max_iter ,
34  const std::function<bool(Mesh::Edge)> &edge_filter = [](Mesh::Edge){ return true; }):
36  msh(&_msh), NOD(_msh.getNbNodes()), paramTet(_pTetra),
37  paramTri(_pTri), verbose(v), iter(name,_tol,v,max_iter),
38  K(build_shape(edge_filter)), L_rhs(DIM_PROBLEM*NOD) {}
39 
41  virtual void checkBoundaryConditions(void) const = 0;
42 
43  protected:
45  static const int DIM_PB = DIM_PROBLEM;
46 
49 
51  const int NOD;
52 
55  const std::vector<Tetra::prm> &paramTet;
56 
59  const std::vector<Triangle::prm> &paramTri;
60 
62  const bool verbose;
63 
66 
69 
71  std::vector<double> L_rhs;
72 
74  algebra::MatrixShape build_shape(const std::function<bool(Mesh::Edge)>& edge_filter) const
75  {
76  algebra::MatrixShape shape(DIM_PROBLEM * NOD);
77 
78  // Add a DIM_PROBLEM × DIM_PROBLEM block connecting nodes i and j.
79  auto add_block = [this, &shape](const int i, const int j)
80  {
81  for (int k = 0; k < DIM_PROBLEM; ++k)
82  {
83  for (int l = 0; l < DIM_PROBLEM; ++l)
84  { shape[DIM_PROBLEM*i+k].insert(DIM_PROBLEM*j+l); }
85  }
86  };
87 
88  // Add a diagonal block for each node.
89  for (int i = 0; i < NOD; ++i)
90  { add_block(i, i); }
91 
92  // Add two off-diagonal blocks for each edge relevant to the current problem.
93  for (auto edge: msh->edges)
94  {
95  if (edge_filter(edge))
96  {
97  add_block(edge.first, edge.second);
98  add_block(edge.second, edge.first);
99  }
100  }
101 
102  return shape;
103  }
104 
108  template <int N>
109  void buildMat(std::array<int,N> &ind, Eigen::Matrix<double,DIM_PROBLEM*N,DIM_PROBLEM*N> &Ke)
110  {
111  for (int ie=0; ie<N; ie++)
112  {
113  int i_ = ind[ie];
114  for (int je=0; je<N; je++)
115  {
116  int j_ = ind[je];
117  for (int di=0; di<DIM_PROBLEM; di++)
118  for (int dj=0; dj<DIM_PROBLEM; dj++)
119  K.add(DIM_PROBLEM*i_ + di, DIM_PROBLEM*j_ + dj, Ke(di*N+ie,dj*N+je));
120  }
121  }
122  }
123 
127  template <int N>
128  void buildVect(std::array<int,N> &ind, std::vector<double> &Le)
129  {
130  for (int ie=0; ie<N; ie++)
131  {
132  int i_ = ind[ie];
133  for (int di=0; di<DIM_PROBLEM; di++)
134  { L_rhs[DIM_PROBLEM*i_ + di] += Le[di*N+ie]; }
135  }
136  }
137  }; // end template class solver
138 
139 #endif
set of class to handle sparse matrix operations for gradient conjugate algorithms a sparse vector cla...
Definition: mesh.h:32
std::vector< Edge > edges
Definition: mesh.h:350
int getNbNodes(void) const
Definition: mesh.h:144
Square sparse matrix.
Definition: sparseMat.h:46
void add(const int i, const int j, const double val)
Definition: sparseMat.h:114
template class for the different solvers template parameter DIM_PROBLEM: dimensionnality of the probl...
Definition: solver.h:22
Mesh::mesh * msh
Definition: solver.h:48
virtual void checkBoundaryConditions(void) const =0
void buildMat(std::array< int, N > &ind, Eigen::Matrix< double, DIM_PROBLEM *N, DIM_PROBLEM *N > &Ke)
Definition: solver.h:109
algebra::SparseMatrix K
Definition: solver.h:68
void buildVect(std::array< int, N > &ind, std::vector< double > &Le)
Definition: solver.h:128
const int NOD
Definition: solver.h:51
const bool verbose
Definition: solver.h:62
algebra::iteration< double > iter
Definition: solver.h:65
const std::vector< Tetra::prm > & paramTet
Definition: solver.h:55
const std::vector< Triangle::prm > & paramTri
Definition: solver.h:59
algebra::MatrixShape build_shape(const std::function< bool(Mesh::Edge)> &edge_filter) const
Definition: solver.h:74
solver(Mesh::mesh &_msh, const std::vector< Tetra::prm > &_pTetra, const std::vector< Triangle::prm > &_pTri, const std::string &name, const double _tol, const bool v, const int max_iter, const std::function< bool(Mesh::Edge)> &edge_filter=[](Mesh::Edge){ return true;})
Definition: solver.h:25
static const int DIM_PB
Definition: solver.h:45
std::vector< double > L_rhs
Definition: solver.h:71
class mesh, readMesh is expecting a mesh file in gmsh format either text or binary,...
std::pair< int, int > Edge
Definition: mesh.h:25
const int N
Definition: tetra.h:25
constexpr double v[NPI]
Definition: tetra.h:58
std::vector< std::set< int > > MatrixShape
Definition: sparseMat.h:38