|
| GroupPenaltyBC (unsigned, unsigned, uvec &&, uvec &&) |
|
| GroupPenaltyBC (unsigned, unsigned, uvec &&, char) |
|
int | initialize (const shared_ptr< DomainBase > &) override |
|
int | process (const shared_ptr< DomainBase > &) override |
| This method provides all necessary pieces of typical constraints/loads required, including additional blocks in original global stiffness, border matrix resistance of multiplier, external loads.
|
|
int | process_resistance (const shared_ptr< DomainBase > &) override |
| For some algorithms, the global stiffness is formed only once in each substep. After calling solver, the storage may contain factorization. It is not correct to modify it in those algorithms. This method should provide updated constraint/load resistance but must not touch global stiffness.
|
|
int | process (const shared_ptr< DomainBase > &) override |
| method to apply the BC to the system.
|
|
int | process_resistance (const shared_ptr< DomainBase > &) override |
| For some algorithms, the global stiffness is formed only once in each substep. After calling solver, the storage may contain factorization. It is not correct to modify it in those algorithms. This method should provide updated constraint/load resistance but must not touch global stiffness.
|
|
| PenaltyBC (unsigned, unsigned, uvec &&, uvec &&) |
| the constructor uses DoF vector.
|
|
| PenaltyBC (unsigned, unsigned, uvec &&, char) |
| the constructor uses predefined TYPE: "XSYMM", "YSYMM", "ZSYMM", "ENCASTRE", "PINNED".
|
|
| PenaltyBC (unsigned, unsigned, uvec &&, uvec &&) |
| the constructor uses DoF vector.
|
|
| PenaltyBC (unsigned, unsigned, uvec &&, char) |
| the constructor uses predefined TYPE: "XSYMM", "YSYMM", "ZSYMM", "ENCASTRE", "PINNED".
|
|
int | process (const shared_ptr< DomainBase > &) override |
| method to apply the PenaltyBC to the system.
|
|
int | process_resistance (const shared_ptr< DomainBase > &) override |
| For some algorithms, the global stiffness is formed only once in each substep. After calling solver, the storage may contain factorization. It is not correct to modify it in those algorithms. This method should provide updated constraint/load resistance but must not touch global stiffness.
|
|
| Constraint (unsigned, unsigned, unsigned, uvec &&, uvec &&, unsigned) |
|
| Constraint (const Constraint &)=delete |
|
| Constraint (Constraint &&)=delete |
|
Constraint & | operator= (const Constraint &)=delete |
|
Constraint & | operator= (Constraint &&)=delete |
|
| ~Constraint () override=default |
|
const sp_vec & | get_resistance () const |
|
const sp_mat & | get_stiffness () const |
|
const vec & | get_auxiliary_resistance () const |
|
const vec & | get_auxiliary_load () const |
|
const sp_mat & | get_auxiliary_stiffness () const |
|
void | set_multiplier_size (unsigned) |
| At the beginning of each sub-step, it is assumed that constraints are not active (constraining conditions are not satisfied). The process(const shared_ptr<DomainBase>&) checks the constraining conditions for each iteration, and activates the multiplier(s) if conditions are met. The activation will be valid for all subsequent iterations in the same sub-step to avoid numerical instability.
|
|
unsigned | get_multiplier_size () const |
|
| ConditionalModifier (unsigned, unsigned, unsigned, uvec &&, uvec &&) |
|
virtual int | initialize (const shared_ptr< DomainBase > &) |
|
virtual int | process (const shared_ptr< DomainBase > &)=0 |
| This method provides all necessary pieces of typical constraints/loads required, including additional blocks in original global stiffness, border matrix resistance of multiplier, external loads.
|
|
virtual int | process_resistance (const shared_ptr< DomainBase > &) |
| For some algorithms, the global stiffness is formed only once in each substep. After calling solver, the storage may contain factorization. It is not correct to modify it in those algorithms. This method should provide updated constraint/load resistance but must not touch global stiffness.
|
|
virtual void | stage (const shared_ptr< DomainBase > &) |
| Some algorithms needs to manually modify some variables after solving. Typical example is the predictor–corrector type algorithms. This method is called before committing trial status to perform necessary operations.
|
|
const uvec & | get_node_encoding () const |
|
const uvec & | get_dof_encoding () const |
|
void | set_initialized (bool) const |
|
bool | is_initialized () const |
|
void | set_start_step (unsigned) |
|
unsigned | get_start_step () const |
|
void | set_end_step (unsigned) |
|
unsigned | get_end_step () const |
|
void | set_connected (bool) const |
| Some constraints may modify global stiffness matrix so that it needs to be treated as an element which may affect bandwidth of banded storage. By calling this method, the RCM reordering algorithm will take this constraint into consideration. Make sure it is called in the constructor.
|
|
bool | is_connected () const |
|
bool | validate_step (const shared_ptr< DomainBase > &) const |
|
virtual void | update_status (const vec &) |
|
virtual void | commit_status () |
|
virtual void | clear_status () |
|
virtual void | reset_status () |
|
| Tag (unsigned=0) |
|
| Tag (const Tag &)=default |
|
| Tag (Tag &&)=default |
|
Tag & | operator= (const Tag &)=delete |
|
Tag & | operator= (Tag &&)=delete |
|
virtual | ~Tag ()=default |
|
void | set_tag (unsigned) const |
|
unsigned | get_tag () const |
|
void | enable () |
|
void | disable () |
|
void | guard () |
|
void | unguard () |
|
bool | is_active () const |
|
bool | is_guarded () const |
|
virtual void | print () |
|
A GroupPenaltyBC class handles boundary conditions.
The GroupPenaltyBC class is in charge of applying boundary conditions to the system. The GroupPenaltyBC class only takes care of homogeneous Dirichlet conditions. Non-homogeneous displacement boundary conditions are treated as Load so that can be solved iteratively. Others are handled by general constraint class such as MPC. The GroupPenaltyBC class stores the boundary condition category, type, node(s) and corresponding DoF(s). The Domain invokes process(const shared_ptr<Domain>&)
method to modify the global stiffness matrix.
- Author
- tlc
- Date
- 21/03/2020
- Version
- 0.1.0