22 #ifndef _aspect_material_model_grain_size_h 23 #define _aspect_material_model_grain_size_h 32 #include <deal.II/matrix_free/fe_point_evaluation.h> 38 namespace MaterialModel
51 std::vector<double>
get_nth_output(
const unsigned int idx)
const override;
110 bool is_compressible ()
const override;
133 parse_parameters (ParameterHandler &prm)
override;
148 const Point<dim> &position)
const;
161 std::array<std::pair<double, unsigned int>,2>
215 double diffusion_viscosity (
const double temperature,
216 const double adiabatic_temperature,
217 const double adiabatic_pressure,
218 const double grain_size,
219 const double second_strain_rate_invariant,
220 const unsigned int phase_index)
const;
233 double dislocation_viscosity (
const double temperature,
234 const double adiabatic_temperature,
235 const double adiabatic_pressure,
237 const unsigned int phase_index,
238 const double diffusion_viscosity,
239 const double viscosity_guess = 0)
const;
241 double density (
const double temperature,
242 const double pressure,
243 const std::vector<double> &compositional_fields,
244 const Point<dim> &position)
const;
247 const double pressure,
248 const std::vector<double> &compositional_fields,
249 const Point<dim> &position)
const;
252 const double pressure,
253 const std::vector<double> &compositional_fields,
254 const Point<dim> &position)
const;
257 const double pressure,
258 const std::vector<double> &compositional_fields,
259 const Point<dim> &position)
const;
264 double seismic_Vp (
const double temperature,
265 const double pressure,
266 const std::vector<double> &compositional_fields,
267 const Point<dim> &position)
const;
272 double seismic_Vs (
const double temperature,
273 const double pressure,
274 const std::vector<double> &compositional_fields,
275 const Point<dim> &position)
const;
325 } material_file_format;
332 std::vector<std::unique_ptr<MaterialModel::MaterialUtilities::Lookup::MaterialLookup>>
material_lookup;
std::vector< double > diffusion_activation_volume
Rheology::DruckerPrager< dim > drucker_prager_plasticity
double max_thermal_expansivity
std::vector< std::string > material_file_names
double reference_specific_heat
std::unique_ptr< ReactionModel::GrainSizeEvolution< dim > > grain_size_evolution
std::vector< double > diffusion_creep_exponent
double dislocation_viscosity_iteration_threshold
std::vector< double > dislocation_activation_volume
bool use_table_properties
std::vector< double > get_nth_output(const unsigned int idx) const override
void declare_parameters(ParameterHandler &prm)
std::vector< std::unique_ptr< MaterialModel::MaterialUtilities::Lookup::MaterialLookup > > material_lookup
Rheology::DruckerPragerParameters drucker_prager_parameters
DislocationViscosityOutputs(const unsigned int n_points)
std::vector< double > diffusion_creep_grain_size_exponent
std::vector< double > diffusion_creep_prefactor
std::vector< double > dislocation_activation_energy
double reference_compressibility
unsigned int dislocation_viscosity_iteration_number
bool use_adiabatic_pressure_for_yielding
std::vector< double > dislocation_creep_exponent
std::vector< double > dislocation_viscosities
std::vector< double > diffusion_viscosities
std::unique_ptr< FEPointEvaluation< 1, dim > > temperature_evaluator
std::vector< double > diffusion_activation_energy
bool enable_drucker_prager_rheology
unsigned int n_material_data
double max_temperature_dependence_of_eta
bool use_bilinear_interpolation
unsigned int max_latent_heat_substeps
std::string datadirectory
double min_thermal_expansivity
double minimum_grain_size
unsigned int n_phase_transitions
std::vector< std::string > derivatives_file_names
std::unique_ptr< FEPointEvaluation< 1, dim > > pressure_evaluator
std::shared_ptr< MaterialUtilities::PhaseFunction< dim > > phase_function
std::vector< double > dislocation_creep_prefactor