Skip to content
Snippets Groups Projects
Forked from gmsh / gmsh
12758 commits behind the upstream repository.
GaussIntegration.h 1.60 KiB
// Gmsh - Copyright (C) 1997-2012 C. Geuzaine, J.-F. Remacle
//
// See the LICENSE.txt file for license information. Please report all
// bugs and problems to <gmsh@geuz.org>.

#ifndef _GAUSS_INTEGRATION_H_
#define _GAUSS_INTEGRATION_H_

#include "fullMatrix.h"

struct IntPt{
  double pt[3];
  double weight;
};

int GaussLegendreTri(int n1, int n2, IntPt *pts);
int GaussLegendreTet(int n1, int n2, int n3, IntPt *pts); 

int getNGQLPts (int order);
IntPt *getGQLPts (int order);

int getNGQTPts(int order);
IntPt *getGQTPts (int order);

int getNGQQPts(int order);
IntPt *getGQQPts(int order);

int getNGQTetPts(int order);
IntPt *getGQTetPts(int order);

int getNGQPriPts(int order);
IntPt *getGQPriPts(int order);

int getNGQHPts(int order);
IntPt *getGQHPts(int order);

class gaussIntegration {
  public:
  static void get(int elementType, int order, fullMatrix<double> &pts,
                  fullMatrix<double> &weights);
  static void getTriangle(int order, fullMatrix<double> &pts,
                          fullMatrix<double> &weights);
  static void getLine(int order, fullMatrix<double> &pts,
                      fullMatrix<double> &weights);
  static void getQuad(int order, fullMatrix<double> &pts,
                      fullMatrix<double> &weights);
  static void getTetrahedron(int order, fullMatrix<double> &pts,
                             fullMatrix<double> &weights);
  static void getHexahedron(int order, fullMatrix<double> &pts, 
                            fullMatrix<double> &weights);
  static void getPrism(int order, fullMatrix<double> &pts,
                       fullMatrix<double> &weights);
};

#endif