mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-13 14:40:35 +05:00
hex20 WIP
This commit is contained in:
parent
c0d0a3a1ab
commit
66ac2f1a4f
@ -43,10 +43,10 @@
|
|||||||
enum NG_ELEMENT_TYPE {
|
enum NG_ELEMENT_TYPE {
|
||||||
NG_PNT = 0,
|
NG_PNT = 0,
|
||||||
NG_SEGM = 1, NG_SEGM3 = 2,
|
NG_SEGM = 1, NG_SEGM3 = 2,
|
||||||
NG_TRIG = 10, NG_QUAD=11, NG_TRIG6 = 12, NG_QUAD6 = 13,
|
NG_TRIG = 10, NG_QUAD=11, NG_TRIG6 = 12, NG_QUAD6 = 13, NG_QUAD8 = 14,
|
||||||
NG_TET = 20, NG_TET10 = 21,
|
NG_TET = 20, NG_TET10 = 21,
|
||||||
NG_PYRAMID = 22, NG_PRISM = 23, NG_PRISM12 = 24,
|
NG_PYRAMID = 22, NG_PRISM = 23, NG_PRISM12 = 24,
|
||||||
NG_HEX = 25
|
NG_HEX = 25, NG_HEX20 = 26
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef double NG_POINT[3]; // coordinates
|
typedef double NG_POINT[3]; // coordinates
|
||||||
|
@ -17,10 +17,10 @@
|
|||||||
enum NG_ELEMENT_TYPE {
|
enum NG_ELEMENT_TYPE {
|
||||||
NG_PNT = 0,
|
NG_PNT = 0,
|
||||||
NG_SEGM = 1, NG_SEGM3 = 2,
|
NG_SEGM = 1, NG_SEGM3 = 2,
|
||||||
NG_TRIG = 10, NG_QUAD=11, NG_TRIG6 = 12, NG_QUAD6 = 13,
|
NG_TRIG = 10, NG_QUAD=11, NG_TRIG6 = 12, NG_QUAD6 = 13, NG_QUAD8 = 14,
|
||||||
NG_TET = 20, NG_TET10 = 21,
|
NG_TET = 20, NG_TET10 = 21,
|
||||||
NG_PYRAMID = 22, NG_PRISM = 23, NG_PRISM12 = 24,
|
NG_PYRAMID = 22, NG_PRISM = 23, NG_PRISM12 = 24,
|
||||||
NG_HEX = 25
|
NG_HEX = 25, NG_HEX20 = 26
|
||||||
};
|
};
|
||||||
|
|
||||||
enum NG_REFINEMENT_TYPE { NG_REFINE_H = 0, NG_REFINE_P = 1, NG_REFINE_HP = 2 };
|
enum NG_REFINEMENT_TYPE { NG_REFINE_H = 0, NG_REFINE_P = 1, NG_REFINE_HP = 2 };
|
||||||
|
@ -22,7 +22,7 @@ namespace netgen
|
|||||||
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,
|
||||||
PYRAMID = 22, PRISM = 23, PRISM12 = 24,
|
PYRAMID = 22, PRISM = 23, PRISM12 = 24,
|
||||||
HEX = 25
|
HEX = 25, HEX20 = 26
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -45,7 +45,7 @@ namespace netgen
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#define ELEMENT_MAXPOINTS 12
|
#define ELEMENT_MAXPOINTS 20
|
||||||
#define ELEMENT2D_MAXPOINTS 8
|
#define ELEMENT2D_MAXPOINTS 8
|
||||||
|
|
||||||
|
|
||||||
|
@ -263,6 +263,13 @@ DLL_HEADER void ExportNetgenMeshing(py::module &m)
|
|||||||
(*newel)[i] = py::extract<PointIndex>(vertices[i])();
|
(*newel)[i] = py::extract<PointIndex>(vertices[i])();
|
||||||
newel->SetIndex(index);
|
newel->SetIndex(index);
|
||||||
}
|
}
|
||||||
|
else if (py::len(vertices) == 20)
|
||||||
|
{
|
||||||
|
newel = new Element(HEX20);
|
||||||
|
for (int i = 0; i < 20; i++)
|
||||||
|
(*newel)[i] = py::extract<PointIndex>(vertices[i])();
|
||||||
|
newel->SetIndex(index);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
throw NgException ("cannot create element");
|
throw NgException ("cannot create element");
|
||||||
return newel;
|
return newel;
|
||||||
@ -316,6 +323,13 @@ DLL_HEADER void ExportNetgenMeshing(py::module &m)
|
|||||||
(*newel)[i] = py::extract<PointIndex>(vertices[i])();
|
(*newel)[i] = py::extract<PointIndex>(vertices[i])();
|
||||||
newel->SetIndex(index);
|
newel->SetIndex(index);
|
||||||
}
|
}
|
||||||
|
else if (py::len(vertices) == 8)
|
||||||
|
{
|
||||||
|
newel = new Element2d(QUAD8);
|
||||||
|
for(int i = 0; i<8; i++)
|
||||||
|
(*newel)[i] = py::extract<PointIndex>(vertices[i])();
|
||||||
|
newel->SetIndex(index);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
throw NgException("Inconsistent number of vertices in Element2D");
|
throw NgException("Inconsistent number of vertices in Element2D");
|
||||||
return newel;
|
return newel;
|
||||||
|
@ -219,6 +219,7 @@ inline short int MeshTopology :: GetNVertices (ELEMENT_TYPE et)
|
|||||||
return 6;
|
return 6;
|
||||||
|
|
||||||
case HEX:
|
case HEX:
|
||||||
|
case HEX20:
|
||||||
return 8;
|
return 8;
|
||||||
|
|
||||||
// default:
|
// default:
|
||||||
@ -244,9 +245,11 @@ inline short int MeshTopology :: GetNPoints (ELEMENT_TYPE et)
|
|||||||
|
|
||||||
case QUAD:
|
case QUAD:
|
||||||
case QUAD6:
|
case QUAD6:
|
||||||
case QUAD8:
|
|
||||||
return 4;
|
return 4;
|
||||||
|
|
||||||
|
case QUAD8:
|
||||||
|
return 8;
|
||||||
|
|
||||||
case TET:
|
case TET:
|
||||||
return 4;
|
return 4;
|
||||||
case TET10:
|
case TET10:
|
||||||
@ -262,6 +265,8 @@ inline short int MeshTopology :: GetNPoints (ELEMENT_TYPE et)
|
|||||||
case HEX:
|
case HEX:
|
||||||
return 8;
|
return 8;
|
||||||
|
|
||||||
|
case HEX20:
|
||||||
|
return 20;
|
||||||
// default:
|
// default:
|
||||||
// cerr << "Ng_ME_GetNVertices, illegal element type " << et << endl;
|
// cerr << "Ng_ME_GetNVertices, illegal element type " << et << endl;
|
||||||
}
|
}
|
||||||
@ -300,6 +305,7 @@ inline short int MeshTopology :: GetNEdges (ELEMENT_TYPE et)
|
|||||||
return 9;
|
return 9;
|
||||||
|
|
||||||
case HEX:
|
case HEX:
|
||||||
|
case HEX20:
|
||||||
return 12;
|
return 12;
|
||||||
default:
|
default:
|
||||||
return 0;
|
return 0;
|
||||||
@ -340,6 +346,7 @@ inline short int MeshTopology :: GetNFaces (ELEMENT_TYPE et)
|
|||||||
return 5;
|
return 5;
|
||||||
|
|
||||||
case HEX:
|
case HEX:
|
||||||
|
case HEX20:
|
||||||
return 6;
|
return 6;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -443,6 +450,7 @@ const ELEMENT_EDGE * MeshTopology :: GetEdges1 (ELEMENT_TYPE et)
|
|||||||
return prism_edges;
|
return prism_edges;
|
||||||
|
|
||||||
case HEX:
|
case HEX:
|
||||||
|
case HEX20:
|
||||||
return hex_edges;
|
return hex_edges;
|
||||||
// default:
|
// default:
|
||||||
// cerr << "Ng_ME_GetEdges, illegal element type " << et << endl;
|
// cerr << "Ng_ME_GetEdges, illegal element type " << et << endl;
|
||||||
@ -513,7 +521,7 @@ const ELEMENT_EDGE * MeshTopology :: GetEdges0 (ELEMENT_TYPE et)
|
|||||||
{ 2, 6 },
|
{ 2, 6 },
|
||||||
{ 3, 7 },
|
{ 3, 7 },
|
||||||
};
|
};
|
||||||
|
|
||||||
switch (et)
|
switch (et)
|
||||||
{
|
{
|
||||||
case SEGMENT:
|
case SEGMENT:
|
||||||
@ -541,6 +549,7 @@ const ELEMENT_EDGE * MeshTopology :: GetEdges0 (ELEMENT_TYPE et)
|
|||||||
return prism_edges;
|
return prism_edges;
|
||||||
|
|
||||||
case HEX:
|
case HEX:
|
||||||
|
case HEX20:
|
||||||
return hex_edges;
|
return hex_edges;
|
||||||
// default:
|
// default:
|
||||||
// cerr << "Ng_ME_GetEdges, illegal element type " << et << endl;
|
// cerr << "Ng_ME_GetEdges, illegal element type " << et << endl;
|
||||||
@ -627,6 +636,7 @@ inline const ELEMENT_FACE * MeshTopology :: GetFaces1 (ELEMENT_TYPE et)
|
|||||||
case SEGMENT3:
|
case SEGMENT3:
|
||||||
|
|
||||||
case HEX:
|
case HEX:
|
||||||
|
case HEX20:
|
||||||
return hex_faces;
|
return hex_faces;
|
||||||
|
|
||||||
// default:
|
// default:
|
||||||
@ -709,6 +719,7 @@ inline const ELEMENT_FACE * MeshTopology :: GetFaces0 (ELEMENT_TYPE et)
|
|||||||
case SEGMENT3:
|
case SEGMENT3:
|
||||||
|
|
||||||
case HEX:
|
case HEX:
|
||||||
|
case HEX20:
|
||||||
return hex_faces;
|
return hex_faces;
|
||||||
|
|
||||||
// default:
|
// default:
|
||||||
|
Loading…
Reference in New Issue
Block a user