suanPan
Loading...
Searching...
No Matches
SectionShell.h
Go to the documentation of this file.
1/*******************************************************************************
2 * Copyright (C) 2017-2025 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 ******************************************************************************/
28#ifndef SECTIONSHELL_H
29#define SECTIONSHELL_H
30
31#include <Domain/Tag.h>
32
33enum class OutputType;
34
35class DomainBase;
36
64
65class SectionShell : protected SectionShellData, public CopiableTag {
66 const bool symmetric = false;
67 const bool initialized = false;
68
69public:
70 explicit SectionShell(
71 unsigned = 0, // section tag
72 unsigned = 0, // material tag
73 vec&& = {0., 0.} // eccentricity
74 );
75
76 virtual int initialize(const shared_ptr<DomainBase>&) = 0;
77
78 void set_initialized(bool) const;
79 void set_symmetric(bool) const;
80 [[nodiscard]] bool is_initialized() const;
81 [[nodiscard]] bool is_symmetric() const;
82
83 void set_eccentricity(const vec&) const;
84 [[nodiscard]] const vec& get_eccentricity() const;
85
86 [[nodiscard]] virtual const vec& get_trial_membrane_strain() const;
87 [[nodiscard]] virtual const vec& get_trial_membrane_strain_rate() const;
88 [[nodiscard]] virtual const vec& get_trial_plate_strain() const;
89 [[nodiscard]] virtual const vec& get_trial_plate_strain_rate() const;
90 [[nodiscard]] virtual const vec& get_trial_membrane_stress() const;
91 [[nodiscard]] virtual const vec& get_trial_plate_stress() const;
92 [[nodiscard]] virtual const mat& get_trial_membrane_stiffness() const;
93 [[nodiscard]] virtual const mat& get_trial_plate_stiffness() const;
94
95 [[nodiscard]] virtual const vec& get_current_membrane_strain() const;
96 [[nodiscard]] virtual const vec& get_current_membrane_strain_rate() const;
97 [[nodiscard]] virtual const vec& get_current_plate_strain() const;
98 [[nodiscard]] virtual const vec& get_current_plate_strain_rate() const;
99 [[nodiscard]] virtual const vec& get_current_membrane_stress() const;
100 [[nodiscard]] virtual const vec& get_current_plate_stress() const;
101 [[nodiscard]] virtual const mat& get_current_membrane_stiffness() const;
102 [[nodiscard]] virtual const mat& get_current_plate_stiffness() const;
103
104 [[nodiscard]] virtual const mat& get_initial_membrane_stiffness() const;
105 [[nodiscard]] virtual const mat& get_initial_plate_stiffness() const;
106
107 virtual unique_ptr<SectionShell> get_copy() = 0;
108
109 int update_incre_status(double, double);
110 int update_incre_status(double, double, double, double);
111 int update_trial_status(double, double);
112 int update_trial_status(double, double, double, double);
113
114 virtual int update_incre_status(const vec&, const vec&);
115 virtual int update_incre_status(const vec&, const vec&, const vec&, const vec&);
116 virtual int update_trial_status(const vec&, const vec&);
117 virtual int update_trial_status(const vec&, const vec&, const vec&, const vec&);
118
119 virtual int clear_status() = 0;
120 virtual int commit_status() = 0;
121 virtual int reset_status() = 0;
122
123 virtual std::vector<vec> record(OutputType);
124};
125
126namespace suanpan {
127 unique_ptr<SectionShell> make_copy(const shared_ptr<SectionShell>&);
128 unique_ptr<SectionShell> make_copy(const unique_ptr<SectionShell>&);
129} // namespace suanpan
130
131#endif
132
OutputType
Definition OutputType.h:23
Definition Tag.h:66
The DomainBase class is a template.
Definition DomainBase.h:102
A SectionShell class.
Definition SectionShell.h:65
bool is_initialized() const
Definition SectionShell.cpp:30
void set_symmetric(bool) const
Definition SectionShell.cpp:28
virtual const vec & get_current_plate_stress() const
Definition SectionShell.cpp:64
int update_incre_status(double, double)
Definition SectionShell.cpp:74
virtual int reset_status()=0
virtual const vec & get_current_plate_strain() const
Definition SectionShell.cpp:58
bool is_symmetric() const
Definition SectionShell.cpp:32
virtual const vec & get_trial_membrane_strain() const
Definition SectionShell.cpp:38
const vec & get_eccentricity() const
Definition SectionShell.cpp:36
void set_initialized(bool) const
Definition SectionShell.cpp:26
virtual const mat & get_trial_membrane_stiffness() const
Definition SectionShell.cpp:50
virtual int clear_status()=0
virtual const vec & get_current_plate_strain_rate() const
Definition SectionShell.cpp:60
virtual const vec & get_trial_plate_strain() const
Definition SectionShell.cpp:42
virtual std::vector< vec > record(OutputType)
Definition SectionShell.cpp:106
virtual const mat & get_current_plate_stiffness() const
Definition SectionShell.cpp:68
int update_trial_status(double, double)
Definition SectionShell.cpp:84
virtual const vec & get_trial_membrane_strain_rate() const
Definition SectionShell.cpp:40
virtual int initialize(const shared_ptr< DomainBase > &)=0
virtual const vec & get_current_membrane_stress() const
Definition SectionShell.cpp:62
void set_eccentricity(const vec &) const
Definition SectionShell.cpp:34
virtual int commit_status()=0
virtual const vec & get_trial_plate_stress() const
Definition SectionShell.cpp:48
virtual const mat & get_current_membrane_stiffness() const
Definition SectionShell.cpp:66
virtual const mat & get_initial_membrane_stiffness() const
Definition SectionShell.cpp:70
virtual const mat & get_trial_plate_stiffness() const
Definition SectionShell.cpp:52
virtual const vec & get_trial_membrane_stress() const
Definition SectionShell.cpp:46
virtual const vec & get_trial_plate_strain_rate() const
Definition SectionShell.cpp:44
virtual const vec & get_current_membrane_strain_rate() const
Definition SectionShell.cpp:56
virtual const vec & get_current_membrane_strain() const
Definition SectionShell.cpp:54
virtual unique_ptr< SectionShell > get_copy()=0
virtual const mat & get_initial_plate_stiffness() const
Definition SectionShell.cpp:72
Definition SparseMatMAGMA.hpp:43
unique_ptr< Material > make_copy(const shared_ptr< Material > &)
Definition Material.cpp:371
Definition SectionShell.h:37
const unsigned material_tag
Definition SectionShell.h:38
vec trial_plate_strain
Definition SectionShell.h:44
vec trial_plate_stress
Definition SectionShell.h:54
mat initial_plate_stiffness
Definition SectionShell.h:60
vec current_plate_strain
Definition SectionShell.h:45
vec current_membrane_stress
Definition SectionShell.h:53
mat trial_plate_stiffness
Definition SectionShell.h:62
const vec eccentricity
Definition SectionShell.h:40
mat current_plate_stiffness
Definition SectionShell.h:61
vec trial_membrane_strain
Definition SectionShell.h:42
vec trial_membrane_strain_rate
Definition SectionShell.h:47
mat current_membrane_stiffness
Definition SectionShell.h:59
vec current_membrane_strain_rate
Definition SectionShell.h:48
vec current_membrane_strain
Definition SectionShell.h:43
vec current_plate_stress
Definition SectionShell.h:55
mat initial_membrane_stiffness
Definition SectionShell.h:57
vec trial_plate_strain_rate
Definition SectionShell.h:49
vec current_plate_strain_rate
Definition SectionShell.h:50
mat trial_membrane_stiffness
Definition SectionShell.h:58
vec trial_membrane_stress
Definition SectionShell.h:52