Alamo
Elastic.H
Go to the documentation of this file.
1#ifndef OPERATOR_ELASTIC_H_
2#define OPERATOR_ELASTIC_H_
3
4#include <AMReX_MLCellLinOp.H>
5#include <AMReX_Array.H>
6#include <limits>
7#include "Set/Set.H"
8#include "Operator/Operator.H"
9#include "Model/Solid/Solid.H"
11#include "Numeric/Stencil.H"
12#include "IC/IC.H"
13
14using namespace amrex;
15
16namespace Operator
17{
18///
19/// \todo Remove Elastic derived classes. They have been replaced with the Model construction.
20///
21template<int SYM>
22class Elastic : public Operator<Grid::Node>
23{
25 using TArrayBox = amrex::BaseFab<MATRIX4>;
26 using MultiTab = amrex::FabArray<TArrayBox>;
27public:
29 enum class Boundary {Lo, Hi, None};
30
31 Elastic () {}
32 Elastic (const Vector<Geometry>& a_geom,
33 const Vector<BoxArray>& a_grids,
34 const Vector<DistributionMapping>& a_dmap,
35 const LPInfo& a_info);
36 virtual ~Elastic ();
37 Elastic (const Elastic&) = delete;
38 Elastic (Elastic&&) = delete;
39 Elastic& operator= (const Elastic&) = delete;
41
42 void define (const Vector<Geometry>& a_geom,
43 const Vector<BoxArray>& a_grids,
44 const Vector<DistributionMapping>& a_dmap,
45 const LPInfo& a_info = LPInfo(),
46 const Vector<FabFactory<FArrayBox> const*>& a_factory = {});
47
48 virtual void SetHomogeneous (bool a_homogeneous) override {m_homogeneous = a_homogeneous;}
50 void SetModel (int amrlev, const MultiTab& a_model);
51 void SetModel (const amrex::Vector<MultiTab> & a_model)
52 { for (int ilev = 0; ilev < a_model.size(); ilev++) SetModel(ilev,a_model[ilev]);}
54 { for (int ilev = 0; ilev < a_model.size(); ilev++) SetModel(ilev,*a_model[ilev]);}
55 void SetPsi (int amrlev, const amrex::MultiFab& a_psi);
56 void SetPsi (int amrlev, const amrex::MultiFab& a_psi, const Set::Scalar &a_psi_small)
57 {m_psi_small = a_psi_small; SetPsi(amrlev,a_psi);}
58
59 /// The different types of Boundary Condtiions are listed in the `BC::Operator::Elastic` documentation
60 ///
62 {
63 if (this->Geom(0).isAnyPeriodic())
64 {
65 Util::Warning(INFO,"Looks like you're using a periodic domain. \nThat is currently VERY DANGEROUS when using linear elastic solver!!!");
66 }
67 m_bc = a_bc;
68 m_bc_set = true;
69 };
71 {
72 return *m_bc;
73 }
74
75 /// Compute strain \f$\mathbf{\epsilon}\f$ given the displacement field \f$\mathbf{u}\f$
76 /// by
77 /// \f[\mathbf{\epsilon}_{ij} = \frac{1}{2}(u_{i,j} + u_{j,i})\f]
78 ///
79 void Strain (int amrlev, amrex::MultiFab& epsfab, const amrex::MultiFab& ufab, bool voigt = false) const;
80
81 /// Compute stress \f$\mathbf{\sigma}\f$ given the displacement field \f$\mathbf{u}\f$
82 /// by
83 /// \f[\mathbf{\sigma}_{ij} = \mathbb{C}_{ijkl}\,u_{k,l}\f]
84 /// where, \f$\mathbb{C}\f$ is furnished by the templated `model`
85 ///
86 void Stress (int amrlev, amrex::MultiFab& sigmafab, const amrex::MultiFab& ufab, bool voigt = false, bool a_homogeneous=false);
87
88 /// Compute energy density \f$\mathbb{W}\f$ given the displacement field \f$\mathbf{u}\f$
89 /// by
90 /// \f[\mathbb{W} = \mathbb{\Sigma}\mathbb{\Sigma}\mathbf{\sigma}_{ij}\mathbf{\epsilon}_{ij}\f]
91 /// where \f$\mathbf{\sigma}\f$ and \f$\mathbf{\epsilon}\f$ are as defined above
92 ///
93 void Energy (int amrlev, amrex::MultiFab& energy, const amrex::MultiFab& u, bool a_homogeneous=false);
94
95 //void Energy (int amrlev, amrex::MultiFab& energies, const amrex::MultiFab& u, std::vector<SOLID> models, bool a_homogeneous=false);
96
97 /// This function is depricated and should not be used. Use the other `SetBC` function.
98 ///
99 void SetBC(const std::array<std::array<BC,AMREX_SPACEDIM>,AMREX_SPACEDIM> &a_bc_lo,
100 const std::array<std::array<BC,AMREX_SPACEDIM>,AMREX_SPACEDIM> &a_bc_hi)
101 {
102 Util::Abort(INFO,"This is now depricated. Use the other SetBC function.");
103 m_bc_lo = a_bc_lo;m_bc_hi = a_bc_hi;
104 };
105
106 void Error0x (int amrlev, int mglev, MultiFab& R0x, const MultiFab& x) const;
107
108 void SetTesting(bool a_testing) {m_testing = a_testing;}
109 void SetUniform(bool a_uniform) {m_uniform = a_uniform;}
110 virtual void SetAverageDownCoeffs(bool a_average_down_coeffs) override
111 {m_average_down_coeffs = a_average_down_coeffs;}
112
113 using Operator::Reflux;
114
115protected:
116
117 virtual void Diagonal (int amrlev, int mglev, amrex::MultiFab& diag) override;
118
119 virtual void Fapply (int amrlev, int mglev, MultiFab& out, const MultiFab& in) const override final;
120 virtual void FFlux (int amrlev, const MFIter& mfi,
121 const std::array<FArrayBox*,AMREX_SPACEDIM>& flux,
122 const FArrayBox& sol, const int face_only=0) const final;
123
124
125
126
127 virtual int getNComp() const override {return AMREX_SPACEDIM;};
128 virtual bool isCrossStencil () const { return false; }
129 virtual void prepareForSolve () override
130 {
131 if (!m_model_set) Util::Abort(INFO,"Attempting to use operator before calling SetModel!");
132 if (!m_bc_set) Util::Warning(INFO,"Attempting to use operator before calling SetBC!");
134 };
135
136private:
137 /// Simple arrays storing boundary conditions for each component and each face.
138 std::array<std::array<BC,AMREX_SPACEDIM>, AMREX_SPACEDIM> m_bc_lo; // m_bc_lo[face][dimension]
139 std::array<std::array<BC,AMREX_SPACEDIM>, AMREX_SPACEDIM> m_bc_hi; // m_bc_hi[face][dimension]
140
141 /// This is a multifab-type object containing objects of type
142 /// Model::Solid::Elastic::Isotropic::Isotropic
143 /// (or some other model type). T is the template argument.
144 /// The models contain elastic constants and contain methods for converting strain to stress
145 amrex::Vector<Set::Field<Set::Matrix4<AMREX_SPACEDIM,SYM>>> m_ddw_mf;
146
147 // This is a mask variable.
148 amrex::Vector<Set::Field<Set::Scalar>> m_psi_mf;
150 bool m_psi_set = false;
151
152 virtual void averageDownCoeffs () override;
153 void averageDownCoeffsDifferentAmrLevels (int fine_amrlev);
154
155 /// \fn averageDownCoeffsSameAmrLevel
156 /// \brief Update coarse-level AMR coefficients with data from fine level
157 ///
158 /// This function is called before the solve, and it updates the Matrix4 coefficients
159 /// on coarse levels with averaged versions on the fine levels.
160 /// Typically, this is not necessary, since the coefficients are computed on each level
161 /// already.
162 /// However, there are some cases where this messes up the multigrid solver.
163 /// (Phase field fracture is the primary example.)
164 ///
165 /// This is disabled by default. In order to enable, call
166 ///
167 /// elasticoperator.SetAverageDownCoeffs(true);
168 ///
169 void averageDownCoeffsSameAmrLevel (int amrlev);
170
171 void FillBoundaryCoeff (MultiTab& sigma, const Geometry& geom);
172 void FillBoundaryCoeff (MultiFab& psi, const Geometry& geom);
173
174 bool m_testing = false;
175 bool m_uniform = false;
176 bool m_homogeneous = false;
177
179
181
182 bool m_model_set = false;
183 bool m_bc_set = false;
184
185public:
186 static void Parse(Elastic<SYM> & value, IO::ParmParse & pp)
187 {
188 // Regularization offset value used in near-singular elastic solves.
189 // It should be small - if it is too large, you will get better convergence
190 // but less correct values!
191 pp_query("small",value.m_psi_small);
192 }
193
194};
195}
196
197#endif
#define pp_query(...)
Definition ParmParse.H:106
#define INFO
Definition Util.H:20
void SetModel(int amrlev, const MultiTab &a_model)
static void Parse(Elastic< SYM > &value, IO::ParmParse &pp)
Definition Elastic.H:186
void define(const Vector< Geometry > &a_geom, const Vector< BoxArray > &a_grids, const Vector< DistributionMapping > &a_dmap, const LPInfo &a_info=LPInfo(), const Vector< FabFactory< FArrayBox > const * > &a_factory={})
Definition Elastic.cpp:26
amrex::Vector< Set::Field< Set::Matrix4< AMREX_SPACEDIM, SYM > > > m_ddw_mf
This is a multifab-type object containing objects of type Model::Solid::Elastic::Isotropic::Isotropic...
Definition Elastic.H:145
Set::Scalar m_psi_small
Definition Elastic.H:149
void SetModel(Set::Matrix4< AMREX_SPACEDIM, SYM > &a_model)
Definition Elastic.cpp:59
amrex::FabArray< TArrayBox > MultiTab
Definition Elastic.H:26
void SetBC(::BC::Operator::Elastic::Elastic *a_bc)
The different types of Boundary Condtiions are listed in the BC::Operator::Elastic documentation.
Definition Elastic.H:61
void Stress(int amrlev, amrex::MultiFab &sigmafab, const amrex::MultiFab &ufab, bool voigt=false, bool a_homogeneous=false)
Compute stress given the displacement field by.
Definition Elastic.cpp:464
virtual int getNComp() const override
Definition Elastic.H:127
virtual bool isCrossStencil() const
Definition Elastic.H:128
void SetTesting(bool a_testing)
Definition Elastic.H:108
void SetUniform(bool a_uniform)
Definition Elastic.H:109
std::array< std::array< BC, AMREX_SPACEDIM >, AMREX_SPACEDIM > m_bc_lo
Simple arrays storing boundary conditions for each component and each face.
Definition Elastic.H:138
virtual void FFlux(int amrlev, const MFIter &mfi, const std::array< FArrayBox *, AMREX_SPACEDIM > &flux, const FArrayBox &sol, const int face_only=0) const final
Definition Elastic.cpp:386
void Error0x(int amrlev, int mglev, MultiFab &R0x, const MultiFab &x) const
Definition Elastic.cpp:359
virtual void prepareForSolve() override
Definition Elastic.H:129
std::array< std::array< BC, AMREX_SPACEDIM >, AMREX_SPACEDIM > m_bc_hi
Definition Elastic.H:139
::BC::Operator::Elastic::Elastic & GetBC()
Definition Elastic.H:70
void SetBC(const std::array< std::array< BC, AMREX_SPACEDIM >, AMREX_SPACEDIM > &a_bc_lo, const std::array< std::array< BC, AMREX_SPACEDIM >, AMREX_SPACEDIM > &a_bc_hi)
This function is depricated and should not be used.
Definition Elastic.H:99
void SetModel(const amrex::Vector< MultiTab > &a_model)
Definition Elastic.H:51
bool m_average_down_coeffs
Definition Elastic.H:178
void averageDownCoeffsSameAmrLevel(int amrlev)
Update coarse-level AMR coefficients with data from fine level.
Definition Elastic.cpp:720
void FillBoundaryCoeff(MultiTab &sigma, const Geometry &geom)
Definition Elastic.cpp:883
virtual void SetHomogeneous(bool a_homogeneous) override
Definition Elastic.H:48
Elastic & operator=(const Elastic &)=delete
::BC::Operator::Elastic::Elastic * m_bc
Definition Elastic.H:180
virtual ~Elastic()
Definition Elastic.cpp:21
void Strain(int amrlev, amrex::MultiFab &epsfab, const amrex::MultiFab &ufab, bool voigt=false) const
Compute strain given the displacement field by.
Definition Elastic.cpp:403
void SetPsi(int amrlev, const amrex::MultiFab &a_psi, const Set::Scalar &a_psi_small)
Definition Elastic.H:56
virtual void SetAverageDownCoeffs(bool a_average_down_coeffs) override
Definition Elastic.H:110
Elastic(Elastic &&)=delete
amrex::Vector< Set::Field< Set::Scalar > > m_psi_mf
Definition Elastic.H:148
void Energy(int amrlev, amrex::MultiFab &energy, const amrex::MultiFab &u, bool a_homogeneous=false)
Compute energy density given the displacement field by.
Definition Elastic.cpp:529
void averageDownCoeffsDifferentAmrLevels(int fine_amrlev)
Definition Elastic.cpp:605
void SetModel(const Set::Field< Set::Matrix4< AMREX_SPACEDIM, SYM > > &a_model)
Definition Elastic.H:53
virtual void Fapply(int amrlev, int mglev, MultiFab &out, const MultiFab &in) const override final
Definition Elastic.cpp:147
amrex::BaseFab< MATRIX4 > TArrayBox
Definition Elastic.H:25
Elastic(const Elastic &)=delete
virtual void averageDownCoeffs() override
Definition Elastic.cpp:582
void SetPsi(int amrlev, const amrex::MultiFab &a_psi)
Definition Elastic.cpp:126
const Geometry & Geom(int amr_lev, int mglev=0) const noexcept
Definition Operator.H:49
Collection of boundary condition (BC) objects.
Definition BC.cpp:5
Documentation for operator namespace.
Definition Diagonal.cpp:14
amrex::Real Scalar
Definition Base.H:19
Eigen::Matrix< amrex::Real, AMREX_SPACEDIM, 1 > Vector
Definition Base.H:20
void Abort(const char *msg)
Definition Util.cpp:170
void Warning(std::string file, std::string func, int line, Args const &... args)
Definition Util.H:181