OOFEM  2.4
OOFEM.org - Object Oriented Finite Element Solver
oofem::SymmetryBarrier Class Reference

Implementation of symmetry nonlocal barrier. More...

#include <symmetrybarrier.h>

+ Inheritance diagram for oofem::SymmetryBarrier:
+ Collaboration diagram for oofem::SymmetryBarrier:

Public Member Functions

 SymmetryBarrier (int n, Domain *d)
 Constructor. More...
 
virtual ~SymmetryBarrier ()
 Destructor. More...
 
virtual void applyConstraint (const FloatArray &c1, const FloatArray &c2, double &weight, bool &shieldFlag, NonlocalMaterialExtensionInterface *nei)
 Abstract method modifying the integration weight between master (c1) and source (c2) point. More...
 
virtual double calculateMinimumDistanceFromBoundary (const FloatArray &coords)
 Abstract method calculating the minimum distance of the Gauss Point from the nonlocal boundaries. More...
 
virtual IRResultType initializeFrom (InputRecord *ir)
 Initializes receiver according to object description stored in input record. More...
 
virtual const char * giveInputRecordName () const
 
virtual const char * giveClassName () const
 
- Public Member Functions inherited from oofem::NonlocalBarrier
 NonlocalBarrier (int n, Domain *aDomain)
 Constructor. More...
 
virtual ~NonlocalBarrier ()
 Destructor. More...
 
- Public Member Functions inherited from oofem::FEMComponent
 FEMComponent (int n, Domain *d)
 Regular constructor, creates component with given number and belonging to given domain. More...
 
virtual ~FEMComponent ()
 Virtual destructor. More...
 
DomaingiveDomain () const
 
virtual void setDomain (Domain *d)
 Sets associated Domain. More...
 
int giveNumber () const
 
void setNumber (int num)
 Sets number of receiver. More...
 
virtual void updateLocalNumbering (EntityRenumberingFunctor &f)
 Local renumbering support. More...
 
virtual void giveInputRecord (DynamicInputRecord &input)
 Setups the input record string of receiver. More...
 
virtual contextIOResultType saveContext (DataStream &stream, ContextMode mode, void *obj=NULL)
 Stores receiver state to output stream. More...
 
virtual contextIOResultType restoreContext (DataStream &stream, ContextMode mode, void *obj=NULL)
 Restores the receiver state previously written in stream. More...
 
virtual int checkConsistency ()
 Allows programmer to test some internal data, before computation begins. More...
 
virtual void printOutputAt (FILE *file, TimeStep *tStep)
 Prints output of receiver to stream, for given time step. More...
 
virtual void printYourself ()
 Prints receiver state on stdout. Useful for debugging. More...
 
virtual InterfacegiveInterface (InterfaceType t)
 Interface requesting service. More...
 
std::string errorInfo (const char *func) const
 Returns string for prepending output (used by error reporting macros). More...
 

Protected Attributes

FloatArray origin
 
FloatArray normals
 
IntArray mask
 
FloatMatrix lcs
 
- Protected Attributes inherited from oofem::FEMComponent
int number
 Component number. More...
 
Domaindomain
 Link to domain object, useful for communicating with other FEM components. More...
 

Detailed Description

Implementation of symmetry nonlocal barrier.

It allows to specify up to three planes (orthogonal ones) of symmetry It then modifies the integration weights of source points to take into account symmetry of the averaged field.

Definition at line 58 of file symmetrybarrier.h.

Constructor & Destructor Documentation

oofem::SymmetryBarrier::SymmetryBarrier ( int  n,
Domain d 
)

Constructor.

Creates an element with number n belonging to domain aDomain.

Parameters
nElement's number
dPointer to the domain to which element belongs.
oofem::SymmetryBarrier::~SymmetryBarrier ( )
virtual

Destructor.

Definition at line 50 of file symmetrybarrier.C.

Member Function Documentation

void oofem::SymmetryBarrier::applyConstraint ( const FloatArray c1,
const FloatArray c2,
double &  weight,
bool &  shieldFlag,
NonlocalMaterialExtensionInterface nei 
)
virtual

Abstract method modifying the integration weight between master (c1) and source (c2) point.

Parameters
c1Coordinates of master point.
c2Coordinates of source point.
weightOriginal integration weight; on output modified weight.
[out]shieldFlagSet to true if shielding is activated.
neiThe element with the non local material extension.

Implements oofem::NonlocalBarrier.

Definition at line 55 of file symmetrybarrier.C.

References oofem::IntArray::at(), oofem::FloatArray::at(), oofem::FloatMatrix::at(), oofem::NonlocalMaterialExtensionInterface::computeWeightFunction(), oofem::FloatArray::giveSize(), lcs, mask, and origin.

virtual double oofem::SymmetryBarrier::calculateMinimumDistanceFromBoundary ( const FloatArray coords)
inlinevirtual

Abstract method calculating the minimum distance of the Gauss Point from the nonlocal boundaries.

Parameters
coordsCoordinates of the Gauss Point
maxPossibleDistanceDistance from the boundary beyond which the nonlocal radius(as it is interpreted in each weight function) becomes equal to the user-defined
Returns
the minimum value of the minimum distance from nonlocal boundary and maxPossibleDistance

Implements oofem::NonlocalBarrier.

Definition at line 78 of file symmetrybarrier.h.

References initializeFrom().

virtual const char* oofem::SymmetryBarrier::giveClassName ( ) const
inlinevirtual
Returns
Class name of the receiver.

Implements oofem::FEMComponent.

Definition at line 82 of file symmetrybarrier.h.

virtual const char* oofem::SymmetryBarrier::giveInputRecordName ( ) const
inlinevirtual
Returns
Input record name of the receiver.

Implements oofem::FEMComponent.

Definition at line 81 of file symmetrybarrier.h.

References _IFT_SymmetryBarrier_Name.

IRResultType oofem::SymmetryBarrier::initializeFrom ( InputRecord ir)
virtual

Initializes receiver according to object description stored in input record.

This function is called immediately after creating object using constructor. Input record can be imagined as data record in component database belonging to receiver. Receiver may use value-name extracting functions to extract particular field from record.

See also
IR_GIVE_FIELD
IR_GIVE_OPTIONAL_FIELD
Parameters
irInput record to initialize from.
Returns
IRResultType

Reimplemented from oofem::FEMComponent.

Definition at line 124 of file symmetrybarrier.C.

References _IFT_SymmetryBarrier_activemask, _IFT_SymmetryBarrier_normals, _IFT_SymmetryBarrier_origin, oofem::FloatArray::at(), oofem::FloatMatrix::at(), oofem::FEMComponent::giveNumber(), oofem::IntArray::giveSize(), oofem::FloatArray::giveSize(), IR_GIVE_FIELD, oofem::IRRT_BAD_FORMAT, oofem::IRRT_OK, lcs, mask, normals, OOFEM_ERROR, OOFEM_WARNING, origin, and oofem::FloatMatrix::resize().

Referenced by calculateMinimumDistanceFromBoundary().

Member Data Documentation

FloatMatrix oofem::SymmetryBarrier::lcs
protected

Definition at line 64 of file symmetrybarrier.h.

Referenced by applyConstraint(), and initializeFrom().

IntArray oofem::SymmetryBarrier::mask
protected

Definition at line 63 of file symmetrybarrier.h.

Referenced by applyConstraint(), and initializeFrom().

FloatArray oofem::SymmetryBarrier::normals
protected

Definition at line 62 of file symmetrybarrier.h.

Referenced by initializeFrom().

FloatArray oofem::SymmetryBarrier::origin
protected

Definition at line 61 of file symmetrybarrier.h.

Referenced by applyConstraint(), and initializeFrom().


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

This page is part of the OOFEM documentation. Copyright (c) 2011 Borek Patzak
Project e-mail: info@oofem.org
Generated at Tue Jan 2 2018 20:07:42 for OOFEM by doxygen 1.8.11 written by Dimitri van Heesch, © 1997-2011