1
0
mirror of https://github.com/NGSolve/netgen.git synced 2025-01-18 08:50:33 +05:00
netgen/libsrc/csg/identify.hpp

214 lines
7.1 KiB
C++
Raw Normal View History

2009-01-13 04:40:13 +05:00
#ifndef FILE_IDENTIFY
#define FILE_IDENTIFY
/**************************************************************************/
/* File: identify.hh */
/* Author: Joachim Schoeberl */
/* Date: 1. Aug. 99 */
2009-09-07 17:50:13 +06:00
/**************************************************************************/
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
namespace netgen
2009-01-13 04:40:13 +05:00
{
2009-09-07 17:50:13 +06:00
/**
Identify surfaces for periodic b.c. or
thin domains
*/
class SpecialPoint;
class Identification
{
protected:
const CSGeometry & geom;
// identified faces, index sorted
INDEX_2_HASHTABLE<int> identfaces;
int nr;
public:
DLL_HEADER Identification (int anr, const CSGeometry & ageom);
DLL_HEADER virtual ~Identification ();
DLL_HEADER virtual void Print (ostream & ost) const = 0;
DLL_HEADER virtual void GetData (ostream & ost) const = 0;
2009-09-07 17:50:13 +06:00
/// obsolete
// virtual void IdentifySpecialPoints (Array<class SpecialPoint> & points);
/// can identify both special points (fixed direction)
/// (identified points, same tangent)
virtual int Identifyable (const SpecialPoint & sp1, const SpecialPoint & sp2,
const TABLE<int> & specpoint2solid,
const TABLE<int> & specpoint2surface) const;
///
virtual int Identifyable (const Point<3> & p1, const Point<3> & sp2) const;
/// is it possible to identify sp1 with some other ?
virtual int IdentifyableCandidate (const SpecialPoint & sp1) const;
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
/// are points (if connected) by a short edge (direction anyhow) ?
virtual int ShortEdge (const SpecialPoint & sp1, const SpecialPoint & sp2) const;
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
/// add entries in mesh identification tables
virtual void IdentifyPoints (class Mesh & mesh);
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
/// add entries to identified faces (based on segment infos)
virtual void IdentifyFaces (class Mesh & mesh);
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
/// get point on other surface, add entry in mesh identifications
virtual int GetIdentifiedPoint (class Mesh & mesh, int pi1);
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
/// copy surfaces, or fill rectangles
virtual void BuildSurfaceElements (Array<class Segment> & segs,
class Mesh & mesh,
const Surface * surf);
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
/// insert volume elements in thin layers
virtual void BuildVolumeElements (Array<class Element2d> & surfels,
class Mesh & mesh);
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
/// get list of identified faces
virtual void GetIdentifiedFaces (Array<INDEX_2> & idfaces) const;
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
friend ostream & operator<< (ostream & ost, Identification & ident);
};
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
class PeriodicIdentification : public Identification
{
const Surface * s1;
const Surface * s2;
Transformation<3> trafo; // from s1 to s2
Transformation<3> inv_trafo; // from s2 to s1
2009-09-07 17:50:13 +06:00
public:
PeriodicIdentification (int anr,
const CSGeometry & ageom,
const Surface * as1,
const Surface * as2,
Transformation<3> atrafo = Vec<3>(0,0,0));
2018-03-11 20:27:58 +05:00
virtual ~PeriodicIdentification () override;
virtual void Print (ostream & ost) const override;
virtual void GetData (ostream & ost) const override;
2009-09-07 17:50:13 +06:00
// virtual void IdentifySpecialPoints (Array<class SpecialPoint> & points);
virtual int Identifyable (const SpecialPoint & sp1, const SpecialPoint & sp2,
const TABLE<int> & specpoint2solid,
2018-03-11 20:27:58 +05:00
const TABLE<int> & specpoint2surface) const override;
2009-09-07 17:50:13 +06:00
2018-03-11 20:27:58 +05:00
virtual int Identifyable (const Point<3> & p1, const Point<3> & sp2) const override;
virtual int GetIdentifiedPoint (class Mesh & mesh, int pi1) override;
virtual void IdentifyPoints (class Mesh & mesh) override;
virtual void IdentifyFaces (class Mesh & mesh) override;
2009-09-07 17:50:13 +06:00
virtual void BuildSurfaceElements (Array<class Segment> & segs,
class Mesh & mesh,
2018-03-11 20:27:58 +05:00
const Surface * surf) override;
2009-09-07 17:50:13 +06:00
};
2009-01-13 04:40:13 +05:00
///
2009-09-07 17:50:13 +06:00
class TopLevelObject;
class CloseSurfaceIdentification : public Identification
{
const Surface * s1;
const Surface * s2;
const TopLevelObject * domain;
///
int dom_nr;
/// number of refinement levels (in Z-refinement)
int ref_levels;
/// number of refinement levels for layer next to s1 (in Z-refinement)
int ref_levels_s1;
/// number of refinement levels for layer next to s2 (in Z-refinement)
int ref_levels_s2;
///
double eps_n;
Array<double> slices;
/// used only for domain-local identification:
Array<int> domain_surfaces;
///
bool dom_surf_valid;
///
Vec<3> direction;
///
bool usedirection;
public:
CloseSurfaceIdentification (int anr,
const CSGeometry & ageom,
const Surface * as1,
const Surface * as2,
const TopLevelObject * adomain,
const Flags & flags);
virtual ~CloseSurfaceIdentification ();
virtual void Print (ostream & ost) const;
virtual void GetData (ostream & ost) const;
// virtual void IdentifySpecialPoints (Array<class SpecialPoint> & points);
virtual int Identifyable (const SpecialPoint & sp1, const SpecialPoint & sp2,
const TABLE<int> & specpoint2solid,
const TABLE<int> & specpoint2surface) const;
virtual int Identifyable (const Point<3> & p1, const Point<3> & sp2) const;
virtual int IdentifyableCandidate (const SpecialPoint & sp1) const;
virtual int ShortEdge (const SpecialPoint & sp1, const SpecialPoint & sp2) const;
virtual int GetIdentifiedPoint (class Mesh & mesh, int pi1);
const Array<double> & GetSlices () const { return slices; }
virtual void IdentifyPoints (class Mesh & mesh);
virtual void IdentifyFaces (class Mesh & mesh);
virtual void BuildSurfaceElements (Array<class Segment> & segs,
class Mesh & mesh,
const Surface * surf);
void BuildSurfaceElements2 (Array<class Segment> & segs,
class Mesh & mesh,
const Surface * surf);
virtual void BuildVolumeElements (Array<class Element2d> & surfels,
class Mesh & mesh);
int RefLevels () const { return ref_levels; }
int RefLevels1 () const { return ref_levels_s1; }
int RefLevels2 () const { return ref_levels_s2; }
bool IsSkewIdentification(void) const {return usedirection;}
const Vec<3> & GetDirection(void) const {return direction;}
const Surface & GetSurface1(void) const
{ return *s1;}
const Surface & GetSurface2(void) const
{ return *s2;}
};
class CloseEdgesIdentification : public Identification
{
const Surface * facet;
const Surface * s1;
const Surface * s2;
public:
CloseEdgesIdentification (int anr,
2009-01-13 04:40:13 +05:00
const CSGeometry & ageom,
2009-09-07 17:50:13 +06:00
const Surface * afacet,
2009-01-13 04:40:13 +05:00
const Surface * as1,
2009-09-07 17:50:13 +06:00
const Surface * as2);
virtual ~CloseEdgesIdentification ();
virtual void Print (ostream & ost) const;
virtual void GetData (ostream & ost) const;
// virtual void IdentifySpecialPoints (Array<class SpecialPoint> & points);
virtual int Identifyable (const SpecialPoint & sp1, const SpecialPoint & sp2,
const TABLE<int> & specpoint2solid,
const TABLE<int> & specpoint2surface) const;
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
virtual void IdentifyPoints (class Mesh & mesh);
virtual void BuildSurfaceElements (Array<class Segment> & segs,
class Mesh & mesh,
const Surface * surf);
};
2009-01-13 04:40:13 +05:00
2009-09-07 17:50:13 +06:00
}
2009-01-13 04:40:13 +05:00
#endif