GranOO  3.0
A robust and versatile workbench to build 3D dynamic simulations based on the Discrete Element Method
Thermal.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 _LibDEM_Prop_Thermal_HPP
31 #define _LibDEM_Prop_Thermal_HPP
32 
33 #include "GranOO3/Core/Prop.hpp"
34 #include "GranOO3/DEM/Element.hpp"
35 
36 
37 namespace GranOO3
38 {
39  namespace DEM
40  {
41 
42  class Thermal : public Core::Prop<Element>,
43  public Core::Register<Thermal>
44  {
45 
46  GRANOO_CLASS(DEM::Thermal, Core::Prop<Element>);
47 
48  public:
49  Thermal();
50  virtual ~Thermal();
51 
52  // Usefull for internal use only, NOT DOCUMENTED !
53  virtual std::string info() const;
54 
55  // Accessors and mutators
56  GRANOO_ACCESS(capacity , double, _capacity );
57  GRANOO_ACCESS(conductivity , double, _conductivity );
58  GRANOO_ACCESS(temperature , double, _temperature );
59  GRANOO_ACCESS(temperature_variation, double, _temperature_variation);
60 
61  private:
63  template<class Archive> void serialize(Archive& ar, const unsigned int );
64 
65  private:
66  double _capacity;
67  double _conductivity;
68  double _temperature;
70  };
71 
72  template<class Archive> void
73  Thermal::serialize(Archive& ar, const unsigned int) {
74  ar & boost::serialization::base_object<Core::Prop<Element> >(*this);
75  ar & _capacity;
76  ar & _conductivity;
77  ar & _temperature;
79  }
80 
81  }
82 }
83 
84 namespace GranOO3
85 {
86  GRANOO_CLASS_DECLARE_TPL(DEM::Thermal);
87 }
88 
89 
90 #endif
91 
Definition: Prop.hpp:48
Definition: SetOf.hpp:346
a property for adding thermal physics to DEM::Element
Definition: Thermal.hpp:44
double _capacity
The thermal capacity of the element (same as the simulated material)
Definition: Thermal.hpp:66
double _conductivity
The thermal conductivity of the element (same as the simulated material)
Definition: Thermal.hpp:67
virtual std::string info() const
Definition: Thermal.cpp:58
Thermal()
constructor
Definition: Thermal.cpp:46
friend class boost::serialization::access
Definition: Thermal.hpp:62
void serialize(Archive &ar, const unsigned int)
complete serializing of the instance in the *.gdd format
Definition: Thermal.hpp:73
virtual ~Thermal()
destructor
Definition: Thermal.cpp:54
double _temperature_variation
The current temperature variation (incremental variation) of the element.
Definition: Thermal.hpp:69
double _temperature
The current temperature of the element.
Definition: Thermal.hpp:68
Definition: Common.hpp:198