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.