libMesh
Public Member Functions | Public Attributes | List of all members
LaplaceQoI Class Reference

#include <L-qoi.h>

Inheritance diagram for LaplaceQoI:
[legend]

Public Member Functions

 LaplaceQoI ()
 
virtual ~LaplaceQoI ()
 
virtual void init_qoi (std::vector< Number > &sys_qoi)
 
virtual void init_context (DiffContext &context)
 Prepares the result of a build_context() call for use. More...
 
virtual void postprocess ()
 
virtual void element_qoi_derivative (DiffContext &context, const QoISet &qois)
 Does any work that needs to be done on elem in a quantity of interest derivative assembly loop, outputting to elem_qoi_derivative. More...
 
virtual void element_qoi (DiffContext &context, const QoISet &qois)
 Does any work that needs to be done on elem in a quantity of interest assembly loop, outputting to elem_qoi. More...
 
virtual std::unique_ptr< DifferentiableQoIclone ()
 Copy of this object. More...
 
virtual void init_qoi (std::vector< Number > &)
 Initialize system qoi. More...
 
virtual void clear_qoi ()
 Clear all the data structures associated with the QoI. More...
 
virtual void side_qoi (DiffContext &, const QoISet &)
 Does any work that needs to be done on side of elem in a quantity of interest assembly loop, outputting to elem_qoi. More...
 
virtual void side_qoi_derivative (DiffContext &, const QoISet &)
 Does any work that needs to be done on side of elem in a quantity of interest derivative assembly loop, outputting to elem_qoi_derivative. More...
 
virtual void thread_join (std::vector< Number > &qoi, const std::vector< Number > &other_qoi, const QoISet &qoi_indices)
 Method to combine thread-local qois. More...
 
virtual void parallel_op (const Parallel::Communicator &communicator, std::vector< Number > &sys_qoi, std::vector< Number > &local_qoi, const QoISet &qoi_indices)
 Method to populate system qoi data structure with process-local qoi. More...
 
virtual void finalize_derivative (NumericVector< Number > &derivatives, std::size_t qoi_index)
 Method to finalize qoi derivatives which require more than just a simple sum of element contributions. More...
 

Public Attributes

bool assemble_qoi_sides
 If assemble_qoi_sides is true (it is false by default), the assembly loop for a quantity of interest or its derivatives will loop over domain boundary sides. More...
 
bool assemble_qoi_internal_sides
 If assemble_qoi_internal_sides is true (it is false by default), the assembly loop for a quantity of interest or its derivatives will loop over element sides which do not fall on domain boundaries. More...
 
bool assemble_qoi_elements
 If assemble_qoi_elements is false (it is true by default), the assembly loop for a quantity of interest or its derivatives will skip computing on mesh elements, and will only compute on mesh sides. More...
 

Detailed Description

Definition at line 17 of file L-qoi.h.

Constructor & Destructor Documentation

◆ LaplaceQoI()

LaplaceQoI::LaplaceQoI ( )
inline

Definition at line 20 of file L-qoi.h.

20 {}

◆ ~LaplaceQoI()

virtual LaplaceQoI::~LaplaceQoI ( )
inlinevirtual

Definition at line 21 of file L-qoi.h.

21 {}

Member Function Documentation

◆ clear_qoi()

virtual void libMesh::DifferentiableQoI::clear_qoi ( )
inlinevirtualinherited

Clear all the data structures associated with the QoI.

Definition at line 77 of file diff_qoi.h.

77 {}

Referenced by libMesh::DifferentiableSystem::clear().

◆ clone()

virtual std::unique_ptr<DifferentiableQoI> LaplaceQoI::clone ( )
inlinevirtual

Copy of this object.

User should override to copy any needed state.

Implements libMesh::DifferentiableQoI.

Definition at line 34 of file L-qoi.h.

35  {
36  return libmesh_make_unique<LaplaceQoI>(*this);
37  }

◆ element_qoi()

void LaplaceQoI::element_qoi ( DiffContext ,
const QoISet  
)
virtual

Does any work that needs to be done on elem in a quantity of interest assembly loop, outputting to elem_qoi.

Only qois included in the supplied QoISet need to be assembled.

Reimplemented from libMesh::DifferentiableQoI.

Definition at line 27 of file L-qoi.C.

29 {
30  FEMContext & c = cast_ref<FEMContext &>(context);
31 
32  FEBase * elem_fe = nullptr;
33  c.get_element_fe(0, elem_fe);
34 
35  // Element Jacobian * quadrature weights for interior integration
36  const std::vector<Real> & JxW = elem_fe->get_JxW();
37 
38  const std::vector<Point> & xyz = elem_fe->get_xyz();
39 
40  unsigned int n_qpoints = c.get_element_qrule().n_points();
41 
42  Number dQoI_0 = 0.;
43 
44  // Loop over quadrature points
45  for (unsigned int qp = 0; qp != n_qpoints; qp++)
46  {
47  // Get co-ordinate locations of the current quadrature point
48  const Real xf = xyz[qp](0);
49  const Real yf = xyz[qp](1);
50 
51  // If in the sub-domain omega, add the contribution to the integral R
52  if (std::abs(xf - 0.875) <= 0.125 && std::abs(yf - 0.125) <= 0.125)
53  {
54  // Get the solution value at the quadrature point
55  Number T = c.interior_value(0, qp);
56 
57  // Update the elemental increment dR for each qp
58  dQoI_0 += JxW[qp] * T;
59  }
60  }
61 
62  // Update the computed value of the global functional R, by adding the contribution from this element
63  c.get_qois()[0] = c.get_qois()[0] + dQoI_0;
64 }

References std::abs(), libMesh::FEMContext::get_element_fe(), libMesh::FEMContext::get_element_qrule(), libMesh::FEAbstract::get_JxW(), libMesh::DiffContext::get_qois(), libMesh::FEAbstract::get_xyz(), libMesh::FEMContext::interior_value(), libMesh::QBase::n_points(), and libMesh::Real.

◆ element_qoi_derivative()

void LaplaceQoI::element_qoi_derivative ( DiffContext ,
const QoISet  
)
virtual

Does any work that needs to be done on elem in a quantity of interest derivative assembly loop, outputting to elem_qoi_derivative.

Only qois included in the supplied QoISet need their derivatives assembled.

Reimplemented from libMesh::DifferentiableQoI.

Definition at line 68 of file L-qoi.C.

70 {
71  FEMContext & c = cast_ref<FEMContext &>(context);
72 
73  // First we get some references to cell-specific data that
74  // will be used to assemble the linear system.
75  FEBase * elem_fe = nullptr;
76  c.get_element_fe(0, elem_fe);
77 
78  // Element Jacobian * quadrature weights for interior integration
79  const std::vector<Real> & JxW = elem_fe->get_JxW();
80 
81  // The basis functions for the element
82  const std::vector<std::vector<Real>> & phi = elem_fe->get_phi();
83 
84  // The element quadrature points
85  const std::vector<Point > & q_point = elem_fe->get_xyz();
86 
87  // The number of local degrees of freedom in each variable
88  const unsigned int n_T_dofs = c.n_dof_indices(0);
89  unsigned int n_qpoints = c.get_element_qrule().n_points();
90 
91  // Fill the QoI RHS corresponding to this QoI. Since this is the 0th QoI
92  // we fill in the [0][i] subderivatives, i corresponding to the variable index.
93  // Our system has only one variable, so we only have to fill the [0][0] subderivative
95 
96  // Loop over the qps
97  for (unsigned int qp=0; qp != n_qpoints; qp++)
98  {
99  const Real x = q_point[qp](0);
100  const Real y = q_point[qp](1);
101 
102  // If in the sub-domain over which QoI 0 is supported, add contributions
103  // to the adjoint rhs
104  if (std::abs(x - 0.875) <= 0.125 && std::abs(y - 0.125) <= 0.125)
105  for (unsigned int i=0; i != n_T_dofs; i++)
106  Q(i) += JxW[qp]*phi[i][qp];
107  } // end of the quadrature point qp-loop
108 }

References std::abs(), libMesh::FEMContext::get_element_fe(), libMesh::FEMContext::get_element_qrule(), libMesh::FEAbstract::get_JxW(), libMesh::FEGenericBase< OutputType >::get_phi(), libMesh::DiffContext::get_qoi_derivatives(), libMesh::FEAbstract::get_xyz(), libMesh::DiffContext::n_dof_indices(), libMesh::QBase::n_points(), and libMesh::Real.

◆ finalize_derivative()

void libMesh::DifferentiableQoI::finalize_derivative ( NumericVector< Number > &  derivatives,
std::size_t  qoi_index 
)
virtualinherited

Method to finalize qoi derivatives which require more than just a simple sum of element contributions.

Definition at line 53 of file diff_qoi.C.

54 {
55  // by default, do nothing
56 }

Referenced by libMesh::FEMSystem::assemble_qoi_derivative().

◆ init_context()

void LaplaceQoI::init_context ( DiffContext )
virtual

Prepares the result of a build_context() call for use.

Most FEMSystem-based problems will need to reimplement this in order to call FE::get_*() as their particular QoI requires.

Reimplemented from libMesh::DifferentiableQoI.

Definition at line 11 of file L-qoi.C.

12 {
13  FEMContext & c = cast_ref<FEMContext &>(context);
14 
15  // Now make sure we have requested all the data
16  // we need to build the linear system.
17  FEBase * elem_fe = nullptr;
18  c.get_element_fe(0, elem_fe);
19  elem_fe->get_JxW();
20  elem_fe->get_phi();
21  elem_fe->get_xyz();
22 }

References libMesh::FEMContext::get_element_fe(), libMesh::FEAbstract::get_JxW(), libMesh::FEGenericBase< OutputType >::get_phi(), and libMesh::FEAbstract::get_xyz().

◆ init_qoi() [1/2]

virtual void libMesh::DifferentiableQoI::init_qoi ( std::vector< Number > &  )
inlinevirtualinherited

Initialize system qoi.

By default, does nothing in order to maintain backward compatibility for FEMSystem applications that control qoi.

Definition at line 71 of file diff_qoi.h.

71 {}

Referenced by libMesh::DifferentiableSystem::attach_qoi().

◆ init_qoi() [2/2]

void LaplaceQoI::init_qoi ( std::vector< Number > &  sys_qoi)
virtual

Definition at line 5 of file L-qoi.C.

6 {
7  // Only 1 qoi to worry about
8  sys_qoi.resize(1);
9 }

◆ parallel_op()

void libMesh::DifferentiableQoI::parallel_op ( const Parallel::Communicator &  communicator,
std::vector< Number > &  sys_qoi,
std::vector< Number > &  local_qoi,
const QoISet qoi_indices 
)
virtualinherited

Method to populate system qoi data structure with process-local qoi.

By default, simply sums process qois into system qoi.

Definition at line 41 of file diff_qoi.C.

45 {
46  // Sum everything into local_qoi
47  communicator.sum(local_qoi);
48 
49  // Now put into system qoi
50  sys_qoi = local_qoi;
51 }

Referenced by libMesh::FEMSystem::assemble_qoi().

◆ postprocess()

virtual void LaplaceQoI::postprocess ( void  )
inlinevirtual

Definition at line 28 of file L-qoi.h.

28 {}

◆ side_qoi()

virtual void libMesh::DifferentiableQoI::side_qoi ( DiffContext ,
const QoISet  
)
inlinevirtualinherited

Does any work that needs to be done on side of elem in a quantity of interest assembly loop, outputting to elem_qoi.

Only qois included in the supplied QoISet need to be assembled.

Reimplemented in CoupledSystemQoI.

Definition at line 133 of file diff_qoi.h.

135  {}

◆ side_qoi_derivative()

virtual void libMesh::DifferentiableQoI::side_qoi_derivative ( DiffContext ,
const QoISet  
)
inlinevirtualinherited

Does any work that needs to be done on side of elem in a quantity of interest derivative assembly loop, outputting to elem_qoi_derivative.

Only qois included in the supplied QoISet need their derivatives assembled.

Reimplemented in LaplaceSystem, LaplaceSystem, and CoupledSystemQoI.

Definition at line 145 of file diff_qoi.h.

147  {}

◆ thread_join()

void libMesh::DifferentiableQoI::thread_join ( std::vector< Number > &  qoi,
const std::vector< Number > &  other_qoi,
const QoISet qoi_indices 
)
virtualinherited

Method to combine thread-local qois.

By default, simply sums thread qois.

Definition at line 33 of file diff_qoi.C.

36 {
37  for (auto i : index_range(qoi))
38  qoi[i] += other_qoi[i];
39 }

References libMesh::index_range().

Member Data Documentation

◆ assemble_qoi_elements

bool libMesh::DifferentiableQoI::assemble_qoi_elements
inherited

If assemble_qoi_elements is false (it is true by default), the assembly loop for a quantity of interest or its derivatives will skip computing on mesh elements, and will only compute on mesh sides.

Definition at line 101 of file diff_qoi.h.

◆ assemble_qoi_internal_sides

bool libMesh::DifferentiableQoI::assemble_qoi_internal_sides
inherited

If assemble_qoi_internal_sides is true (it is false by default), the assembly loop for a quantity of interest or its derivatives will loop over element sides which do not fall on domain boundaries.

Definition at line 93 of file diff_qoi.h.

◆ assemble_qoi_sides

bool libMesh::DifferentiableQoI::assemble_qoi_sides
inherited

If assemble_qoi_sides is true (it is false by default), the assembly loop for a quantity of interest or its derivatives will loop over domain boundary sides.

To add domain interior sides, also set assemble_qoi_internal_sides to true.

Definition at line 85 of file diff_qoi.h.

Referenced by main().


The documentation for this class was generated from the following files:
libMesh::Number
Real Number
Definition: libmesh_common.h:195
libMesh::FEMContext::get_element_qrule
const QBase & get_element_qrule() const
Accessor for element interior quadrature rule for the dimension of the current _elem.
Definition: fem_context.h:790
libMesh::FEAbstract::get_xyz
const std::vector< Point > & get_xyz() const
Definition: fe_abstract.h:237
libMesh::QBase::n_points
unsigned int n_points() const
Definition: quadrature.h:126
libMesh::index_range
IntRange< std::size_t > index_range(const std::vector< T > &vec)
Helper function that returns an IntRange<std::size_t> representing all the indices of the passed-in v...
Definition: int_range.h:106
libMesh::FEGenericBase
This class forms the foundation from which generic finite elements may be derived.
Definition: exact_error_estimator.h:39
libMesh::FEAbstract::get_JxW
const std::vector< Real > & get_JxW() const
Definition: fe_abstract.h:244
libMesh::DiffContext::get_qois
const std::vector< Number > & get_qois() const
Const accessor for QoI vector.
Definition: diff_context.h:319
std::abs
MetaPhysicL::DualNumber< T, D > abs(const MetaPhysicL::DualNumber< T, D > &in)
libMesh::DiffContext::get_qoi_derivatives
const std::vector< DenseVector< Number > > & get_qoi_derivatives() const
Const accessor for QoI derivatives.
Definition: diff_context.h:331
libMesh::DiffContext::n_dof_indices
unsigned int n_dof_indices() const
Total number of dof indices on the element.
Definition: diff_context.h:399
libMesh::DenseSubVector< Number >
libMesh::FEMContext::get_element_fe
void get_element_fe(unsigned int var, FEGenericBase< OutputShape > *&fe) const
Accessor for interior finite element object for variable var for the largest dimension in the mesh.
Definition: fem_context.h:275
libMesh::FEGenericBase::get_phi
const std::vector< std::vector< OutputShape > > & get_phi() const
Definition: fe_base.h:206
libMesh::Real
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
Definition: libmesh_common.h:121
libMesh::FEMContext::interior_value
Number interior_value(unsigned int var, unsigned int qp) const
Definition: fem_context.C:371
libMesh::FEMContext
This class provides all data required for a physics package (e.g.
Definition: fem_context.h:62