suanPan
ExpDP.h
Go to the documentation of this file.
1
/*******************************************************************************
2
* Copyright (C) 2017-2024 Theodore Chang
3
*
4
* This program is free software: you can redistribute it and/or modify
5
* it under the terms of the GNU General Public License as published by
6
* the Free Software Foundation, either version 3 of the License, or
7
* (at your option) any later version.
8
*
9
* This program is distributed in the hope that it will be useful,
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
* GNU General Public License for more details.
13
*
14
* You should have received a copy of the GNU General Public License
15
* along with this program. If not, see <http://www.gnu.org/licenses/>.
16
******************************************************************************/
32
#ifndef EXPDP_H
33
#define EXPDP_H
34
35
#include "
NonlinearDruckerPrager.h
"
36
37
struct
DataExpDP
{
38
const
double
cohesion
,
a
,
b
;
39
};
40
41
class
ExpDP
final :
protected
DataExpDP
,
public
NonlinearDruckerPrager
{
42
[[nodiscard]]
double
compute_c(
double
)
const override
;
43
[[nodiscard]]
double
compute_dc(
double
)
const override
;
44
45
public
:
46
ExpDP
(
47
unsigned
,
// tag
48
double
,
// elastic modulus
49
double
,
// poisson's ratio
50
double
,
// eta_yield
51
double
,
// eta_flow
52
double
,
// xi
53
double
,
// cohesion
54
double
,
// a
55
double
,
// b
56
double
= 0.
// density
57
);
58
59
unique_ptr<Material>
get_copy
()
override
;
60
61
void
print
()
override
;
62
};
63
64
#endif
65
NonlinearDruckerPrager.h
ExpDP
The ExpDP class.
Definition:
ExpDP.h:41
ExpDP::print
void print() override
Definition:
ExpDP.cpp:36
ExpDP::get_copy
unique_ptr< Material > get_copy() override
Definition:
ExpDP.cpp:34
ExpDP::ExpDP
ExpDP(unsigned, double, double, double, double, double, double, double, double, double=0.)
Definition:
ExpDP.cpp:30
NonlinearDruckerPrager
The NonlinearDruckerPrager class.
Definition:
NonlinearDruckerPrager.h:45
unique_ptr< Material >
DataExpDP
Definition:
ExpDP.h:37
DataExpDP::a
const double a
Definition:
ExpDP.h:38
DataExpDP::b
const double b
Definition:
ExpDP.h:38
DataExpDP::cohesion
const double cohesion
Definition:
ExpDP.h:38
Material
Material3D
DruckerPrager
ExpDP.h
Generated by
1.9.4