GranOO  3.0
A robust and versatile workbench to build 3D dynamic simulations based on the Discrete Element Method
SolverCD.hpp
Go to the documentation of this file.
1 // This file is part of GranOO, a workbench for DEM simulation.
2 //
3 // Author(s) : - Damien Andre IRCER/UNILIM, Limoges France
4 // <damien.andre@unilim.fr>
5 // - Jean-luc Charles Arts et Metiers ParisTech, CNRS, I2M, Bordeaux France
6 // <jean-luc.charles@ensam.eu>
7 // - Jeremie Girardot Arts et Metiers ParisTech, CNRS, I2M, Bordeaux France
8 // <jeremie.girardot@ensam.eu>
9 // - Cedric Hubert LAMIH/UPHF, Valenciennes France
10 // <cedric.hubert@uphf.fr>
11 // - Ivan Iordanoff Arts et Metiers ParisTech, CNRS, I2M, Bordeaux France
12 // <ivan.iordanoff@ensam.eu>
13 //
14 // Copyright (C) 2008-2019 D. Andre, JL. Charles, J. Girardot, C. Hubert, I. Iordanoff
15 //
16 // This program is free software: you can redistribute it and/or modify
17 // it under the terms of the GNU General Public License as published by
18 // the Free Software Foundation, either version 3 of the License, or
19 // (at your option) any later version.
20 //
21 // This program is distributed in the hope that it will be useful,
22 // but WITHOUT ANY WARRANTY; without even the implied warranty of
23 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
24 // GNU General Public License for more details.
25 //
26 // You should have received a copy of the GNU General Public License
27 // along with this program. If not, see <http://www.gnu.org/licenses/>.
28 
29 
30 #ifndef _LibPlugIn_SolverCD_HPP
31 #define _LibPlugIn_SolverCD_HPP
32 
33 #include <string>
34 #include <iostream>
35 #include <fstream>
36 
37 #include "GranOO3/FEM/Element.hpp"
38 
40 #include "GranOO3/Core/PlugIn.hpp"
41 
42 namespace GranOO3
43 {
44  namespace PlugIn
45  {
46  class SolverCD : public Core::PlugInInterface<SolverCD>,
47  public GranOO3::Core::NeedSetOf<GranOO3::Physic::Node>
48  {
49  public:
51 
52  SolverCD();
53  ~SolverCD() {};
54 
55  void parse_xml();
56  void init();
57  void run();
58 
59  private:
60  void assemble_mass_matrix();
61 
62  private:
63  Eigen::SparseMatrix<double> _MMat;
64  Eigen::SparseVector<double> _lumpedMMat;
65  Eigen::VectorXd _ooDispVector; // global displacement vector (at t-dt)
66  Eigen::VectorXd _oDispVector; // global displacement vector (at t)
67 // Eigen::SparseVector<double> _ooDispVector; // global displacement vector (at t-dt)
68 // Eigen::SparseVector<double> _oDispVector; // global displacement vector (at t)
69  unsigned int _totalDofsCount;
70  };
71  }
72 }
73 
74 #endif
Definition: NeedSetOf.hpp:51
Definition: PlugIn.hpp:177
Definition: SolverCD.hpp:48
Eigen::SparseMatrix< double > _MMat
Definition: SolverCD.hpp:63
void assemble_mass_matrix()
Definition: SolverCD.cpp:101
void parse_xml()
Definition: SolverCD.cpp:64
unsigned int _totalDofsCount
Definition: SolverCD.hpp:69
Eigen::SparseVector< double > _lumpedMMat
Definition: SolverCD.hpp:64
~SolverCD()
Definition: SolverCD.hpp:53
DECLARE_STD_GRANOO_PLUGIN(SOLVER-CD) SolverCD()
void init()
Definition: SolverCD.cpp:67
void run()
Definition: SolverCD.cpp:80
Eigen::VectorXd _ooDispVector
Definition: SolverCD.hpp:65
Eigen::VectorXd _oDispVector
Definition: SolverCD.hpp:66
Definition: Common.hpp:198