20 template <
class F = concepts::Real>
42 uint
blksz()
const {
return blksz_;}
43 uint
m()
const {
return m_;}
57 void apply(
const concepts::Real Y[],
const F src[], F dst[])
const;
94 shift<concepts::Real>(z, src, dst, 0);
101 if (Y) {apply(YMPE->value(), src, dst);
return;}
#define conceptsException(exc)
void evaluate(const bem::Constant3d000< F > &elm, const concepts::Real3d &c, XYColExpPtr *Y[]) const
void evaluate(const bem::Linear3d000< F > &elm, const concepts::Real3d &c, XYColExpPtr *Y[]) const
uint blksz() const
Size of memory used for the expansion.
void evaluate(const bem::Dirac3d000< F > &elm, const concepts::Real3d &c, XYColExpPtr *Y[]) const
void shift(const concepts::Real3d &z, const concepts::Real src[], concepts::Real dst[]) const
XYColReal * getCol(uint blksz, uint n) const
void evaluate(const bem::Constant3d002< F > &elm, const concepts::Real3d &c, XYColExpPtr *Y[]) const
void evaluate(const concepts::Real3d &z, concepts::Real Y[]) const
void apply(const XYColExpPtr *Y, const F src[], F dst[]) const
void evaluate(const bem::Constant3d001< F > &elm, const concepts::Real3d &c, XYColExpPtr *Y[]) const
void evaluate(const concepts::Element< F > &elm, const concepts::Real3d &c, XYColExpPtr *Y[]) const
uint m() const
Order of the expansion.
MultipoleY(uint m, uint gauss)
std::complex< Real > Cmplx
Type for a complex number. It also depends on the setting of Real.