Newer
Older
//
//
// Author: <Eric Bechet>, (C) 2009
//
// Copyright: See COPYING file that comes with this distribution
//
//
#ifndef _QUADRATURERULES_H_
#define _QUADRATURERULES_H_
#include "Gauss.h"
#include "MElement.h"
class QuadratureBase
{
// but to use clasical get function in term npts and IntPt are needed
// so use a empty gaussQuadrature rule
class QuadratureVoid : public QuadratureBase
{
public:
QuadratureVoid() : QuadratureBase(){}
~QuadratureVoid(){}
int getIntPoints(MElement *e, IntPt **GP){GP=NULL; return 0;}
} ;
class GaussQuadrature : public QuadratureBase
{
GaussQuadrature(int order_ = 0) : order(order_), info(Other) {}
GaussQuadrature(IntegCases info_) : order(0), info(info_) {}
switch(info)
{
case Other :
integrationOrder = order;
break;
case Val :
}
e->getIntegrationPoints(integrationOrder, &npts, GP);
return npts;
}
// copy constructor
GaussQuadrature(const GaussQuadrature &other) : info(other.info), order(other.order){}