![]() |
ASPECT
|
Static Public Member Functions | |
static void | declare_parameters (ParameterHandler &prm) |
![]() | |
static void | get_composition_values_at_q_point (const std::vector< std::vector< double >> &composition_values, const unsigned int q, std::vector< double > &composition_values_at_q_point) |
Private Attributes | |
Rheology::DiffusionCreep< dim > | diffusion_creep |
Rheology::DislocationCreep< dim > | dislocation_creep |
double | min_strain_rate |
double | minimum_viscosity |
double | maximum_viscosity |
double | log_strain_rate_residual_threshold |
unsigned int | stress_max_iteration_number |
double | grain_size |
unsigned int | n_chemical_composition_fields |
MaterialUtilities::CompositionalAveragingOperation | viscosity_averaging |
A viscous rheology including diffusion and dislocation creep.
The effective viscosity is defined as the harmonic mean of the two effective viscosity functions describing diffusion and dislocation creep:
\[ v_\text{eff} = \left( \frac{1}{v_\text{eff}^\text{diff}} + \frac{1}{v_\text{eff}^\text{dis}} \right)^{-1} \]
where
\[ v_\text{eff}^\text{diff} = A_\text{diff}^{-1} \exp\left(\frac{E_\text{diff} + PV_\text{diff}}{RT}\right), \]
and
\[ v_\text{eff}^\text{dis} = A_\text{dis}^{\frac{-1}{n_\text{dis}}} \dot{\varepsilon}^{\frac{1-n}{n}} \exp\left(\frac{E_\text{diff} + PV_\text{diff}}{n_\text{dis}RT}\right) \]
where \(\dot{\varepsilon}\) is the second invariant of the strain rate tensor, \(A_i\) are prefactors where \(i\) corresponds to diffusion or dislocation creep, \(E_i\) are the activation energies, \(V_i\) are the activation volumes, \(\rho_m\) is the mantle density, \(R\) is the gas constant, \(T\) is temperature, and \(P\) is pressure.
Rheological parameters can be defined per-compositional field. For each material parameter the user supplies a comma delimited list of length N+1, where N is the number of compositional fields. The additional field corresponds to the value for background mantle. They should be ordered ``background, composition1, composition2...''
The individual output viscosities for each compositional field are averaged. The user can choose from a range of options for this viscosity averaging. If only one value is given for any of these parameters, all compositions are assigned the same value. The first value in the list is the value assigned to "background mantle" (regions where the sum of the compositional fields is < 1.0).
Definition at line 74 of file diffusion_dislocation.h.
aspect::MaterialModel::Rheology::DiffusionDislocation< dim >::DiffusionDislocation | ( | ) |
Constructor.
std::vector<double> aspect::MaterialModel::Rheology::DiffusionDislocation< dim >::calculate_isostrain_viscosities | ( | const double | pressure, |
const double | temperature, | ||
const SymmetricTensor< 2, dim > & | strain_rate | ||
) | const |
Calculate the viscosities for each compositional field assuming that each composition experiences the same strain rate.
double aspect::MaterialModel::Rheology::DiffusionDislocation< dim >::compute_viscosity | ( | const double | pressure, |
const double | temperature, | ||
const std::vector< double > & | volume_fractions, | ||
const SymmetricTensor< 2, dim > & | strain_rate | ||
) | const |
Compute the viscosity based on the composite viscous creep law, averaging over all compositional fields according to their volume fractions.
|
static |
void aspect::MaterialModel::Rheology::DiffusionDislocation< dim >::parse_parameters | ( | ParameterHandler & | prm | ) |
|
private |
Objects for computing viscous creep viscosities.
Definition at line 113 of file diffusion_dislocation.h.
|
private |
Definition at line 114 of file diffusion_dislocation.h.
|
private |
Defining a minimum strain rate stabilizes the viscosity calculation, which involves a division by the strain rate. Units: 1/s.
Definition at line 120 of file diffusion_dislocation.h.
|
private |
Definition at line 121 of file diffusion_dislocation.h.
|
private |
Definition at line 122 of file diffusion_dislocation.h.
|
private |
Definition at line 124 of file diffusion_dislocation.h.
|
private |
Definition at line 125 of file diffusion_dislocation.h.
|
private |
Definition at line 127 of file diffusion_dislocation.h.
|
private |
Definition at line 128 of file diffusion_dislocation.h.
|
private |
Definition at line 130 of file diffusion_dislocation.h.