21 #ifndef _aspect_material_model_interface_h 22 #define _aspect_material_model_interface_h 28 #include <deal.II/base/point.h> 29 #include <deal.II/base/quadrature.h> 30 #include <deal.II/base/symmetric_tensor.h> 31 #include <deal.II/base/parameter_handler.h> 32 #include <deal.II/dofs/dof_handler.h> 33 #include <deal.II/dofs/dof_accessor.h> 34 #include <deal.II/fe/mapping.h> 35 #include <deal.II/fe/fe_values.h> 36 #include <deal.II/fe/component_mask.h> 37 #include <deal.II/numerics/data_postprocessor.h> 38 #include <deal.II/base/signaling_nan.h> 53 namespace MaterialModel
59 namespace NonlinearDependence
102 return Dependence(static_cast<int>(d1) | static_cast<int>(d2));
172 namespace MaterialProperties
221 return Property(static_cast<int>(d1) | static_cast<int>(d2));
257 const unsigned int n_comp);
276 const bool compute_strain_rate =
true);
299 const typename DoFHandler<dim>::active_cell_iterator &cell,
302 const bool compute_strain_rate =
true);
340 void reinit(
const FEValuesBase<dim,dim> &fe_values,
341 const typename DoFHandler<dim>::active_cell_iterator &cell,
344 const bool compute_strain_rate =
true);
350 unsigned int n_evaluation_points()
const;
447 template <
class AdditionalInputType>
448 AdditionalInputType *get_additional_input();
454 template <
class AdditionalInputType>
455 const AdditionalInputType *get_additional_input()
const;
492 const unsigned int n_comp);
529 unsigned int n_evaluation_points()
const;
630 template <
class AdditionalOutputType>
631 AdditionalOutputType *get_additional_output();
636 template <
class AdditionalOutputType>
637 const AdditionalOutputType *get_additional_output()
const;
662 namespace MaterialAveraging
740 const typename DoFHandler<dim>::active_cell_iterator &cell,
741 const Quadrature<dim> &quadrature_formula,
742 const Mapping<dim> &mapping,
752 const FullMatrix<double> &projection_matrix,
753 const FullMatrix<double> &expansion_matrix,
754 std::vector<double> &values_out);
802 const FEValuesBase<dim> &fe_values,
844 const FullMatrix<double> &,
845 const FullMatrix<double> &)
896 const unsigned int n_points);
907 const std::vector<std::string> &
get_names()
const;
913 virtual std::vector<double> get_nth_output(
const unsigned int idx)
const;
916 const FullMatrix<double> &,
917 const FullMatrix<double> &)
override 928 const std::vector<std::string>
names;
943 std::vector<double> get_nth_output(
const unsigned int idx)
const override;
950 std::vector<double>
vs;
957 std::vector<double>
vp;
986 const unsigned int n_comp);
988 std::vector<double> get_nth_output(
const unsigned int idx)
const override;
1039 const unsigned int n_comp);
1041 std::vector<double> get_nth_output(
const unsigned int idx)
const override;
1072 std::vector<double> get_nth_output(
const unsigned int idx)
const override;
1095 : rhs_u(n_points), rhs_p(n_points), rhs_melt_pc(n_points)
1102 const FullMatrix<double> &,
1103 const FullMatrix<double> &)
override 1157 std::vector<double> get_nth_output(
const unsigned int idx)
const override;
1179 : elastic_force(n_points, numbers::signaling_nan<SymmetricTensor<2,dim>>())
1180 , viscoelastic_strain_rate(n_points, numbers::signaling_nan<SymmetricTensor<2,dim>>())
1187 const FullMatrix<double> &,
1188 const FullMatrix<double> &)
override 1225 : enthalpies_of_fusion(n_points, numbers::signaling_nan<double>())
1232 const FullMatrix<double> &,
1233 const FullMatrix<double> &)
override 1296 get_model_dependence ()
const;
1307 virtual bool is_compressible ()
const = 0;
1341 const FEValuesBase<dim> &fe_values,
1381 const std::string &description,
1382 void (*declare_parameters_function) (ParameterHandler &),
1396 std::unique_ptr<Interface<dim>>
1412 std::unique_ptr<Interface<dim>>
1456 template <
class AdditionalInputType>
1459 for (
unsigned int i=0; i<additional_inputs.size(); ++i)
1461 AdditionalInputType *result =
dynamic_cast<AdditionalInputType *
> (additional_inputs[i].get());
1470 template <
class AdditionalInputType>
1473 for (
unsigned int i=0; i<additional_inputs.size(); ++i)
1475 const AdditionalInputType *result =
dynamic_cast<const AdditionalInputType *
> (additional_inputs[i].get());
1484 template <
class AdditionalOutputType>
1489 AdditionalOutputType *result =
dynamic_cast<AdditionalOutputType *
> (
additional_outputs[i].get());
1498 template <
class AdditionalOutputType>
1503 const AdditionalOutputType *result =
dynamic_cast<const AdditionalOutputType *
> (
additional_outputs[i].get());
1514 Assert(this->
additional_outputs.empty(), ExcMessage(
"Destination of move needs to be empty!"));
1526 #define ASPECT_REGISTER_MATERIAL_MODEL(classname,name,description) \ 1527 template class classname<2>; \ 1528 template class classname<3>; \ 1529 namespace ASPECT_REGISTER_MATERIAL_MODEL_ ## classname \ 1531 aspect::internal::Plugins::RegisterHelper<aspect::MaterialModel::Interface<2>,classname<2>> \ 1532 dummy_ ## classname ## _2d (&aspect::MaterialModel::register_material_model<2>, \ 1533 name, description); \ 1534 aspect::internal::Plugins::RegisterHelper<aspect::MaterialModel::Interface<3>,classname<3>> \ 1535 dummy_ ## classname ## _3d (&aspect::MaterialModel::register_material_model<3>, \ 1536 name, description); \ void write_plugin_graph(std::ostream &output_stream)
AveragingOperation get_averaging_operation_for_viscosity(const AveragingOperation operation)
std::vector< double > entropy_derivative_pressure
std::vector< Tensor< 1, dim > > rhs_u
std::vector< double > compressibilities
std::vector< double > entropy_derivative_temperature
void average_property(const AveragingOperation operation, const FullMatrix< double > &projection_matrix, const FullMatrix< double > &expansion_matrix, std::vector< double > &values_out)
std::vector< double > rhs_melt_pc
std::vector< double > specific_heat
::TrilinosWrappers::MPI::BlockVector BlockVector
std::vector< double > thermal_expansion_coefficients
virtual void average(const MaterialAveraging::AveragingOperation, const FullMatrix< double > &, const FullMatrix< double > &)
std::vector< std::vector< double > > prescribed_field_outputs
void register_material_model(const std::string &name, const std::string &description, void(*declare_parameters_function)(ParameterHandler &), std::unique_ptr< Interface< dim >>(*factory_function)())
std::vector< std::unique_ptr< AdditionalMaterialOutputs< dim > > > additional_outputs
std::vector< double > thermal_conductivities
ElasticOutputs(const unsigned int n_points)
std::vector< std::vector< double > > reaction_rates
void declare_parameters(ParameterHandler &prm)
bool identifies_single_variable(const Dependence dependence)
void average(const MaterialAveraging::AveragingOperation, const FullMatrix< double > &, const FullMatrix< double > &) override
std::vector< std::vector< double > > reaction_terms
AdditionalOutputType * get_additional_output()
const std::vector< std::string > names
std::vector< double > densities
std::vector< double > rhs_p
void average(const MaterialAveraging::AveragingOperation operation, const FullMatrix< double > &, const FullMatrix< double > &) override
EnthalpyOutputs(const unsigned int n_points)
AveragingOperation parse_averaging_operation_name(const std::string &s)
Dependence compressibility
AdditionalMaterialOutputsStokesRHS(const unsigned int n_points)
std::vector< double > dilation
Dependence operator|=(Dependence &d1, const Dependence d2)
void move_additional_outputs_from(MaterialModelOutputs< dim > &other)
std::vector< double > enthalpies_of_fusion
std::string get_averaging_operation_names()
std::vector< SymmetricTensor< 2, dim > > elastic_force
std::vector< std::vector< double > > output_values
void average(const MaterialAveraging::AveragingOperation operation, const FullMatrix< double > &, const FullMatrix< double > &) override
std::vector< double > viscosities
std::vector< double > prescribed_temperature_outputs
NonlinearDependence::ModelDependence model_dependence
std::unique_ptr< Interface< dim > > create_material_model(const std::string &model_name)
void average(const AveragingOperation operation, const typename DoFHandler< dim >::active_cell_iterator &cell, const Quadrature< dim > &quadrature_formula, const Mapping< dim > &mapping, const MaterialProperties::Property &requested_properties, MaterialModelOutputs< dim > &values_out)
Dependence thermal_conductivity
std::string get_valid_model_names_pattern()
Dependence operator|(const Dependence d1, const Dependence d2)
std::vector< SymmetricTensor< 2, dim > > viscoelastic_strain_rate
void average(const MaterialAveraging::AveragingOperation, const FullMatrix< double > &, const FullMatrix< double > &) override