Forked from
gmsh / gmsh
13399 commits behind the upstream repository.
-
Emilie Marchandise authoredEmilie Marchandise authored
GFaceCompound.h 5.93 KiB
// Gmsh - Copyright (C) 1997-2011 C. Geuzaine, J.-F. Remacle
//
// See the LICENSE.txt file for license information. Please report all
// bugs and problems to <gmsh@geuz.org>.
#ifndef _GFACE_COMPOUND_H_
#define _GFACE_COMPOUND_H_
#include <list>
#include <map>
#include "GmshConfig.h"
#include "GmshMessage.h"
#include "GFace.h"
#include "simpleFunction.h"
#if defined(HAVE_SOLVER)
#include "GEdge.h"
#include "GEdgeCompound.h"
#include "meshGFaceOptimize.h"
#include "linearSystem.h"
#include "GRbf.h"
#define AR_MAX 5 //maximal geometrical aspect ratio
/*
A GFaceCompound is a model face that is the compound of model faces.
The user selects 4 corners to the compound, which are mmapped to
points (0,0), (1,0), (1,1) and (0,1) of the compound parametric plane.
It is assumed that all the faces of the compound have been meshed
first. We use this discretization to solve 2 elliptic problems on the
compound. Those 2 problems enables to compute the parametric
coordinates of the mesh points. The parametrization of the compound
consist in a triangulation in the (u,v) space with parameter values at
nodes.
The compound can therefore be re-meshed using any surface mesh
generator of gmsh!
*/
class GFaceCompoundTriangle {
public:
SPoint3 p1, p2, p3;
SPoint2 gfp1, gfp2, gfp3;
SPoint3 v1, v2, v3;
GFace *gf;
MTriangle *tri;
GFaceCompoundTriangle() : gf(0), tri(0) {}
};
class Octree;
class GRbf;
class GFaceCompound : public GFace {
public:
typedef enum {ITERU=0,ITERV=1,ITERD=2} iterationStep;
typedef enum {HARMONIC=1,CONFORMAL=2, CONVEXCOMBINATION=3, MULTISCALE=4, RBF=5} typeOfMapping;
typedef enum {UNITCIRCLE, SQUARE} typeOfIsomorphism;
void computeNormals(std::map<MVertex*, SVector3> &normals) const;
protected:
mutable GRbf *_rbf;
simpleFunction<double> *ONE;
simpleFunction<double> *MONE;
std::list<GFace*> _compound;
std::list<GEdge*> _U0;
std::list<std::list<GEdge*> > _interior_loops;
mutable int nbT;
mutable GFaceCompoundTriangle *_gfct;
mutable Octree *oct;
mutable std::set<MVertex*> allNodes;
mutable v2t_cont adjv;
mutable bool mapv2Tri;
mutable std::map<MVertex*, SPoint3> coordinates;
mutable std::map<SPoint3,SPoint3 > _coordPoints;
mutable std::map<MVertex*, SVector3> _normals;
mutable std::list<MTriangle*> fillTris;
mutable std::set<MVertex*> fillNodes;
mutable std::vector<MVertex*> _ordered;
mutable std::vector<double> _coords;
mutable std::map<MVertex*, int> _mapV;
void buildOct() const ;
void buildAllNodes() const;
void parametrize(iterationStep, typeOfMapping) const;
bool parametrize_conformal() const;
bool parametrize_conformal_spectral() const;
void compute_distance() const;
bool checkOrientation(int iter) const;
bool checkOverlap() const;
void one2OneMap() const;
double checkAspectRatio() const;
void computeNormals () const;
void getBoundingEdges();
void getUniqueEdges(std::set<GEdge*> &_unique);
void computeALoop(std::set<GEdge*> &_unique, std::list<GEdge*> &);
void getTriangle(double u, double v, GFaceCompoundTriangle **lt,
double &_u, double &_v) const;
virtual double locCurvature(MTriangle *t, double u, double v) const;
void printStuff(int iNewton=0) const;
bool trivial() const ;
linearSystem <double> *_lsys;
double getSizeH() const;
double getSizeBB(const std::list<GEdge* > &elist) const;
SBoundingBox3d boundEdges(const std::list<GEdge* > &elist) const;
SOrientedBoundingBox obb_boundEdges(const std::list<GEdge* > &elist) const;
void fillNeumannBCS() const;
/* double sumAngles(std::vector<MVertex*> ordered) const; */
public:
GFaceCompound(GModel *m, int tag, std::list<GFace*> &compound,
std::list<GEdge*> &U0, linearSystem<double>* lsys =0,
typeOfMapping typ = HARMONIC, int allowPartition=1);
virtual ~GFaceCompound();
Range<double> parBounds(int i) const
{ return trivial() ? (*(_compound.begin()))->parBounds(i) : Range<double>(-1, 1); }
virtual GPoint point(double par1, double par2) const;
typeOfMapping getTypeOfMapping() { return _mapping;}
SPoint2 parFromPoint(const SPoint3 &p, bool onSurface=true) const;
virtual Pair<SVector3,SVector3> firstDer(const SPoint2 ¶m) const;
virtual void secondDer(const SPoint2 &, SVector3 *, SVector3 *, SVector3 *) const;
virtual GEntity::GeomType geomType() const { return CompoundSurface; }
ModelType getNativeType() const { return GmshModel; }
void * getNativePtr() const { return 0; }
virtual SPoint2 getCoordinates(MVertex *v) const;
virtual double curvatureMax(const SPoint2 ¶m) const;
virtual int genusGeom () const;
virtual bool checkTopology() const;
bool parametrize() const ;
void coherenceNormals();
void coherencePatches() const;
virtual std::list<GFace*> getCompounds() const { return _compound; }
mutable int nbSplit;
int getNbSplit() const { return nbSplit; }
int allowPartition() const{ return _allowPartition; }
private:
typeOfIsomorphism _type;
mutable typeOfMapping _mapping;
int _allowPartition;
};
#else
template<class scalar> class linearSystem;
class GFaceCompound : public GFace {
public:
typedef enum {HARMONIC=1,CONFORMAL=2, CONVEXCOMBINATION=3, MULTISCALE=4} typeOfMapping;
GFaceCompound(GModel *m, int tag, std::list<GFace*> &compound,
std::list<GEdge*> &U0, linearSystem<double>* lsys =0,
typeOfMapping typ = HARMONIC, int allowPartition=1)
: GFace(m, tag)
{
Msg::Error("Gmsh has to be compiled with solver support to use GFaceCompounds");
}
virtual ~GFaceCompound() {}
GPoint point(double par1, double par2) const { return GPoint(); }
Pair<SVector3, SVector3> firstDer(const SPoint2 ¶m) const
{
return Pair<SVector3, SVector3>(SVector3(0, 0, 0), SVector3(0, 0, 0));
}
void secondDer(const SPoint2 ¶m,
SVector3 *dudu, SVector3 *dvdv, SVector3 *dudv) const{}
virtual SPoint2 getCoordinates(MVertex *v) const { return SPoint2(); }
void parametrize() const {}
int getNbSplit() const { return 0; }
};
#endif
#endif