31#ifndef NONLINEARDRUCKERPRAGER_H
32#define NONLINEARDRUCKERPRAGER_H
46 static constexpr unsigned max_iteration = 20;
47 static const mat unit_dev_tensor;
48 static const mat unit_x_unit;
52 const double double_shear = 2. * shear;
56 const double factor_c = sqrt(2.) * shear * bulk;
61 [[nodiscard]]
virtual double compute_c(
double)
const = 0;
62 [[nodiscard]]
virtual double compute_dc(
double)
const = 0;
74 int initialize(
const shared_ptr<DomainBase>&)
override;
84 void print()
override;
ParameterType
Definition: ParameterType.h:21
The Material3D class.
Definition: Material3D.h:37
The NonlinearDruckerPrager class.
Definition: NonlinearDruckerPrager.h:45
double get_parameter(ParameterType) const override
Definition: NonlinearDruckerPrager.cpp:36
int commit_status() override
Definition: NonlinearDruckerPrager.cpp:128
void print() override
Definition: NonlinearDruckerPrager.cpp:144
int update_trial_status(const vec &) override
Definition: NonlinearDruckerPrager.cpp:45
int reset_status() override
Definition: NonlinearDruckerPrager.cpp:136
int initialize(const shared_ptr< DomainBase > &) override
Definition: NonlinearDruckerPrager.cpp:28
int clear_status() override
Definition: NonlinearDruckerPrager.cpp:120
std::enable_if_t<!std::numeric_limits< T >::is_integer, bool > approx_equal(T x, T y, int ulp=2)
Definition: utility.h:58
Definition: NonlinearDruckerPrager.h:37
const double eta_yield
Definition: NonlinearDruckerPrager.h:40
const double elastic_modulus
Definition: NonlinearDruckerPrager.h:38
const double poissons_ratio
Definition: NonlinearDruckerPrager.h:39
const double xi
Definition: NonlinearDruckerPrager.h:42
const double eta_flow
Definition: NonlinearDruckerPrager.h:41