Skip to content
Snippets Groups Projects
quadratureRules.h 1.8 KiB
Newer Older
Éric Béchet's avatar
Éric Béchet committed
//
// C++ Interface: quadratureRules
//
// Description:
Éric Béchet's avatar
Éric Béchet committed
//
//
// 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
{
Éric Béchet's avatar
Éric Béchet committed
  virtual ~QuadratureBase(){}
Gaetan Bricteux's avatar
pp  
Gaetan Bricteux committed
  virtual int getIntPoints(MElement *e, IntPt **GP) =0;
Gauthier Becker's avatar
Gauthier Becker committed
// For rigid contact no need of Gauss'integration
// but to use clasical get function in term npts and IntPt are needed
Gauthier Becker's avatar
Gauthier Becker committed
// so use a empty gaussQuadrature rule
class QuadratureVoid : public QuadratureBase
{
 public:
  QuadratureVoid() : QuadratureBase(){}
  ~QuadratureVoid(){}
  int getIntPoints(MElement *e, IntPt **GP){GP=NULL; return 0;}
} ;
Éric Béchet's avatar
Éric Béchet committed

class GaussQuadrature : public QuadratureBase
{
Gaetan Bricteux's avatar
pp  
Gaetan Bricteux committed
  enum IntegCases {Other, Val, Grad, ValVal, GradGrad};
Éric Béchet's avatar
Éric Béchet committed
 private :
  int order;
  IntegCases info;
Gaetan Bricteux's avatar
pp  
Gaetan Bricteux committed
  GaussQuadrature(int order_ = 0) : order(order_), info(Other) {}
  GaussQuadrature(IntegCases info_) : order(0), info(info_) {}
Éric Béchet's avatar
Éric Béchet committed
  virtual ~GaussQuadrature(){}
Gauthier Becker's avatar
Gauthier Becker committed
  virtual int getIntPoints(MElement *e, IntPt **GP)
Éric Béchet's avatar
Éric Béchet committed
  {
    int integrationOrder;
    int npts;
Gaetan Bricteux's avatar
pp  
Gaetan Bricteux committed
    int geoorder = e->getPolynomialOrder();
Éric Béchet's avatar
Éric Béchet committed
    switch(info)
    {
    case Other :
      integrationOrder = order;
      break;
    case Val :
Gaetan Bricteux's avatar
pp  
Gaetan Bricteux committed
      integrationOrder = geoorder + 1;
Éric Béchet's avatar
Éric Béchet committed
      break;
    case Grad :
Gaetan Bricteux's avatar
pp  
Gaetan Bricteux committed
      integrationOrder = geoorder;
Éric Béchet's avatar
Éric Béchet committed
      break;
    case ValVal :
Gaetan Bricteux's avatar
pp  
Gaetan Bricteux committed
      integrationOrder = 2 * geoorder;
Éric Béchet's avatar
Éric Béchet committed
      break;
    case GradGrad :
Gaetan Bricteux's avatar
pp  
Gaetan Bricteux committed
      integrationOrder = 3 * (geoorder - 1) + 1;
Éric Béchet's avatar
Éric Béchet committed
      break;
Gaetan Bricteux's avatar
pp  
Gaetan Bricteux committed
    default : integrationOrder = 1;
Éric Béchet's avatar
Éric Béchet committed
    }
    e->getIntegrationPoints(integrationOrder, &npts, GP);
    return npts;
  }
  // copy constructor
  GaussQuadrature(const GaussQuadrature &other) : info(other.info), order(other.order){}
Éric Béchet's avatar
Éric Béchet committed
};

#endif //_QUADRATURERULES_H_