MFEM  v4.3.0
Finite element discretization library
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Pages
Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
mfem::DiscreteAdaptTC Class Reference

#include <tmop.hpp>

Inheritance diagram for mfem::DiscreteAdaptTC:
[legend]
Collaboration diagram for mfem::DiscreteAdaptTC:
[legend]

Public Member Functions

 DiscreteAdaptTC (TargetType ttype)
 
virtual ~DiscreteAdaptTC ()
 
void ResetUpdateFlags ()
 Used in combination with the Update methods to avoid extra computations. More...
 
void UpdateTargetSpecification (const Vector &new_x, bool use_flag=false)
 
void UpdateTargetSpecification (Vector &new_x, Vector &IntData)
 
void UpdateTargetSpecificationAtNode (const FiniteElement &el, ElementTransformation &T, int nodenum, int idir, const Vector &IntData)
 
void RestoreTargetSpecificationAtNode (ElementTransformation &T, int nodenum)
 
void UpdateGradientTargetSpecification (const Vector &x, double dx, bool use_flag=false)
 
void UpdateHessianTargetSpecification (const Vector &x, double dx, bool use_flag=false)
 
void SetAdaptivityEvaluator (AdaptivityEvaluator *ae)
 
const VectorGetTspecPert1H ()
 
const VectorGetTspecPert2H ()
 
const VectorGetTspecPertMixH ()
 
virtual void ComputeElementTargets (int e_id, const FiniteElement &fe, const IntegrationRule &ir, const Vector &elfun, DenseTensor &Jtr) const
 Given an element and quadrature rule, computes ref->target transformation Jacobians for each quadrature point in the element. The physical positions of the element's nodes are given by elfun. Note that this function assumes that UpdateTargetSpecification() has been called with the position vector corresponding to elfun. More...
 
virtual void ComputeAllElementTargets (const FiniteElementSpace &fes, const IntegrationRule &ir, const Vector &xe, DenseTensor &Jtr) const
 Computes reference-to-target transformation Jacobians for all quadrature points in all elements. More...
 
virtual void ComputeElementTargetsGradient (const IntegrationRule &ir, const Vector &elfun, IsoparametricTransformation &Tpr, DenseTensor &dJtr) const
 
Target specification methods.

The following methods are used to specify geometric parameters of the targets when these parameters are given by discrete FE functions. Note that every GridFunction given to the Set methods must use a H1_FECollection of the same order. The number of components must correspond to the type of geometric parameter and dimension.

Parameters
[in]tspec_Input values of a geometric parameter. Note that the methods in this class support only functions that use H1_FECollection collection of the same order.
virtual void SetSerialDiscreteTargetSpec (const GridFunction &tspec_)
 
virtual void SetSerialDiscreteTargetSize (const GridFunction &tspec_)
 
virtual void SetSerialDiscreteTargetSkew (const GridFunction &tspec_)
 
virtual void SetSerialDiscreteTargetAspectRatio (const GridFunction &tspec_)
 
virtual void SetSerialDiscreteTargetOrientation (const GridFunction &tspec_)
 
virtual void SetParDiscreteTargetSpec (const ParGridFunction &tspec_)
 
virtual void SetParDiscreteTargetSize (const ParGridFunction &tspec_)
 
virtual void SetParDiscreteTargetSkew (const ParGridFunction &tspec_)
 
virtual void SetParDiscreteTargetAspectRatio (const ParGridFunction &tspec_)
 
virtual void SetParDiscreteTargetOrientation (const ParGridFunction &tspec_)
 
- Public Member Functions inherited from mfem::TargetConstructor
 TargetConstructor (TargetType ttype)
 Constructor for use in serial. More...
 
 TargetConstructor (TargetType ttype, MPI_Comm mpicomm)
 Constructor for use in parallel. More...
 
virtual ~TargetConstructor ()
 
void SetNodes (const GridFunction &n)
 Set the nodes to be used in the target-matrix construction. More...
 
const GridFunctionGetNodes () const
 Get the nodes to be used in the target-matrix construction. More...
 
void SetVolumeScale (double vol_scale)
 Used by target type IDEAL_SHAPE_EQUAL_SIZE. The default volume scale is 1. More...
 
TargetType GetTargetType () const
 
bool UsesPhysicalCoordinates () const
 Return true if the methods ComputeElementTargets(), ComputeAllElementTargets(), and ComputeElementTargetsGradient() use the physical node coordinates provided by the parameters 'elfun', or 'xe'. More...
 
virtual bool ContainsVolumeInfo () const
 Checks if the target matrices contain non-trivial size specification. More...
 

Protected Member Functions

void SetDiscreteTargetBase (const GridFunction &tspec_)
 
void SetTspecAtIndex (int idx, const GridFunction &tspec_)
 
void FinalizeSerialDiscreteTargetSpec ()
 
void SetTspecAtIndex (int idx, const ParGridFunction &tspec_)
 
void FinalizeParDiscreteTargetSpec (const ParGridFunction &tspec_)
 
- Protected Member Functions inherited from mfem::TargetConstructor
bool Parallel () const
 
bool Parallel () const
 
void ComputeAvgVolume () const
 
template<int DIM>
bool ComputeAllElementTargets (const FiniteElementSpace &fes, const IntegrationRule &ir, const Vector &xe, DenseTensor &Jtr) const
 
void ComputeAllElementTargets_Fallback (const FiniteElementSpace &fes, const IntegrationRule &ir, const Vector &xe, DenseTensor &Jtr) const
 

Protected Attributes

int ncomp
 
int sizeidx
 
int skewidx
 
int aspectratioidx
 
int orientationidx
 
Vector tspec
 
Vector tspec_sav
 
Vector tspec_pert1h
 
Vector tspec_pert2h
 
Vector tspec_pertmix
 
DenseTensor Jtrcomp
 
const FiniteElementSpacetspec_fes
 
const FiniteElementSpacetspec_fesv
 
bool good_tspec
 
bool good_tspec_grad
 
bool good_tspec_hess
 
AdaptivityEvaluatoradapt_eval
 
- Protected Attributes inherited from mfem::TargetConstructor
const GridFunctionnodes
 
double avg_volume
 
double volume_scale
 
const TargetType target_type
 
bool uses_phys_coords
 
MPI_Comm comm
 

Additional Inherited Members

- Public Types inherited from mfem::TargetConstructor
enum  TargetType {
  IDEAL_SHAPE_UNIT_SIZE, IDEAL_SHAPE_EQUAL_SIZE, IDEAL_SHAPE_GIVEN_SIZE, GIVEN_SHAPE_AND_SIZE,
  GIVEN_FULL
}
 Target-matrix construction algorithms supported by this class. More...
 

Detailed Description

Definition at line 1045 of file tmop.hpp.

Constructor & Destructor Documentation

mfem::DiscreteAdaptTC::DiscreteAdaptTC ( TargetType  ttype)
inline

Definition at line 1086 of file tmop.hpp.

virtual mfem::DiscreteAdaptTC::~DiscreteAdaptTC ( )
inlinevirtual

Definition at line 1095 of file tmop.hpp.

Member Function Documentation

virtual void mfem::DiscreteAdaptTC::ComputeAllElementTargets ( const FiniteElementSpace fes,
const IntegrationRule ir,
const Vector xe,
DenseTensor Jtr 
) const
virtual

Computes reference-to-target transformation Jacobians for all quadrature points in all elements.

Parameters
[in]fesThe nodal FE space
[in]irThe quadrature rule to use for all elements
[in]xeE-vector with the current physical coordinates/positions; this parameter is used only when needed by the target constructor, see UsesPhysicalCoordinates()
[out]JtrThe computed ref->target Jacobian matrices.

Reimplemented from mfem::TargetConstructor.

void mfem::DiscreteAdaptTC::ComputeElementTargets ( int  e_id,
const FiniteElement fe,
const IntegrationRule ir,
const Vector elfun,
DenseTensor Jtr 
) const
virtual

Given an element and quadrature rule, computes ref->target transformation Jacobians for each quadrature point in the element. The physical positions of the element's nodes are given by elfun. Note that this function assumes that UpdateTargetSpecification() has been called with the position vector corresponding to elfun.

Reimplemented from mfem::TargetConstructor.

Definition at line 1535 of file tmop.cpp.

void mfem::DiscreteAdaptTC::ComputeElementTargetsGradient ( const IntegrationRule ir,
const Vector elfun,
IsoparametricTransformation Tpr,
DenseTensor dJtr 
) const
virtual

Reimplemented from mfem::TargetConstructor.

Definition at line 1721 of file tmop.cpp.

void mfem::DiscreteAdaptTC::FinalizeParDiscreteTargetSpec ( const ParGridFunction tspec_)
protected

Definition at line 1317 of file tmop.cpp.

void mfem::DiscreteAdaptTC::FinalizeSerialDiscreteTargetSpec ( )
protected

Definition at line 1463 of file tmop.cpp.

const Vector& mfem::DiscreteAdaptTC::GetTspecPert1H ( )
inline

Definition at line 1164 of file tmop.hpp.

const Vector& mfem::DiscreteAdaptTC::GetTspecPert2H ( )
inline

Definition at line 1165 of file tmop.hpp.

const Vector& mfem::DiscreteAdaptTC::GetTspecPertMixH ( )
inline

Definition at line 1166 of file tmop.hpp.

void mfem::DiscreteAdaptTC::ResetUpdateFlags ( )
inline

Used in combination with the Update methods to avoid extra computations.

Definition at line 1128 of file tmop.hpp.

void mfem::DiscreteAdaptTC::RestoreTargetSpecificationAtNode ( ElementTransformation T,
int  nodenum 
)

Definition at line 1521 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetAdaptivityEvaluator ( AdaptivityEvaluator ae)
inline

Definition at line 1158 of file tmop.hpp.

void mfem::DiscreteAdaptTC::SetDiscreteTargetBase ( const GridFunction tspec_)
protected

Definition at line 1388 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetParDiscreteTargetAspectRatio ( const ParGridFunction tspec_)
virtual

Definition at line 1363 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetParDiscreteTargetOrientation ( const ParGridFunction tspec_)
virtual

Definition at line 1372 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetParDiscreteTargetSize ( const ParGridFunction tspec_)
virtual

Definition at line 1347 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetParDiscreteTargetSkew ( const ParGridFunction tspec_)
virtual

Definition at line 1355 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetParDiscreteTargetSpec ( const ParGridFunction tspec_)
virtual

Definition at line 1381 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetSerialDiscreteTargetAspectRatio ( const GridFunction tspec_)
virtual

Definition at line 1445 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetSerialDiscreteTargetOrientation ( const GridFunction tspec_)
virtual

Definition at line 1454 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetSerialDiscreteTargetSize ( const GridFunction tspec_)
virtual

Definition at line 1428 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetSerialDiscreteTargetSkew ( const GridFunction tspec_)
virtual

Definition at line 1437 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetSerialDiscreteTargetSpec ( const GridFunction tspec_)
virtual

Definition at line 1479 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetTspecAtIndex ( int  idx,
const GridFunction tspec_ 
)
protected

Definition at line 1416 of file tmop.cpp.

void mfem::DiscreteAdaptTC::SetTspecAtIndex ( int  idx,
const ParGridFunction tspec_ 
)
protected

Definition at line 1336 of file tmop.cpp.

void mfem::DiscreteAdaptTC::UpdateGradientTargetSpecification ( const Vector x,
double  dx,
bool  use_flag = false 
)

Used for finite-difference based computations. Computes the target specifications after a mesh perturbation in x or y direction. If use_flags is true, repeated calls won't do anything until ResetUpdateFlags() is called.

Definition at line 2068 of file tmop.cpp.

void mfem::DiscreteAdaptTC::UpdateHessianTargetSpecification ( const Vector x,
double  dx,
bool  use_flag = false 
)

Used for finite-difference based computations. Computes the target specifications after two mesh perturbations in x and/or y direction. If use_flags is true, repeated calls won't do anything until ResetUpdateFlags() is called.

Definition at line 2094 of file tmop.cpp.

void mfem::DiscreteAdaptTC::UpdateTargetSpecification ( const Vector new_x,
bool  use_flag = false 
)

Used to update the target specification after the mesh has changed. The new mesh positions are given by new_x. If use_flags is true, repeated calls won't do anything until ResetUpdateFlags() is called.

Definition at line 1486 of file tmop.cpp.

void mfem::DiscreteAdaptTC::UpdateTargetSpecification ( Vector new_x,
Vector IntData 
)

Definition at line 1498 of file tmop.cpp.

void mfem::DiscreteAdaptTC::UpdateTargetSpecificationAtNode ( const FiniteElement el,
ElementTransformation T,
int  nodenum,
int  idir,
const Vector IntData 
)

Definition at line 1504 of file tmop.cpp.

Member Data Documentation

AdaptivityEvaluator* mfem::DiscreteAdaptTC::adapt_eval
protected

Definition at line 1075 of file tmop.hpp.

int mfem::DiscreteAdaptTC::aspectratioidx
protected

Definition at line 1050 of file tmop.hpp.

bool mfem::DiscreteAdaptTC::good_tspec
protected

Definition at line 1071 of file tmop.hpp.

bool mfem::DiscreteAdaptTC::good_tspec_grad
protected

Definition at line 1071 of file tmop.hpp.

bool mfem::DiscreteAdaptTC::good_tspec_hess
protected

Definition at line 1071 of file tmop.hpp.

DenseTensor mfem::DiscreteAdaptTC::Jtrcomp
mutableprotected

Definition at line 1062 of file tmop.hpp.

int mfem::DiscreteAdaptTC::ncomp
protected

Definition at line 1050 of file tmop.hpp.

int mfem::DiscreteAdaptTC::orientationidx
protected

Definition at line 1050 of file tmop.hpp.

int mfem::DiscreteAdaptTC::sizeidx
protected

Definition at line 1050 of file tmop.hpp.

int mfem::DiscreteAdaptTC::skewidx
protected

Definition at line 1050 of file tmop.hpp.

Vector mfem::DiscreteAdaptTC::tspec
protected

Definition at line 1051 of file tmop.hpp.

const FiniteElementSpace* mfem::DiscreteAdaptTC::tspec_fes
protected

Definition at line 1066 of file tmop.hpp.

const FiniteElementSpace* mfem::DiscreteAdaptTC::tspec_fesv
protected

Definition at line 1067 of file tmop.hpp.

Vector mfem::DiscreteAdaptTC::tspec_pert1h
protected

Definition at line 1053 of file tmop.hpp.

Vector mfem::DiscreteAdaptTC::tspec_pert2h
protected

Definition at line 1054 of file tmop.hpp.

Vector mfem::DiscreteAdaptTC::tspec_pertmix
protected

Definition at line 1055 of file tmop.hpp.

Vector mfem::DiscreteAdaptTC::tspec_sav
protected

Definition at line 1052 of file tmop.hpp.


The documentation for this class was generated from the following files: