Definition at line 37 of file level_set_nonlinear_implicit_assembly.h.
#include <level_set_nonlinear_implicit_assembly.h>
Public Member Functions | |
LevelSetNonlinearImplicitAssembly (bool enable_dof_handler) | |
constructor associates this assembly object with the system More... | |
virtual | ~LevelSetNonlinearImplicitAssembly () |
destructor resets the association of this assembly object with the system More... | |
virtual void | calculate_output (const libMesh::NumericVector< Real > &X, bool if_localize_sol, MAST::OutputAssemblyElemOperations &output) |
calculates the value of quantity . More... | |
virtual void | calculate_output_derivative (const libMesh::NumericVector< Real > &X, bool if_localize_sol, MAST::OutputAssemblyElemOperations &output, libMesh::NumericVector< Real > &dq_dX) |
calculates More... | |
virtual void | calculate_output_direct_sensitivity (const libMesh::NumericVector< Real > &X, bool if_localize_sol, const libMesh::NumericVector< Real > *dXdp, bool if_localize_sol_sens, const MAST::FunctionBase &p, MAST::OutputAssemblyElemOperations &output) |
evaluates the sensitivity of the outputs in the attached discipline with respect to the parametrs in params . More... | |
virtual void | clear_level_set_function () |
clears association with level set function More... | |
virtual void | clear_level_set_velocity_function () |
clears the velocity function More... | |
MAST::LevelSetInterfaceDofHandler & | get_dof_handler () |
MAST::LevelSetIntersection & | get_intersection () |
bool | if_use_dof_handler () const |
virtual void | residual_and_jacobian (const libMesh::NumericVector< Real > &X, libMesh::NumericVector< Real > *R, libMesh::SparseMatrix< Real > *J, libMesh::NonlinearImplicitSystem &S) |
function that assembles the matrices and vectors quantities for nonlinear solution More... | |
virtual bool | sensitivity_assemble (const libMesh::NumericVector< Real > &X, bool if_localize_sol, const MAST::FunctionBase &f, libMesh::NumericVector< Real > &sensitivity_rhs, bool close_vector=true) |
Assembly function. More... | |
void | set_evaluate_output_on_negative_phi (bool f) |
sets the flag on whether or not to evaluate the output on negative level set function More... | |
virtual void | set_indicator_function (MAST::FieldFunction< RealVectorX > &indicator) |
attaches indicator function to this . More... | |
virtual void | set_level_set_function (MAST::FieldFunction< Real > &level_set, const MAST::FilterBase &filter) |
attaches level set function to this More... | |
virtual void | set_level_set_velocity_function (MAST::FieldFunction< RealVectorX > &velocity) |
the velocity function used to calculate topology sensitivity More... | |
Public Member Functions inherited from MAST::NonlinearImplicitAssembly | |
NonlinearImplicitAssembly () | |
constructor associates this assembly object with the system More... | |
virtual | ~NonlinearImplicitAssembly () |
destructor resets the association of this assembly object with the system More... | |
Real | first_iter_res_l2_norm () const |
virtual void | linearized_jacobian_solution_product (const libMesh::NumericVector< Real > &X, const libMesh::NumericVector< Real > &dX, libMesh::NumericVector< Real > &JdX, libMesh::NonlinearImplicitSystem &S) |
calculates the product of the Jacobian and a perturbation in solution vector . More... | |
Real | res_l2_norm () const |
L2 norm of the last-assembled residual. More... | |
void | reset_residual_norm_history () |
reset L2 norm of the last-assembled residual More... | |
virtual void | second_derivative_dot_solution_assembly (const libMesh::NumericVector< Real > &X, bool if_localize_sol, const libMesh::NumericVector< Real > &dX, bool if_localize_sol_sens, libMesh::SparseMatrix< Real > &d_JdX_dX, libMesh::NonlinearImplicitSystem &S) |
calculates . More... | |
void | set_post_assembly_operation (MAST::NonlinearImplicitAssembly::PostAssemblyOperation &post) |
sets the PostAssemblyOperation object for use after assembly. More... | |
Public Member Functions inherited from MAST::AssemblyBase | |
AssemblyBase () | |
constructor takes a reference to the discipline that provides the boundary conditions, volume loads, properties, etc. More... | |
virtual | ~AssemblyBase () |
virtual destructor More... | |
void | attach_elem_parameter_dependence_object (MAST::AssemblyBase::ElemParameterDependence &dep) |
This object, if provided by user, will be used to reduce unnecessary computations in sensitivity analysis assembly operations. More... | |
void | attach_solution_function (MAST::MeshFieldFunction &f) |
tells the assembly object that this function is will need to be initialized before each residual evaluation More... | |
std::unique_ptr< libMesh::NumericVector< Real > > | build_localized_vector (const libMesh::System &sys, const libMesh::NumericVector< Real > &global) const |
localizes the parallel vector so that the local copy stores all values necessary for calculation of the element quantities More... | |
virtual Real | calculate_output_adjoint_sensitivity (const libMesh::NumericVector< Real > &X, bool if_localize_sol, const libMesh::NumericVector< Real > &adj_sol, const MAST::FunctionBase &p, MAST::AssemblyElemOperations &elem_ops, MAST::OutputAssemblyElemOperations &output, const bool include_partial_sens=true) |
Evaluates the total sensitivity of output wrt p using the adjoint solution provided in adj_sol for a linearization about solution X . More... | |
virtual void | calculate_output_adjoint_sensitivity_multiple_parameters_no_direct (const libMesh::NumericVector< Real > &X, bool if_localize_sol, const libMesh::NumericVector< Real > &adj_sol, const std::vector< const MAST::FunctionBase *> &p_vec, MAST::AssemblyElemOperations &elem_ops, MAST::OutputAssemblyElemOperations &output, std::vector< Real > &sens) |
Evaluates the dot product between adj_sol and sensitivity of residual about X for multiple parameter_vectors p_vec and returns the results in sens . More... | |
virtual void | clear_discipline_and_system () |
clears association with a system to this discipline More... | |
virtual void | clear_elem_operation_object () |
clears the association of this object with the assembly element operation object. More... | |
void | clear_elem_parameter_dependence_object () |
void | clear_solver_monitor () |
clears the monitor object More... | |
void | detach_solution_function () |
removes the attachment of the solution function More... | |
const MAST::PhysicsDisciplineBase & | discipline () const |
MAST::PhysicsDisciplineBase & | discipline () |
MAST::AssemblyElemOperations & | get_elem_ops () |
MAST::AssemblyBase::SolverMonitor * | get_solver_monitor () |
virtual void | set_discipline_and_system (MAST::PhysicsDisciplineBase &discipline, MAST::SystemInitialization &system) |
attaches a system to this discipline More... | |
virtual void | set_elem_operation_object (MAST::AssemblyElemOperations &elem_ops) |
attaches a element operation to this object, and associated this with the element operation object. More... | |
void | set_solver_monitor (MAST::AssemblyBase::SolverMonitor &monitor) |
attaches the solver monitor, which is a user provided routine that is called each time More... | |
const MAST::NonlinearSystem & | system () const |
MAST::NonlinearSystem & | system () |
MAST::SystemInitialization & | system_init () |
Additional Inherited Members | |
Public Attributes inherited from MAST::AssemblyBase | |
bool | close_matrix |
flag to control the closing fo the Jacobian after assembly More... | |
std::set< unsigned int > | diagonal_elem_subdomain_id |
subdomain ids for which residuakl and Jacobian contributions will not be computed. More... | |
MAST::LevelSetNonlinearImplicitAssembly::LevelSetNonlinearImplicitAssembly | ( | bool | enable_dof_handler | ) |
constructor associates this assembly object with the system
Definition at line 47 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
destructor resets the association of this assembly object with the system
Definition at line 63 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
calculates the value of quantity .
Reimplemented from MAST::AssemblyBase.
Definition at line 772 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
calculates
Reimplemented from MAST::AssemblyBase.
Definition at line 935 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
evaluates the sensitivity of the outputs in the attached discipline with respect to the parametrs in params
.
The base solution should be provided in X
. If total sensitivity is desired, then dXdp
should contain the sensitivity of solution wrt the parameter p
, otherwise it can be set to nullptr. If dXdp
is nullptr, the calculated sensitivity will be the partial derivarive of output
wrt p
.
Reimplemented from MAST::AssemblyBase.
Definition at line 1167 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
clears association with level set function
Definition at line 137 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
clears the velocity function
Definition at line 171 of file level_set_nonlinear_implicit_assembly.cpp.
MAST::LevelSetInterfaceDofHandler & MAST::LevelSetNonlinearImplicitAssembly::get_dof_handler | ( | ) |
LevelSetInterfaceDofHandler
object Definition at line 94 of file level_set_nonlinear_implicit_assembly.cpp.
MAST::LevelSetIntersection & MAST::LevelSetNonlinearImplicitAssembly::get_intersection | ( | ) |
Definition at line 72 of file level_set_nonlinear_implicit_assembly.cpp.
bool MAST::LevelSetNonlinearImplicitAssembly::if_use_dof_handler | ( | ) | const |
Definition at line 88 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
function that assembles the matrices and vectors quantities for nonlinear solution
Reimplemented from MAST::NonlinearImplicitAssembly.
Definition at line 322 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
Assembly function.
This function will be called to assemble the RHS of the sensitivity equations (which is -1 times sensitivity of system residual) prior to a solve and must be provided by the user in a derived class. The method provides dR/dp for f
parameter.
If the routine is not able to provide sensitivity for this parameter, then it should return false, and the system will attempt to use finite differencing.
Reimplemented from MAST::NonlinearImplicitAssembly.
Definition at line 553 of file level_set_nonlinear_implicit_assembly.cpp.
void MAST::LevelSetNonlinearImplicitAssembly::set_evaluate_output_on_negative_phi | ( | bool | f | ) |
sets the flag on whether or not to evaluate the output on negative level set function
Definition at line 81 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
attaches indicator function to this
.
Definition at line 126 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
attaches level set function to this
Definition at line 104 of file level_set_nonlinear_implicit_assembly.cpp.
|
virtual |
the velocity function used to calculate topology sensitivity
Definition at line 158 of file level_set_nonlinear_implicit_assembly.cpp.
|
protected |
Definition at line 187 of file level_set_nonlinear_implicit_assembly.h.
|
protected |
Definition at line 177 of file level_set_nonlinear_implicit_assembly.h.
|
protected |
Definition at line 179 of file level_set_nonlinear_implicit_assembly.h.
|
protected |
Definition at line 193 of file level_set_nonlinear_implicit_assembly.h.
|
protected |
Definition at line 183 of file level_set_nonlinear_implicit_assembly.h.
|
protected |
Definition at line 185 of file level_set_nonlinear_implicit_assembly.h.
|
protected |
Definition at line 181 of file level_set_nonlinear_implicit_assembly.h.
|
protected |
Definition at line 191 of file level_set_nonlinear_implicit_assembly.h.
|
protected |
Definition at line 189 of file level_set_nonlinear_implicit_assembly.h.