mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-27 13:20:34 +05:00
__assume for switch (element_type)
This commit is contained in:
parent
b3451ed2e4
commit
1d6c7b283a
@ -35,6 +35,22 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __assume
|
||||||
|
#ifdef __GNUC__
|
||||||
|
#define __assume(cond) if (!(cond)) __builtin_unreachable(); else;
|
||||||
|
#else
|
||||||
|
#define __assume(cond)
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define noDEMOVERSION
|
#define noDEMOVERSION
|
||||||
#define noDEVELOP
|
#define noDEVELOP
|
||||||
#define noSTEP
|
#define noSTEP
|
||||||
|
@ -251,7 +251,11 @@ namespace netgen
|
|||||||
|
|
||||||
namespace netgen
|
namespace netgen
|
||||||
{
|
{
|
||||||
|
#ifdef __GNUC__
|
||||||
|
#define NGX_INLINE __attribute__ ((__always_inline__)) inline
|
||||||
|
#else
|
||||||
#define NGX_INLINE inline
|
#define NGX_INLINE inline
|
||||||
|
#endif
|
||||||
#include <nginterface_v2_impl.hpp>
|
#include <nginterface_v2_impl.hpp>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,6 +114,7 @@ NGX_INLINE DLL_HEADER Ng_Element Ngx_Mesh :: GetElement<3> (int nr) const
|
|||||||
Ng_Element ret;
|
Ng_Element ret;
|
||||||
ret.type = NG_ELEMENT_TYPE(el.GetType());
|
ret.type = NG_ELEMENT_TYPE(el.GetType());
|
||||||
ret.index = el.GetIndex();
|
ret.index = el.GetIndex();
|
||||||
|
|
||||||
ret.points.num = el.GetNP();
|
ret.points.num = el.GetNP();
|
||||||
ret.points.ptr = (int*)&el[0];
|
ret.points.ptr = (int*)&el[0];
|
||||||
|
|
||||||
@ -126,8 +127,6 @@ NGX_INLINE DLL_HEADER Ng_Element Ngx_Mesh :: GetElement<3> (int nr) const
|
|||||||
ret.faces.num = MeshTopology::GetNFaces (el.GetType());
|
ret.faces.num = MeshTopology::GetNFaces (el.GetType());
|
||||||
ret.faces.ptr = (T_FACE2*)mesh->GetTopology().GetElementFacesPtr (nr);
|
ret.faces.ptr = (T_FACE2*)mesh->GetTopology().GetElementFacesPtr (nr);
|
||||||
|
|
||||||
// ret.is_curved = mesh->GetCurvedElements().IsElementCurved(nr);
|
|
||||||
ret.is_curved = el.IsCurved();
|
ret.is_curved = el.IsCurved();
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -100,7 +100,7 @@ namespace netgen
|
|||||||
mutable int elementsearchtreets;
|
mutable int elementsearchtreets;
|
||||||
|
|
||||||
/// element -> face, element -> edge etc ...
|
/// element -> face, element -> edge etc ...
|
||||||
class MeshTopology * topology;
|
MeshTopology * topology;
|
||||||
/// methods for high order elements
|
/// methods for high order elements
|
||||||
class CurvedElements * curvedelems;
|
class CurvedElements * curvedelems;
|
||||||
|
|
||||||
@ -655,19 +655,19 @@ namespace netgen
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
DLL_HEADER bool PureTrigMesh (int faceindex = 0) const;
|
DLL_HEADER bool PureTrigMesh (int faceindex = 0) const;
|
||||||
DLL_HEADER bool PureTetMesh () const;
|
DLL_HEADER bool PureTetMesh () const;
|
||||||
|
|
||||||
|
|
||||||
const class MeshTopology & GetTopology () const
|
const MeshTopology & GetTopology () const
|
||||||
{ return *topology; }
|
{ return *topology; }
|
||||||
|
|
||||||
DLL_HEADER void UpdateTopology();
|
DLL_HEADER void UpdateTopology();
|
||||||
|
|
||||||
class CurvedElements & GetCurvedElements () const
|
class CurvedElements & GetCurvedElements () const
|
||||||
{ return *curvedelems; }
|
{ return *curvedelems; }
|
||||||
|
|
||||||
DLL_HEADER void BuildCurvedElements (const class Refinement * ref, int aorder, bool arational = false);
|
DLL_HEADER void BuildCurvedElements (const class Refinement * ref, int aorder, bool arational = false);
|
||||||
|
|
||||||
const class AnisotropicClusters & GetClusters () const
|
const class AnisotropicClusters & GetClusters () const
|
||||||
{ return *clusters; }
|
{ return *clusters; }
|
||||||
|
@ -22,6 +22,7 @@ namespace netgen
|
|||||||
#include "msghandler.hpp"
|
#include "msghandler.hpp"
|
||||||
#include "meshtype.hpp"
|
#include "meshtype.hpp"
|
||||||
#include "localh.hpp"
|
#include "localh.hpp"
|
||||||
|
#include "topology.hpp"
|
||||||
#include "meshclass.hpp"
|
#include "meshclass.hpp"
|
||||||
#include "global.hpp"
|
#include "global.hpp"
|
||||||
|
|
||||||
@ -48,7 +49,6 @@ namespace netgen
|
|||||||
#include "findip.hpp"
|
#include "findip.hpp"
|
||||||
#include "findip2.hpp"
|
#include "findip2.hpp"
|
||||||
|
|
||||||
#include "topology.hpp"
|
|
||||||
#include "curvedelems.hpp"
|
#include "curvedelems.hpp"
|
||||||
#include "clusters.hpp"
|
#include "clusters.hpp"
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ namespace netgen
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
enum ELEMENT_TYPE {
|
enum ELEMENT_TYPE : unsigned char {
|
||||||
SEGMENT = 1, SEGMENT3 = 2,
|
SEGMENT = 1, SEGMENT3 = 2,
|
||||||
TRIG = 10, QUAD=11, TRIG6 = 12, QUAD6 = 13, QUAD8 = 14,
|
TRIG = 10, QUAD=11, TRIG6 = 12, QUAD6 = 13, QUAD8 = 14,
|
||||||
TET = 20, TET10 = 21,
|
TET = 20, TET10 = 21,
|
||||||
@ -292,7 +292,7 @@ namespace netgen
|
|||||||
/// surface nr
|
/// surface nr
|
||||||
int index:16;
|
int index:16;
|
||||||
///
|
///
|
||||||
ELEMENT_TYPE typ:6;
|
ELEMENT_TYPE typ;
|
||||||
/// number of points
|
/// number of points
|
||||||
unsigned int np:4;
|
unsigned int np:4;
|
||||||
bool badel:1;
|
bool badel:1;
|
||||||
@ -545,7 +545,7 @@ namespace netgen
|
|||||||
/// point numbers
|
/// point numbers
|
||||||
PointIndex pnum[ELEMENT_MAXPOINTS];
|
PointIndex pnum[ELEMENT_MAXPOINTS];
|
||||||
///
|
///
|
||||||
ELEMENT_TYPE typ:6;
|
ELEMENT_TYPE typ;
|
||||||
/// number of points (4..tet, 5..pyramid, 6..prism, 8..hex, 10..quad tet, 12..quad prism)
|
/// number of points (4..tet, 5..pyramid, 6..prism, 8..hex, 10..quad tet, 12..quad prism)
|
||||||
int np:5;
|
int np:5;
|
||||||
///
|
///
|
||||||
@ -601,27 +601,27 @@ namespace netgen
|
|||||||
///
|
///
|
||||||
int GetNP () const { return np; }
|
int GetNP () const { return np; }
|
||||||
///
|
///
|
||||||
int GetNV() const
|
short int GetNV() const
|
||||||
{
|
{
|
||||||
|
__assume(typ >= TET && typ <= HEX);
|
||||||
switch (typ)
|
switch (typ)
|
||||||
{
|
{
|
||||||
case TET:
|
case TET:
|
||||||
case TET10:
|
case TET10:
|
||||||
return 4;
|
return 4;
|
||||||
case PRISM12:
|
case PRISM12:
|
||||||
case PRISM:
|
case PRISM:
|
||||||
return 6;
|
return 6;
|
||||||
case PYRAMID:
|
case PYRAMID:
|
||||||
return 5;
|
return 5;
|
||||||
case HEX:
|
case HEX:
|
||||||
return 8;
|
return 8;
|
||||||
default:
|
default: // not a 3D element
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
PrintSysError ("Element3d::GetNV not implemented for typ ", typ)
|
PrintSysError ("Element3d::GetNV not implemented for typ ", typ)
|
||||||
#endif
|
#endif
|
||||||
;
|
return -1;
|
||||||
}
|
}
|
||||||
return np;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator==(const Element & el2) const;
|
bool operator==(const Element & el2) const;
|
||||||
|
@ -12,7 +12,9 @@
|
|||||||
(Elements, Faces, Edges, Vertices
|
(Elements, Faces, Edges, Vertices
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
namespace netgen
|
||||||
|
{
|
||||||
|
|
||||||
struct T_EDGE
|
struct T_EDGE
|
||||||
{
|
{
|
||||||
int orient:1;
|
int orient:1;
|
||||||
@ -67,30 +69,22 @@ public:
|
|||||||
int GetNEdges () const { return edge2vert.Size(); }
|
int GetNEdges () const { return edge2vert.Size(); }
|
||||||
int GetNFaces () const { return face2vert.Size(); }
|
int GetNFaces () const { return face2vert.Size(); }
|
||||||
|
|
||||||
static inline int GetNVertices (ELEMENT_TYPE et);
|
static inline short int GetNVertices (ELEMENT_TYPE et);
|
||||||
static inline int GetNPoints (ELEMENT_TYPE et);
|
static inline short int GetNPoints (ELEMENT_TYPE et);
|
||||||
static inline int GetNEdges (ELEMENT_TYPE et);
|
static inline short int GetNEdges (ELEMENT_TYPE et);
|
||||||
static inline int GetNFaces (ELEMENT_TYPE et);
|
static inline short int GetNFaces (ELEMENT_TYPE et);
|
||||||
|
|
||||||
static const Point3d * GetVertices (ELEMENT_TYPE et);
|
static const Point3d * GetVertices (ELEMENT_TYPE et);
|
||||||
inline static const ELEMENT_EDGE * GetEdges1 (ELEMENT_TYPE et);
|
inline static const ELEMENT_EDGE * GetEdges1 (ELEMENT_TYPE et);
|
||||||
inline static const ELEMENT_EDGE * GetEdges0 (ELEMENT_TYPE et);
|
inline static const ELEMENT_EDGE * GetEdges0 (ELEMENT_TYPE et);
|
||||||
inline static const ELEMENT_FACE * GetFaces1 (ELEMENT_TYPE et);
|
inline static const ELEMENT_FACE * GetFaces1 (ELEMENT_TYPE et);
|
||||||
inline static const ELEMENT_FACE * GetFaces0 (ELEMENT_TYPE et);
|
inline static const ELEMENT_FACE * GetFaces0 (ELEMENT_TYPE et);
|
||||||
|
|
||||||
|
|
||||||
// int GetSegmentEdge (int segnr) const { return abs(segedges[segnr-1]); }
|
|
||||||
// int GetSegmentEdgeOrientation (int segnr) const { return sgn(segedges[segnr-1]); }
|
|
||||||
// int GetEdge (SegmentIndex segnr) const { return abs(segedges[segnr])-1; }
|
|
||||||
int GetSegmentEdge (int segnr) const { return segedges[segnr-1].nr+1; }
|
int GetSegmentEdge (int segnr) const { return segedges[segnr-1].nr+1; }
|
||||||
int GetEdge (SegmentIndex segnr) const { return segedges[segnr].nr; }
|
int GetEdge (SegmentIndex segnr) const { return segedges[segnr].nr; }
|
||||||
|
|
||||||
void GetSegmentEdge (int segnr, int & enr, int & orient) const
|
void GetSegmentEdge (int segnr, int & enr, int & orient) const
|
||||||
{
|
{
|
||||||
/*
|
|
||||||
enr = abs(segedges.Get(segnr));
|
|
||||||
orient = segedges.Get(segnr) > 0 ? 1 : -1;
|
|
||||||
*/
|
|
||||||
enr = segedges.Get(segnr).nr+1;
|
enr = segedges.Get(segnr).nr+1;
|
||||||
orient = segedges.Get(segnr).orient;
|
orient = segedges.Get(segnr).orient;
|
||||||
}
|
}
|
||||||
@ -160,7 +154,7 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
inline int MeshTopology :: GetNVertices (ELEMENT_TYPE et)
|
inline short int MeshTopology :: GetNVertices (ELEMENT_TYPE et)
|
||||||
{
|
{
|
||||||
switch (et)
|
switch (et)
|
||||||
{
|
{
|
||||||
@ -198,7 +192,7 @@ inline int MeshTopology :: GetNVertices (ELEMENT_TYPE et)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
inline int MeshTopology :: GetNPoints (ELEMENT_TYPE et)
|
inline short int MeshTopology :: GetNPoints (ELEMENT_TYPE et)
|
||||||
{
|
{
|
||||||
switch (et)
|
switch (et)
|
||||||
{
|
{
|
||||||
@ -240,8 +234,9 @@ inline int MeshTopology :: GetNPoints (ELEMENT_TYPE et)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
inline int MeshTopology :: GetNEdges (ELEMENT_TYPE et)
|
inline short int MeshTopology :: GetNEdges (ELEMENT_TYPE et)
|
||||||
{
|
{
|
||||||
|
__assume(et >= SEGMENT && et <= HEX);
|
||||||
switch (et)
|
switch (et)
|
||||||
{
|
{
|
||||||
case SEGMENT:
|
case SEGMENT:
|
||||||
@ -270,16 +265,18 @@ inline int MeshTopology :: GetNEdges (ELEMENT_TYPE et)
|
|||||||
|
|
||||||
case HEX:
|
case HEX:
|
||||||
return 12;
|
return 12;
|
||||||
|
default:
|
||||||
|
return 0;
|
||||||
// default:
|
// default:
|
||||||
// cerr << "Ng_ME_GetNEdges, illegal element type " << et << endl;
|
// cerr << "Ng_ME_GetNEdges, illegal element type " << et << endl;
|
||||||
}
|
}
|
||||||
return 0;
|
// return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
inline int MeshTopology :: GetNFaces (ELEMENT_TYPE et)
|
inline short int MeshTopology :: GetNFaces (ELEMENT_TYPE et)
|
||||||
{
|
{
|
||||||
|
__assume(et >= SEGMENT && et <= HEX);
|
||||||
switch (et)
|
switch (et)
|
||||||
{
|
{
|
||||||
case SEGMENT:
|
case SEGMENT:
|
||||||
@ -309,10 +306,11 @@ inline int MeshTopology :: GetNFaces (ELEMENT_TYPE et)
|
|||||||
case HEX:
|
case HEX:
|
||||||
return 6;
|
return 6;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return -99;
|
||||||
// default:
|
// default:
|
||||||
// cerr << "Ng_ME_GetNVertices, illegal element type " << et << endl;
|
// cerr << "Ng_ME_GetNVertices, illegal element type " << et << endl;
|
||||||
}
|
}
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -683,24 +681,6 @@ inline const ELEMENT_FACE * MeshTopology :: GetFaces0 (ELEMENT_TYPE et)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user