34 #include "libmesh/nonlinear_solver.h" 35 #include "libmesh/numeric_vector.h" 36 #include "libmesh/sparse_matrix.h" 37 #include "libmesh/dof_map.h" 45 _intersection (nullptr),
120 libMesh::SparseMatrix<Real>* B) {
130 libMesh::SparseMatrix<Real>
138 std::unique_ptr<libMesh::NumericVector<Real> >
150 std::vector<libMesh::dof_id_type> dof_indices;
151 const libMesh::DofMap& dof_map = eigen_sys.get_dof_map();
154 libMesh::MeshBase::const_element_iterator el =
155 eigen_sys.get_mesh().active_local_elements_begin();
156 const libMesh::MeshBase::const_element_iterator end_el =
157 eigen_sys.get_mesh().active_local_elements_end();
162 for ( ; el != end_el; ++el) {
164 const libMesh::Elem* elem = *el;
167 eigen_sys.get_mesh().max_elem_id(),
168 eigen_sys.get_mesh().max_node_id());
170 dof_map.dof_indices (elem, dof_indices);
175 unsigned int ndofs = (
unsigned int)dof_indices.size();
178 mat_A.setZero(ndofs, ndofs);
179 mat_B.setZero(ndofs, ndofs);
183 for (
unsigned int i=0; i<dof_indices.size(); i++)
184 sol(i) = (*localized_solution)(dof_indices[i]);
214 dof_map.constrain_element_matrix(A, dof_indices);
215 dof_map.constrain_element_matrix(B, dof_indices);
217 matrix_A.add_matrix (A, dof_indices);
218 matrix_B.add_matrix (B, dof_indices);
236 libMesh::SparseMatrix<Real>* sensitivity_A,
237 libMesh::SparseMatrix<Real>* sensitivity_B) {
248 libMesh::SparseMatrix<Real>& matrix_A = *sensitivity_A;
249 libMesh::SparseMatrix<Real>& matrix_B = *sensitivity_B;
254 std::unique_ptr<libMesh::NumericVector<Real> >
256 localized_solution_sens;
274 std::vector<libMesh::dof_id_type> dof_indices;
275 const libMesh::DofMap& dof_map = eigen_sys.get_dof_map();
278 libMesh::MeshBase::const_element_iterator el =
279 eigen_sys.get_mesh().active_local_elements_begin();
280 const libMesh::MeshBase::const_element_iterator end_el =
281 eigen_sys.get_mesh().active_local_elements_end();
286 for ( ; el != end_el; ++el) {
288 const libMesh::Elem* elem = *el;
291 eigen_sys.get_mesh().max_elem_id(),
292 eigen_sys.get_mesh().max_node_id());
297 dof_map.dof_indices (elem, dof_indices);
300 unsigned int ndofs = (
unsigned int)dof_indices.size();
303 mat_A.setZero(ndofs, ndofs);
304 mat_B.setZero(ndofs, ndofs);
305 mat2_A.setZero(ndofs, ndofs);
306 mat2_B.setZero(ndofs, ndofs);
312 for (
unsigned int i=0; i<dof_indices.size(); i++) {
314 sol(i) = (*localized_solution)(dof_indices[i]);
315 dsol(i) = (*localized_solution_sens)(dof_indices[i]);
319 const std::vector<const libMesh::Elem *> &
322 std::vector<const libMesh::Elem*>::const_iterator
323 hi_sub_elem_it = elems_hi.begin(),
324 hi_sub_elem_end = elems_hi.end();
326 for (; hi_sub_elem_it != hi_sub_elem_end; hi_sub_elem_it++ ) {
328 const libMesh::Elem* sub_elem = *hi_sub_elem_it;
362 dof_map.constrain_element_matrix(A, dof_indices);
363 dof_map.constrain_element_matrix(B, dof_indices);
365 matrix_A.add_matrix (A, dof_indices);
366 matrix_B.add_matrix (B, dof_indices);
373 sensitivity_A->close();
374 sensitivity_B->close();
MAST::AssemblyElemOperations * _elem_ops
provides assembly elem operations for use by this class
MAST::NonlinearSystem & system()
const std::vector< const libMesh::Elem * > & get_sub_elems_positive_phi() const
bool if_elem_has_positive_phi_region() const
virtual void elem_topology_sensitivity_calculations(const MAST::FunctionBase &f, bool base_sol, RealMatrixX &mat_A, RealMatrixX &mat_B)=0
performs the element topology sensitivity calculations over elem.
MAST::FieldFunction< Real > * _level_set
libMesh::DenseMatrix< Real > DenseRealMatrix
This class implements a system for solution of nonlinear systems.
virtual void set_elem_solution_sensitivity(const RealVectorX &sol)
sets the element solution sensitivity
MAST::FieldFunction< RealVectorX > * _velocity
virtual void init(const libMesh::Elem &elem, const MAST::SystemInitialization &sys_init)
This method should not get called for this class.
virtual void elem_calculations(RealMatrixX &mat_A, RealMatrixX &mat_B)=0
performs the element calculations over elem, and returns the element matrices for the eigenproblem ...
virtual void set_elem_solution(const RealVectorX &sol)
sets the element solution
virtual void set_level_set_function(MAST::FieldFunction< Real > &level_set)
attaches level set function to this
void init(const MAST::FieldFunction< Real > &phi, const libMesh::Elem &e, const Real t, unsigned int max_elem_id, unsigned int max_node_id)
MAST::SystemInitialization * _system
System for which this assembly is performed.
virtual bool is_topology_parameter() const
MAST::PhysicsDisciplineBase * _discipline
PhysicsDisciplineBase object for which this class is assembling.
virtual void set_elem_data(unsigned int dim, const libMesh::Elem &ref_elem, MAST::GeomElem &elem) const =0
some analyses may want to set additional element data before initialization of the GeomElem...
virtual void clear_level_set_function()
clears association with level set function
Assembles the system of equations for an eigenproblem of type .
Matrix< Real, Dynamic, Dynamic > RealMatrixX
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 t...
const libMesh::NumericVector< Real > * _base_sol
base solution about which this eigenproblem is defined.
void copy(DenseRealMatrix &m1, const RealMatrixX &m2)
This class inherits from MAST::GeomElem and provides an interface to initialize FE objects on sub-ele...
Matrix< Real, Dynamic, 1 > RealVectorX
virtual void init(const MAST::GeomElem &elem)=0
initializes the object for calculation of element quantities for the specified elem.
virtual ~LevelSetEigenproblemAssembly()
destructor resets the association of this assembly object with the system
virtual void set_level_set_velocity_function(MAST::FieldFunction< RealVectorX > &velocity)
the velocity function used to calculate topology sensitivity
virtual void eigenproblem_assemble(libMesh::SparseMatrix< Real > *A, libMesh::SparseMatrix< Real > *B)
assembles the matrices for eigenproblem depending on the analysis type
This class acts as a wrapper around libMesh::Elem for the purpose of providing a uniform interface fo...
const libMesh::NumericVector< Real > * _base_sol_sensitivity
sensitivity of base solution may be needed for sensitivity analysis.
virtual void elem_sensitivity_calculations(const MAST::FunctionBase &f, bool base_sol, RealMatrixX &mat_A, RealMatrixX &mat_B)=0
performs the element sensitivity calculations over elem, and returns the element matrices for the eig...
virtual void clear_elem()
clears the element initialization
virtual void init(const libMesh::Elem &elem, const MAST::SystemInitialization &sys_init)
initialize the object for the specified reference elem.
virtual bool eigenproblem_sensitivity_assemble(const MAST::FunctionBase &f, libMesh::SparseMatrix< Real > *sensitivity_A, libMesh::SparseMatrix< Real > *sensitivity_B)
Assembly function.
LevelSetEigenproblemAssembly()
constructor associates this assembly object with the system
MAST::LevelSetIntersection * _intersection
void clear()
clears the data structures
MAST::LevelSetIntersection & get_intersection()
virtual void clear_level_set_velocity_function()
clears the velocity function