MAST
Multidisciplinary-design Adaptation and Sensitivity Toolkit (MAST)
solid_1d_section_element_property_card.h
Go to the documentation of this file.
1 /*
2  * MAST: Multidisciplinary-design Adaptation and Sensitivity Toolkit
3  * Copyright (C) 2013-2020 Manav Bhatia and MAST authors
4  *
5  * This library is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU Lesser General Public
7  * License as published by the Free Software Foundation; either
8  * version 2.1 of the License, or (at your option) any later version.
9  *
10  * This library is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13  * Lesser General Public License for more details.
14  *
15  * You should have received a copy of the GNU Lesser General Public
16  * License along with this library; if not, write to the Free Software
17  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18  */
19 
20 #ifndef __mast__solid_1d_section_element_property_card__
21 #define __mast__solid_1d_section_element_property_card__
22 
23 
24 // MAST includes
26 
27 namespace MAST {
28 
29 
32 
33  public:
34 
37  _initialized(false),
38  _material(nullptr)
39  { }
40 
41 
46 
47 
48  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
49  stiffness_A_matrix(const MAST::ElementBase& e) const;
50 
51  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
52  stiffness_B_matrix(const MAST::ElementBase& e) const;
53 
54  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
55  stiffness_D_matrix(const MAST::ElementBase& e) const;
56 
57  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
58  damping_matrix(const MAST::ElementBase& e) const;
59 
60  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
61  inertia_matrix(const MAST::ElementBase& e) const;
62 
63  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
65 
66  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
68 
69  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
71 
72  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
74 
75  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
77 
78  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
80 
81  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
83 
84  virtual const MAST::FieldFunction<Real>*
85  section(const MAST::ElementBase& e) const;
86 
87  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
88  stiffness_A_matrix() const;
89 
90  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
91  stiffness_B_matrix() const;
92 
93  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
94  stiffness_D_matrix() const;
95 
96  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
97  damping_matrix() const;
98 
99  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
100  inertia_matrix() const;
101 
102  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
104 
105  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
107 
108  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
110 
111  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
112  prestress_A_matrix() const;
113 
114  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
115  prestress_B_matrix() const;
116 
117  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
119 
120  virtual std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
122 
123  virtual const MAST::FieldFunction<Real>*
124  section() const;
125 
126 
131  _material = &mat;
132  }
133 
134 
138  virtual bool if_isotropic() const {
139  return true;
140  }
141 
142 
147  libmesh_assert(_material); // make sure it has already been set
148  return *_material;
149  }
150 
154  virtual const MAST::FieldFunction<Real>& A() const;
155 
156 
160  virtual MAST::FieldFunction<Real>& A();
161 
166  virtual const MAST::FieldFunction<Real>& J() const;
167 
172  virtual MAST::FieldFunction<Real>& J();
173 
177  virtual const MAST::FieldFunction<Real>& Ip() const;
178 
182  virtual MAST::FieldFunction<Real>& Ip();
183 
188  virtual const MAST::FieldFunction<Real>& Ay() const;
189 
194  virtual MAST::FieldFunction<Real>& Ay();
195 
200  virtual const MAST::FieldFunction<Real>& Az() const;
201 
206  virtual MAST::FieldFunction<Real>& Az();
207 
212  virtual const MAST::FieldFunction<RealMatrixX>& I() const;
213 
214 
220 
225  virtual const MAST::FieldFunction<RealMatrixX>& Kap() const;
226 
227 
232  virtual const MAST::FieldFunction<Real>& Gam() const;
233 
234 
240 
241 
246  virtual MAST::FieldFunction<Real>& Gam();
247 
251  virtual bool depends_on(const MAST::FunctionBase& f) const;
252 
253 
254  virtual void clear();
255 
256  virtual void init();
257 
258  protected:
259 
261 
266 
267  std::unique_ptr<MAST::FieldFunction<Real> > _A;
268 
269  std::unique_ptr<MAST::FieldFunction<Real> > _J;
270 
271  std::unique_ptr<MAST::FieldFunction<Real> > _Ip;
272 
273  std::unique_ptr<MAST::FieldFunction<Real> > _Ay;
274 
275  std::unique_ptr<MAST::FieldFunction<Real> > _Az;
276 
277  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _AI;
278 
279  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _Kappa;
280 
281  std::unique_ptr<MAST::FieldFunction<Real> > _Gamma;
282 
283  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _stiff_A;
284 
285  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _stiff_B;
286 
287  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _stiff_D;
288 
289  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _damp;
290 
291  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _inertia;
292 
293  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _thermal_A;
294 
295  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _thermal_B;
296 
297  std::unique_ptr<MAST::FieldFunction<RealMatrixX> > _transverse_shear;
298 
299  };
300 
301 }
302 
303 
304 
305 #endif // __mast__solid_1d_section_element_property_card__
std::unique_ptr< MAST::FieldFunction< Real > > _Ip
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _thermal_A
MAST::MaterialPropertyCardBase * _material
material property card
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > transverse_shear_stiffness_matrix() const
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _transverse_shear
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _AI
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > stiffness_D_matrix() const
virtual const MAST::FieldFunction< Real > & Ip() const
virtual void set_material(MAST::MaterialPropertyCardBase &mat)
sets the material card
virtual const MAST::FieldFunction< Real > * section() const
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _damp
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _stiff_D
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > prestress_A_matrix() const
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > thermal_capacitance_matrix() const
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > inertia_matrix() const
virtual const MAST::FieldFunction< RealMatrixX > & I() const
virtual bool depends_on(const MAST::FunctionBase &f) const
returns true if the property card depends on the function f
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _stiff_A
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > stiffness_B_matrix() const
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > stiffness_A_matrix() const
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > prestress_B_matrix() const
std::unique_ptr< MAST::FieldFunction< Real > > _J
virtual const MAST::FieldFunction< Real > & Az() const
virtual const MAST::FieldFunction< Real > & Gam() const
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > thermal_expansion_A_matrix() const
virtual bool if_isotropic() const
return true if the property is isotropic
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > thermal_conductance_matrix() const
virtual const MAST::FieldFunction< Real > & A() const
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _stiff_B
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > thermal_expansion_B_matrix() const
std::unique_ptr< MAST::FieldFunction< Real > > _Az
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _inertia
virtual const MAST::FieldFunction< Real > & Ay() const
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _Kappa
std::unique_ptr< MAST::FieldFunction< RealMatrixX > > _thermal_B
virtual const MAST::MaterialPropertyCardBase & get_material() const
returns a reference to the material
std::unique_ptr< MAST::FieldFunction< Real > > _A
std::unique_ptr< MAST::FieldFunction< Real > > _Gamma
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > damping_matrix() const
virtual const MAST::FieldFunction< RealMatrixX > & Kap() const
virtual const MAST::FieldFunction< Real > & J() const
std::unique_ptr< MAST::FieldFunction< Real > > _Ay
This is the base class for elements that implement calculation of finite element quantities over the ...
Definition: elem_base.h:72