Chombo + EB + MF
3.2
|
A FArrayBox-like container for face-centered fluxes. More...
#include <FluxBox.H>
Public Member Functions | |
FluxBox () | |
Default constructor. More... | |
FluxBox (const Box &bx, int n=1) | |
Constructs FluxBox on cell-centered box with n components. More... | |
FluxBox (const Box &a_bx, const int a_nComp, D_DECL6(Real *const a_alias0, Real *const a_alias1, Real *const a_alias2, Real *const a_alias3, Real *const a_alias4, Real *const a_alias5)) | |
Constructs FluxBox aliasing SpaceDim memory pointers for the FArrayBox. More... | |
FluxBox (const Interval &a_comps, FluxBox &a_original) | |
aliasing constructor More... | |
~FluxBox () | |
Destructor. More... | |
void | define (const Box &bx, int n=1) |
Resize FluxBox similar to BaseFab::resize() More... | |
void | define (const FluxBox &a_fb) |
void | clear () |
Returns the FluxBox to the undefined state. More... | |
int | nComp () const |
Number of components. More... | |
const Box & | box () const |
Returns cell-centered box which defines fluxBox. More... | |
FArrayBox & | getFlux (const int dir) |
Returns face-centered flux in direction dir. More... | |
const FArrayBox & | getFlux (const int dir) const |
Returns const reference to face-centered flux in direction dir. More... | |
FArrayBox & | operator[] (const int dir) |
Returns FArrayBox in direction dir. More... | |
const FArrayBox & | operator[] (const int dir) const |
Constant version. More... | |
void | setVal (const Real val) |
Set all fluxes to val. More... | |
void | setVal (const Real val, const int dir) |
Set fluxes in direction dir to val. More... | |
void | setVal (const Real val, const int dir, const int startComp, const int nComp) |
More specific setVal. More... | |
void | setVal (const Real val, const Box &bx) |
Sets fluxes on faces surrounding cell-centered box bx. More... | |
void | setVal (const Real val, const Box &bx, const int dir, const int startComp, const int nComp) |
Most specific setVal. More... | |
void | copy (const FluxBox &src) |
Copy from src to this FluxBox – sizes must be identical. More... | |
void | copy (const FluxBox &src, const int srcComp, const int destComp, const int numComp) |
Copy on overlap, for all directions. More... | |
void | copy (const FluxBox &src, const int dir, const int srcComp, const int destComp, const int numComp) |
Copy on overlap of FluxBoxes, in direction dir. More... | |
void | copy (const FluxBox &a_src, const Box &a_destbox) |
void | copy (const Box &R, const Interval &Cdest, const FluxBox &src, const Interval &Csrc) |
Copies from a subsection of one box into another. More... | |
void | copy (const Box &srcbox, const Interval &destcomps, const Box &destbox, const FluxBox &src, const Interval &srccomps) |
Modifies this FluxBox by copying the contents of src into it. More... | |
FluxBox & | negate (const Box &subbox, int comp=0, int numcomp=1) |
Modifies this FluxBox to its additive inverse. More... | |
FluxBox & | negate (int comp, int numcomp=1) |
Modifies this FluxBox to its additive inverse. More... | |
FluxBox & | negate () |
Modifies this FluxBox to its additive inverse. More... | |
FluxBox & | plus (const FluxBox &a_src, const Box &a_subbox, int a_srccomp, int a_destcomp, int a_numcomp=1) |
Modifies this FluxBox by adding src in the CELL-CENTERED sub-box. More... | |
void | plus (const Box &srcbox, const Interval &destcomps, const Box &destbox, const FluxBox &src, const Interval &srccomps) |
FluxBox & | minus (const FluxBox &a_src, const Box &a_subbox, int a_srccomp, int a_destcomp, int a_numcomp=1) |
Modifies this FluxBox by subtracting src in the CELL-CENTERED sub-box. More... | |
FluxBox & | mult (const FluxBox &a_src, const Box &a_subbox, int a_srccomp, int a_destcomp, int a_numcomp=1) |
Modifies this FluxBox by multiplying src in the CELL-CENTERED sub-box. More... | |
FluxBox & | divide (const FluxBox &a_src, const Box &a_subbox, int a_srccomp, int a_destcomp, int a_numcomp=1) |
Modifies this FluxBox by dividing src in the CELL-CENTERED sub-box. More... | |
FluxBox & | operator+= (Real r) |
Modifies this FluxBox by adding the scalar Real r to all values. More... | |
FluxBox & | operator+= (const FluxBox &f) |
Modifies this FluxBox by incrementing with the argument FluxBox. More... | |
FluxBox & | operator-= (Real r) |
Modifies this FluxBox by subtracting the scalar Real r to all values. More... | |
FluxBox & | operator-= (const FluxBox &f) |
Modifies this FluxBox by decrementing with the argument FluxBox. More... | |
FluxBox & | operator*= (Real r) |
Modifies this FluxBox by multiplying all values by the scalar Real r. More... | |
FluxBox & | operator*= (const FluxBox &f) |
Modifies this FluxBox by multiplying by the argument FluxBox. More... | |
FluxBox & | shift (const IntVect &v) |
Modifies this FluxBox by shifting its domain box. More... | |
int | size (const Box &bx, const Interval &comps) const |
Returns size of linearized data over bx. More... | |
void | linearOut (void *buf, const Box &R, const Interval &comps) const |
Writes a linear representation of this FluxBox. More... | |
void * | linearOut2 (void *buf, const Box &R, const Interval &comps) const |
like linearOut, but returns current position in the buffer More... | |
void | linearIn (void *buf, const Box &R, const Interval &comps) |
Read a linear representation of the data over the Box R. More... | |
void * | linearIn2 (void *buf, const Box &R, const Interval &comps) |
like linearInt, but returns current position in the buffer More... | |
Static Public Member Functions | |
static int | preAllocatable () |
Helper function for linearization. More... | |
Protected Attributes | |
Box | m_bx |
int | m_nvar |
Vector< FArrayBox * > | m_fluxes |
Private Member Functions | |
FluxBox (const FluxBox &) | |
Disallowed. More... | |
FluxBox & | operator= (const FluxBox &) |
Disallowed. More... | |
A FArrayBox-like container for face-centered fluxes.
This is a class to contain face-centered fluxes on a box.
FluxBox::FluxBox | ( | ) |
Default constructor.
FluxBox::FluxBox | ( | const Box & | bx, |
int | n = 1 |
||
) |
Constructs FluxBox on cell-centered box with n components.
aliasing constructor
This behaves like the BaseFab(Interval, BaseFab) constructor, by creating aliased versions of each FArrayBox
FluxBox::~FluxBox | ( | ) |
Destructor.
|
private |
Disallowed.
void FluxBox::define | ( | const Box & | bx, |
int | n = 1 |
||
) |
Resize FluxBox similar to BaseFab::resize()
Define function
Referenced by define(), VCAMRPoissonOp2::getFlux(), ViscousTensorOp::getFlux(), NWOViscousTensorOp::getFlux(), and AMRPoissonOp::getFlux().
|
inline |
References box(), clear(), copy(), define(), divide(), getFlux(), linearIn(), linearIn2(), linearOut(), linearOut2(), minus(), mult(), nComp(), negate(), operator*=(), operator+=(), operator-=(), operator[](), plus(), setVal(), shift(), and size().
int FluxBox::nComp | ( | ) | const |
Number of components.
Referenced by define().
const Box& FluxBox::box | ( | ) | const |
Returns cell-centered box which defines fluxBox.
Referenced by define(), ViscousTensorOp::getFlux(), and NWOViscousTensorOp::getFlux().
FArrayBox& FluxBox::getFlux | ( | const int | dir | ) |
Returns face-centered flux in direction dir.
Referenced by define().
const FArrayBox& FluxBox::getFlux | ( | const int | dir | ) | const |
Returns const reference to face-centered flux in direction dir.
FArrayBox& FluxBox::operator[] | ( | const int | dir | ) |
const FArrayBox& FluxBox::operator[] | ( | const int | dir | ) | const |
Constant version.
void FluxBox::setVal | ( | const Real | val, |
const int | dir | ||
) |
Set fluxes in direction dir to val.
void FluxBox::setVal | ( | const Real | val, |
const int | dir, | ||
const int | startComp, | ||
const int | nComp | ||
) |
More specific setVal.
Sets fluxes on faces surrounding cell-centered box bx.
void FluxBox::setVal | ( | const Real | val, |
const Box & | bx, | ||
const int | dir, | ||
const int | startComp, | ||
const int | nComp | ||
) |
Most specific setVal.
Sets fluxes on faces surrounding cell-centered box bx
void FluxBox::copy | ( | const FluxBox & | src | ) |
void FluxBox::copy | ( | const FluxBox & | src, |
const int | srcComp, | ||
const int | destComp, | ||
const int | numComp | ||
) |
Copy on overlap, for all directions.
void FluxBox::copy | ( | const FluxBox & | src, |
const int | dir, | ||
const int | srcComp, | ||
const int | destComp, | ||
const int | numComp | ||
) |
Copy on overlap of FluxBoxes, in direction dir.
void FluxBox::copy | ( | const Box & | R, |
const Interval & | Cdest, | ||
const FluxBox & | src, | ||
const Interval & | Csrc | ||
) |
Copies from a subsection of one box into another.
Assumes the boxes are both in the same index space, and that box R is completely contained in both the src and destination boxes. This function required by BoxLayoutData
void FluxBox::copy | ( | const Box & | srcbox, |
const Interval & | destcomps, | ||
const Box & | destbox, | ||
const FluxBox & | src, | ||
const Interval & | srccomps | ||
) |
Modifies this FluxBox by copying the contents of src into it.
This, the most general form of copy, specifies the contents of any sub-box srcbox in `FluxBox' src may be copied into a (possibly different) destbox in the destination `FluxBox'. Note that although the srcbox and the destbox may be disjoint, they must be the same size and shape. If the sizes differ, the copy is undefined and a runtime error results. This copy function is the only one of the copy functions to allow a copy between differing boxes. The user also specifies how many components are copied, starting at component srccomp in src and stored starting at component destcomp. The results are UNDEFINED if the src and dest FluxBoxes are the same and the srcbox and destbox overlap.
FluxBox& FluxBox::negate | ( | int | comp, |
int | numcomp = 1 |
||
) |
FluxBox& FluxBox::negate | ( | ) |
FluxBox& FluxBox::plus | ( | const FluxBox & | a_src, |
const Box & | a_subbox, | ||
int | a_srccomp, | ||
int | a_destcomp, | ||
int | a_numcomp = 1 |
||
) |
Modifies this FluxBox by adding src in the CELL-CENTERED sub-box.
Modifies this FluxBox by pointwise addition of values in the argument FluxBox. Adds src's components (a_srccomp : a_srccomp+a_numcomp-1) to this FluxBox's components (a_destcomp : a_destcomp+numcomp-1) where the domain of this FluxBox intersects the a_subbox. The actual directionally-dependent subbox is a_subbox.surroundingNodes(dir); NOTE: a_subbox must be contained in the cell-centered Box of this FluxBox. Returns *this
Referenced by define().
void FluxBox::plus | ( | const Box & | srcbox, |
const Interval & | destcomps, | ||
const Box & | destbox, | ||
const FluxBox & | src, | ||
const Interval & | srccomps | ||
) |
FluxBox& FluxBox::minus | ( | const FluxBox & | a_src, |
const Box & | a_subbox, | ||
int | a_srccomp, | ||
int | a_destcomp, | ||
int | a_numcomp = 1 |
||
) |
Modifies this FluxBox by subtracting src in the CELL-CENTERED sub-box.
Modifies this FluxBox by pointwise addition of values in the argument FArrayBox. Subtracts src's components (a_srccomp : a_srccomp+a_numcomp-1) from this FluxBox's components (a_destcomp : a_destcomp+numcomp-1) where the domain of this FluxBox intersects the a_subbox. The actual directionally-dependent subbox is a_subbox.surroundingNodes(dir); NOTE: a_subbox must be contained in the cell-centered Box of this FluxBox. Returns *this
Referenced by define().
FluxBox& FluxBox::mult | ( | const FluxBox & | a_src, |
const Box & | a_subbox, | ||
int | a_srccomp, | ||
int | a_destcomp, | ||
int | a_numcomp = 1 |
||
) |
Modifies this FluxBox by multiplying src in the CELL-CENTERED sub-box.
Modifies this FluxBox by pointwise multiplication of values in the argument FArrayBox. Multiplies src's components (a_srccomp : a_srccomp+a_numcomp-1) with this FluxBox's components (a_destcomp : a_destcomp+numcomp-1) where the domain of this FluxBox intersects the a_subbox. The actual directionally-dependent subbox is a_subbox.surroundingNodes(dir); NOTE: a_subbox must be contained in the cell-centered Box of this FluxBox. Returns *this
Referenced by define().
FluxBox& FluxBox::divide | ( | const FluxBox & | a_src, |
const Box & | a_subbox, | ||
int | a_srccomp, | ||
int | a_destcomp, | ||
int | a_numcomp = 1 |
||
) |
Modifies this FluxBox by dividing src in the CELL-CENTERED sub-box.
Modifies this FluxBox by pointwise division of values in the argument FArrayBox. Divides src's components (a_srccomp : a_srccomp+a_numcomp-1) into this FluxBox's components (a_destcomp : a_destcomp+numcomp-1) where the domain of this FluxBox intersects the a_subbox. The actual directionally-dependent subbox is a_subbox.surroundingNodes(dir); NOTE: a_subbox must be contained in the cell-centered Box of this FluxBox. Returns *this
Referenced by define().
Modifies this FluxBox by incrementing with the argument FluxBox.
Modifies this FluxBox by pointwise addition of the values of the argument FluxBox. You might come to grief if the domains of the FArrayBoxes don't match, just as in FArrayBox::plus().
Modifies this FluxBox by decrementing with the argument FluxBox.
Modifies this FluxBox by pointwise subtraction of the values of the argument FluxBox. You might come to grief if the domains of the FluxBoxes don't match, just as in FArrayBox::minus().
Modifies this FluxBox by multiplying by the argument FluxBox.
Modifies this FluxBox by pointwise multiplication of the values by the argument FluxBox. You might come to grief if the domains of the FluxBoxes don't match, just as in FArrayBox::mult().
Returns size of linearized data over bx.
Returns size, in number of bytes, of a flat linear representation of data in components comps in faces around cell-centered box R
Referenced by define().
like linearOut, but returns current position in the buffer
Referenced by define().
like linearInt, but returns current position in the buffer
Referenced by define().
|
inlinestatic |
Helper function for linearization.
|
protected |
Number of variables on each face