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
53 std::vector<double> get_nth_output(
const unsigned int idx)
const override;
112 bool is_compressible ()
const override;
135 parse_parameters (ParameterHandler &prm)
override;
150 const Point<dim> &position)
const;
163 std::array<std::pair<double, unsigned int>,2>
217 double diffusion_viscosity (
const double temperature,
218 const double adiabatic_temperature,
219 const double adiabatic_pressure,
220 const double grain_size,
221 const double second_strain_rate_invariant,
222 const unsigned int phase_index)
const;
235 double dislocation_viscosity (
const double temperature,
236 const double adiabatic_temperature,
237 const double adiabatic_pressure,
239 const unsigned int phase_index,
240 const double diffusion_viscosity,
241 const double viscosity_guess = 0)
const;
243 double density (
const double temperature,
244 const double pressure,
245 const std::vector<double> &compositional_fields,
246 const Point<dim> &position)
const;
249 const double pressure,
250 const std::vector<double> &compositional_fields,
251 const Point<dim> &position)
const;
254 const double pressure,
255 const std::vector<double> &compositional_fields,
256 const Point<dim> &position)
const;
259 const double pressure,
260 const std::vector<double> &compositional_fields,
261 const Point<dim> &position)
const;
266 double seismic_Vp (
const double temperature,
267 const double pressure,
268 const std::vector<double> &compositional_fields,
269 const Point<dim> &position)
const;
274 double seismic_Vs (
const double temperature,
275 const double pressure,
276 const std::vector<double> &compositional_fields,
277 const Point<dim> &position)
const;
327 } material_file_format;
334 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
void declare_parameters(ParameterHandler &prm)
std::vector< std::unique_ptr< MaterialModel::MaterialUtilities::Lookup::MaterialLookup > > material_lookup
Rheology::DruckerPragerParameters drucker_prager_parameters
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