Skip to content

Commit

Permalink
added elasticity to CompositeViscoPlastic
Browse files Browse the repository at this point in the history
  • Loading branch information
bobmyhill committed Aug 11, 2024
1 parent 798c579 commit 066becb
Show file tree
Hide file tree
Showing 12 changed files with 941 additions and 42 deletions.
4 changes: 4 additions & 0 deletions doc/modules/changes/20240726_myhill
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
New: The CompositeViscoPlastic rheology in ASPECT now
includes an implementation of elasticity.
<br>
(Bob Myhill, 2024/07/26)
117 changes: 113 additions & 4 deletions include/aspect/material_model/rheology/composite_visco_plastic.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
#include <aspect/material_model/rheology/dislocation_creep.h>
#include <aspect/material_model/rheology/peierls_creep.h>
#include <aspect/material_model/rheology/drucker_prager_power.h>
#include <aspect/material_model/rheology/elasticity.h>
#include <aspect/simulator_access.h>

namespace aspect
Expand Down Expand Up @@ -91,6 +92,24 @@ namespace aspect
parse_parameters (ParameterHandler &prm,
const std::unique_ptr<std::vector<unsigned int>> &expected_n_phases_per_composition = nullptr);

/**
* Compute the inverse of the scalar elastic viscosity
* obtained from the elasticity rheology. The required scalar shear modulus is
* calculated by harmonically averaging the individual component shear moduli
* weighted by the @p volume_fractions of the components.
*/
double
compute_inverse_kelvin_viscosity(const std::vector<double> &volume_fractions) const;

/**
* Compute the effective viscoelastic strain rate used to calculate the
* viscosity.
*/
SymmetricTensor<2, dim>
compute_effective_strain_rate(const SymmetricTensor<2, dim> &strain_rate,
const SymmetricTensor<2, dim> &elastic_stress,
const double inverse_kelvin_viscosity) const;

/**
* Compute the viscosity based on the composite viscous creep law.
* If @p n_phase_transitions_per_composition points to a vector of
Expand All @@ -103,7 +122,8 @@ namespace aspect
const double temperature,
const double grain_size,
const std::vector<double> &volume_fractions,
const SymmetricTensor<2,dim> &strain_rate,
const SymmetricTensor<2,dim> &effective_strain_rate,
const double inverse_kelvin_viscosity,
std::vector<double> &partial_strain_rates,
const std::vector<double> &phase_function_values = std::vector<double>(),
const std::vector<unsigned int> &n_phase_transitions_per_composition = std::vector<unsigned int>()) const;
Expand All @@ -122,7 +142,8 @@ namespace aspect
const double temperature,
const double grain_size,
const std::vector<double> &volume_fractions,
const SymmetricTensor<2,dim> &strain_rate,
const SymmetricTensor<2,dim> &effective_strain_rate,
const double inverse_kelvin_viscosity,
std::vector<double> &partial_strain_rates,
const std::vector<double> &phase_function_values = std::vector<double>(),
const std::vector<unsigned int> &n_phase_transitions_per_composition = std::vector<unsigned int>()) const;
Expand All @@ -135,6 +156,7 @@ namespace aspect
std::pair<double, double>
calculate_isostress_log_strain_rate_and_derivative(const std::vector<std::array<std::pair<double, double>, 4>> &logarithmic_strain_rates_and_stress_derivatives,
const double viscoplastic_stress,
const double inverse_kelvin_viscosity,
std::vector<double> &partial_strain_rates) const;

/**
Expand Down Expand Up @@ -185,6 +207,69 @@ namespace aspect
const double viscoplastic_stress,
std::vector<double> &partial_strain_rates) const;

/**
* Create the two additional material model output objects that contain the
* elastic shear moduli, elastic viscosity, ratio of computational to elastic timestep,
* and deviatoric stress of the current timestep and the reaction rates.
*/
/*
void
create_elastic_additional_outputs (MaterialModel::MaterialModelOutputs<dim> &out) const;
*/

/**
* Given the stress of the previous time step in the material model inputs @p in,
* the elastic shear moduli @p average_elastic_shear_moduli at each point,
* and the (viscous) viscosities given in the material model outputs object @p out,
* fill a material model outputs objects with the elastic force terms, viscoelastic
* strain rate and viscous dissipation.
*/
/*
void
fill_elastic_outputs (const MaterialModel::MaterialModelInputs<dim> &in,
const std::vector<double> &average_elastic_shear_moduli,
MaterialModel::MaterialModelOutputs<dim> &out) const;
*/

/**
* Given the stress of the previous time step in the material model inputs @p in,
* the elastic shear moduli @p average_elastic_shear_moduli at each point,
* and the (viscous) viscosities given in the material model outputs object @p out,
* fill a material model outputs (ElasticAdditionalOutputs) object with the
* average shear modulus, elastic viscosity, and the deviatoric stress of the current timestep.
*/
/*
void
fill_elastic_additional_outputs (const MaterialModel::MaterialModelInputs<dim> &in,
const std::vector<double> &average_elastic_shear_moduli,
MaterialModel::MaterialModelOutputs<dim> &out) const;
*/

/**
* Given the stress of the previous time step in the material model inputs @p in,
* the elastic shear moduli @p average_elastic_shear_moduli at each point,
* and the (viscous) viscosities given in the material model outputs object @p out,
* compute an update to the elastic stresses and use it to fill the reaction terms
* material model output property.
*/
void
fill_reaction_outputs (const MaterialModel::MaterialModelInputs<dim> &in,
const std::vector<double> &average_elastic_shear_moduli,
MaterialModel::MaterialModelOutputs<dim> &out) const;

/**
* Given the stress of the previous time step in the material model inputs @p in,
* the elastic shear moduli @p average_elastic_shear_moduli at each point,
* and the (viscous) viscosities given in the material model outputs object @p out,
* compute the update to the elastic stresses of the previous timestep and use it
* to fill the reaction rates material model output property.
*/
void
fill_reaction_rates (const MaterialModel::MaterialModelInputs<dim> &in,
const std::vector<double> &average_elastic_shear_moduli,
MaterialModel::MaterialModelOutputs<dim> &out) const;

private:
/**
* Enumeration for selecting which type of viscosity averaging to use.
*/
Expand All @@ -197,6 +282,7 @@ namespace aspect
bool use_dislocation_creep;
bool use_peierls_creep;
bool use_drucker_prager;
bool use_elasticity;

/**
* Vector storing which flow mechanisms are active.
Expand All @@ -209,16 +295,31 @@ namespace aspect
* which is arranged in parallel with the viscoplastic elements and
* therefore does not contribute to the total strain rate.
*/
static constexpr unsigned int n_decomposed_strain_rates = 5;
static constexpr unsigned int n_decomposed_strain_rates = 6;

/**
* The index of the hard damper in the decomposed strain rates.
* This is always the last element.
*/
static constexpr unsigned int damper_strain_rate_index = 5;
static constexpr unsigned int isostrain_damper_strain_rate_index = 4;

/**
* The index of the elastic element in the decomposed strain rates.
* This is always the penultimate element.
*/
static constexpr unsigned int elastic_strain_rate_index = 4;

/**
* Pointers to objects for computing deformation mechanism
* strain rates and effective viscosities.
*/
std::unique_ptr<Rheology::DiffusionCreep<dim>> diffusion_creep;
std::unique_ptr<Rheology::DiffusionCreep<dim>>
diffusion_creep;
std::unique_ptr<Rheology::DislocationCreep<dim>> dislocation_creep;
std::unique_ptr<Rheology::PeierlsCreep<dim>> peierls_creep;
std::unique_ptr<Rheology::DruckerPragerPower<dim>> drucker_prager;
std::unique_ptr<Rheology::Elasticity<dim>> elasticity;

/**
* The expected number of chemical compositional fields.
Expand All @@ -229,8 +330,14 @@ namespace aspect
* The maximum viscosity, imposed via an isoviscous damper
* in series with the composite viscoplastic element.
*/
double inverse_maximum_viscosity;
double maximum_viscosity;

/**
* The minimum viscosity, imposed via an isoviscous damper
* in parallel with the flow law components
*/
double minimum_viscosity;

/**
* The viscosity of an isoviscous damper placed in parallel
Expand Down Expand Up @@ -273,6 +380,8 @@ namespace aspect
* Useful number to aid in adding together exponentials.
*/
const double logmin = std::log(std::numeric_limits<double>::min());

static constexpr unsigned int n_independent_components = SymmetricTensor<2, dim>::n_independent_components;
};
}
}
Expand Down
6 changes: 6 additions & 0 deletions include/aspect/material_model/rheology/elasticity.h
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,12 @@ namespace aspect
const std::vector<double> &
get_elastic_shear_moduli () const;

/**
* Return the values of the damper viscosity used in the rheology model.
*/
double
get_damper_viscosity() const;

/**
* Calculates the effective elastic viscosity (this is the equivalent viscosity of
* a material which was unstressed at the end of the previous timestep).
Expand Down
Loading

0 comments on commit 066becb

Please sign in to comment.