mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-26 04:40:34 +05:00
export Polyhedra to Python and add test case
This commit is contained in:
parent
4cdaa6e3df
commit
1a051ec555
@ -355,6 +355,35 @@ When r tends to zero, the truncated elliptic cone tends to a full elliptic cone.
|
|||||||
However, when r = 0, the top part becomes a point(tip) and meshing fails!
|
However, when r = 0, the top part becomes a point(tip) and meshing fails!
|
||||||
)raw_string");
|
)raw_string");
|
||||||
|
|
||||||
|
m.def("Polyhedron", [](py::list points, py::list faces)
|
||||||
|
{
|
||||||
|
auto poly = new Polyhedra();
|
||||||
|
for(auto p : points)
|
||||||
|
poly->AddPoint(py::cast<Point<3>>(p));
|
||||||
|
int fnr = 0;
|
||||||
|
for(auto face : faces)
|
||||||
|
{
|
||||||
|
auto lface = py::cast<py::list>(face);
|
||||||
|
if(py::len(lface) == 3)
|
||||||
|
poly->AddFace(py::cast<int>(lface[0]),
|
||||||
|
py::cast<int>(lface[1]),
|
||||||
|
py::cast<int>(lface[2]),
|
||||||
|
fnr++);
|
||||||
|
else if(py::len(lface) == 4)
|
||||||
|
{
|
||||||
|
poly->AddFace(py::cast<int>(lface[0]),
|
||||||
|
py::cast<int>(lface[1]),
|
||||||
|
py::cast<int>(lface[2]),
|
||||||
|
fnr);
|
||||||
|
poly->AddFace(py::cast<int>(lface[0]),
|
||||||
|
py::cast<int>(lface[2]),
|
||||||
|
py::cast<int>(lface[3]),
|
||||||
|
fnr++);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return make_shared<SPSolid>(new Solid(poly));
|
||||||
|
});
|
||||||
|
|
||||||
m.def ("Or", FunctionPointer([](shared_ptr<SPSolid> s1, shared_ptr<SPSolid> s2)
|
m.def ("Or", FunctionPointer([](shared_ptr<SPSolid> s1, shared_ptr<SPSolid> s2)
|
||||||
{
|
{
|
||||||
return make_shared<SPSolid> (SPSolid::UNION, s1, s2);
|
return make_shared<SPSolid> (SPSolid::UNION, s1, s2);
|
||||||
|
27
tests/pytest/test_csg.py
Normal file
27
tests/pytest/test_csg.py
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
from netgen.csg import *
|
||||||
|
|
||||||
|
def test_2_polyhedra():
|
||||||
|
geo = CSGeometry()
|
||||||
|
first = Polyhedron([(0,0,0), (0,1,0), (3,1,0), (3,0,0),
|
||||||
|
(0,1,1), (3,1,1), (3,0,1), (0,0,1)],
|
||||||
|
[(0,1,2,3), (1,4,5,2), (2,5,6,3), (3,6,7,0),
|
||||||
|
(0,7,4,1), (7,6,5,4)])
|
||||||
|
# TODO: height = 0.1 not working!
|
||||||
|
height = 0.3
|
||||||
|
second = Polyhedron([(0,0,1), (0,1,1), (3,1,1), (3,0,1),
|
||||||
|
(0,1,1+height), (3,1,1+height),
|
||||||
|
(3,0,1+height), (0,0,1+height)],
|
||||||
|
[(0,1,2,3), (1,4,5,2), (2,5,6,3), (3,6,7,0),
|
||||||
|
(0,7,4,1), (7,6,5,4)])
|
||||||
|
|
||||||
|
geo.Add(first)
|
||||||
|
geo.Add(second)
|
||||||
|
Draw(geo)
|
||||||
|
mesh = geo.GenerateMesh()
|
||||||
|
return mesh
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
from ngsolve import Mesh, Draw
|
||||||
|
mesh = Mesh(test_2_polyhedra())
|
||||||
|
Draw(mesh)
|
Loading…
Reference in New Issue
Block a user