mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-13 22:50:33 +05:00
python wrapper for mesh manipulation
This commit is contained in:
parent
c66057853e
commit
10e4a596f6
@ -243,6 +243,9 @@ namespace netgen
|
|||||||
const Segment & operator[] (SegmentIndex si) const { return segments[si]; }
|
const Segment & operator[] (SegmentIndex si) const { return segments[si]; }
|
||||||
Segment & operator[] (SegmentIndex si) { return segments[si]; }
|
Segment & operator[] (SegmentIndex si) { return segments[si]; }
|
||||||
|
|
||||||
|
const Array<Segment> & LineSegments() const { return segments; }
|
||||||
|
Array<Segment> & LineSegments() { return segments; }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -52,6 +52,27 @@ DLL_HEADER void ExportNetgenMeshing()
|
|||||||
.add_property("nr", &PointIndex::operator int)
|
.add_property("nr", &PointIndex::operator int)
|
||||||
;
|
;
|
||||||
|
|
||||||
|
bp::class_<ElementIndex>("ElementId3D", bp::init<int>())
|
||||||
|
.def("__repr__", &ToString<ElementIndex>)
|
||||||
|
.def("__str__", &ToString<ElementIndex>)
|
||||||
|
.add_property("nr", &ElementIndex::operator int)
|
||||||
|
;
|
||||||
|
|
||||||
|
|
||||||
|
bp::class_<SurfaceElementIndex>("ElementId2D", bp::init<int>())
|
||||||
|
.def("__repr__", &ToString<SurfaceElementIndex>)
|
||||||
|
.def("__str__", &ToString<SurfaceElementIndex>)
|
||||||
|
.add_property("nr", &SurfaceElementIndex::operator int)
|
||||||
|
;
|
||||||
|
|
||||||
|
bp::class_<SegmentIndex>("ElementId1D", bp::init<int>())
|
||||||
|
.def("__repr__", &ToString<SegmentIndex>)
|
||||||
|
.def("__str__", &ToString<SegmentIndex>)
|
||||||
|
.add_property("nr", &SegmentIndex::operator int)
|
||||||
|
;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
bp::class_<Point<3>> ("Point")
|
bp::class_<Point<3>> ("Point")
|
||||||
.def(bp::init<double,double,double>())
|
.def(bp::init<double,double,double>())
|
||||||
@ -59,7 +80,9 @@ DLL_HEADER void ExportNetgenMeshing()
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
bp::class_<MeshPoint /* ,bp::bases<Point<3>> */ >("MeshPoint")
|
bp::class_<MeshPoint /* ,bp::bases<Point<3>> */ >("MeshPoint")
|
||||||
// .def(bp::init<Point<3>>())
|
.def(bp::init<Point<3>>())
|
||||||
|
.def("__str__", &ToString<MeshPoint>)
|
||||||
|
.def("__repr__", &ToString<MeshPoint>)
|
||||||
.add_property("p", FunctionPointer([](const MeshPoint & self)
|
.add_property("p", FunctionPointer([](const MeshPoint & self)
|
||||||
{
|
{
|
||||||
bp::list l;
|
bp::list l;
|
||||||
@ -71,6 +94,20 @@ DLL_HEADER void ExportNetgenMeshing()
|
|||||||
;
|
;
|
||||||
|
|
||||||
bp::class_<Element>("Element3D")
|
bp::class_<Element>("Element3D")
|
||||||
|
.def("__init__", bp::make_constructor
|
||||||
|
(FunctionPointer ([](int index, bp::list vertices)
|
||||||
|
{
|
||||||
|
Element * tmp = new Element(TET);
|
||||||
|
for (int i = 0; i < 4; i++)
|
||||||
|
(*tmp)[i] = bp::extract<PointIndex>(vertices[i]);
|
||||||
|
tmp->SetIndex(index);
|
||||||
|
return tmp;
|
||||||
|
}),
|
||||||
|
bp::default_call_policies(), // need it to use arguments
|
||||||
|
(bp::arg("index")=1,bp::arg("vertices"))),
|
||||||
|
"create volume element"
|
||||||
|
)
|
||||||
|
.def("__repr__", &ToString<Element>)
|
||||||
.add_property("index", &Element::GetIndex, &Element::SetIndex)
|
.add_property("index", &Element::GetIndex, &Element::SetIndex)
|
||||||
.add_property("vertices",
|
.add_property("vertices",
|
||||||
FunctionPointer ([](const Element & self) -> bp::list
|
FunctionPointer ([](const Element & self) -> bp::list
|
||||||
@ -83,6 +120,19 @@ DLL_HEADER void ExportNetgenMeshing()
|
|||||||
;
|
;
|
||||||
|
|
||||||
bp::class_<Element2d>("Element2D")
|
bp::class_<Element2d>("Element2D")
|
||||||
|
.def("__init__", bp::make_constructor
|
||||||
|
(FunctionPointer ([](int index, bp::list vertices)
|
||||||
|
{
|
||||||
|
Element2d * tmp = new Element2d(TRIG);
|
||||||
|
for (int i = 0; i < 3; i++)
|
||||||
|
(*tmp)[i] = bp::extract<PointIndex>(vertices[i]);
|
||||||
|
tmp->SetIndex(index);
|
||||||
|
return tmp;
|
||||||
|
}),
|
||||||
|
bp::default_call_policies(), // need it to use arguments
|
||||||
|
(bp::arg("index")=1,bp::arg("vertices"))),
|
||||||
|
"create surface element"
|
||||||
|
)
|
||||||
.add_property("index", &Element2d::GetIndex, &Element2d::SetIndex)
|
.add_property("index", &Element2d::GetIndex, &Element2d::SetIndex)
|
||||||
.add_property("vertices",
|
.add_property("vertices",
|
||||||
FunctionPointer([](const Element2d & self) -> bp::list
|
FunctionPointer([](const Element2d & self) -> bp::list
|
||||||
@ -93,9 +143,59 @@ DLL_HEADER void ExportNetgenMeshing()
|
|||||||
return li;
|
return li;
|
||||||
}))
|
}))
|
||||||
;
|
;
|
||||||
|
|
||||||
|
bp::class_<Segment>("Element1D")
|
||||||
|
.def("__init__", bp::make_constructor
|
||||||
|
(FunctionPointer ([](bp::list vertices, bp::list surfaces)
|
||||||
|
{
|
||||||
|
Segment * tmp = new Segment;
|
||||||
|
for (int i = 0; i < 2; i++)
|
||||||
|
(*tmp)[i] = bp::extract<PointIndex>(vertices[i]);
|
||||||
|
|
||||||
|
tmp->surfnr1 = bp::extract<int>(surfaces[0]);
|
||||||
|
tmp->surfnr2 = bp::extract<int>(surfaces[1]);
|
||||||
|
return tmp;
|
||||||
|
}),
|
||||||
|
bp::default_call_policies(),
|
||||||
|
(bp::arg("vertices"),bp::arg("surfaces"))),
|
||||||
|
"create segment element"
|
||||||
|
)
|
||||||
|
.def("__repr__", &ToString<Element>)
|
||||||
|
.add_property("vertices",
|
||||||
|
FunctionPointer ([](const Segment & self) -> bp::list
|
||||||
|
{
|
||||||
|
bp::list li;
|
||||||
|
for (int i = 0; i < 2; i++)
|
||||||
|
li.append (self[i]);
|
||||||
|
return li;
|
||||||
|
}))
|
||||||
|
.add_property("surfaces",
|
||||||
|
FunctionPointer ([](const Segment & self) -> bp::list
|
||||||
|
{
|
||||||
|
bp::list li;
|
||||||
|
li.append (self.surfnr1);
|
||||||
|
li.append (self.surfnr2);
|
||||||
|
return li;
|
||||||
|
}))
|
||||||
|
;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
bp::class_<FaceDescriptor>("FaceDescriptor")
|
||||||
|
.def(bp::init<const FaceDescriptor&>())
|
||||||
|
.def("__str__", &ToString<FaceDescriptor>)
|
||||||
|
.def("__repr__", &ToString<FaceDescriptor>)
|
||||||
|
.add_property("surfnr", &FaceDescriptor::SurfNr, &FaceDescriptor::SetSurfNr)
|
||||||
|
;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ExportArray<Element>();
|
ExportArray<Element>();
|
||||||
ExportArray<Element2d>();
|
ExportArray<Element2d>();
|
||||||
|
ExportArray<Segment>();
|
||||||
ExportArray<MeshPoint,PointIndex::BASE,PointIndex>();
|
ExportArray<MeshPoint,PointIndex::BASE,PointIndex>();
|
||||||
|
ExportArray<FaceDescriptor>();
|
||||||
;
|
;
|
||||||
|
|
||||||
|
|
||||||
@ -128,10 +228,17 @@ DLL_HEADER void ExportNetgenMeshing()
|
|||||||
static_cast<Array<Element2d>&(Mesh::*)()> (&Mesh::SurfaceElements),
|
static_cast<Array<Element2d>&(Mesh::*)()> (&Mesh::SurfaceElements),
|
||||||
bp::return_value_policy<bp::reference_existing_object>())
|
bp::return_value_policy<bp::reference_existing_object>())
|
||||||
|
|
||||||
|
.def("Elements1D",
|
||||||
|
static_cast<Array<Segment>&(Mesh::*)()> (&Mesh::LineSegments),
|
||||||
|
bp::return_value_policy<bp::reference_existing_object>())
|
||||||
|
|
||||||
|
|
||||||
.def("Points",
|
.def("Points",
|
||||||
static_cast<Mesh::T_POINTS&(Mesh::*)()> (&Mesh::Points),
|
static_cast<Mesh::T_POINTS&(Mesh::*)()> (&Mesh::Points),
|
||||||
bp::return_value_policy<bp::reference_existing_object>())
|
bp::return_value_policy<bp::reference_existing_object>())
|
||||||
|
|
||||||
|
.def("FaceDescriptor", static_cast<FaceDescriptor&(Mesh::*)(int)> (&Mesh::GetFaceDescriptor),
|
||||||
|
bp::return_value_policy<bp::reference_existing_object>())
|
||||||
|
|
||||||
.def("__getitem__", FunctionPointer ([](const Mesh & self, PointIndex pi)
|
.def("__getitem__", FunctionPointer ([](const Mesh & self, PointIndex pi)
|
||||||
{
|
{
|
||||||
@ -142,6 +249,27 @@ DLL_HEADER void ExportNetgenMeshing()
|
|||||||
{
|
{
|
||||||
return self.AddPoint (Point3d(p));
|
return self.AddPoint (Point3d(p));
|
||||||
}))
|
}))
|
||||||
|
|
||||||
|
.def ("Add", FunctionPointer ([](Mesh & self, const Element & el)
|
||||||
|
{
|
||||||
|
return self.AddVolumeElement (el);
|
||||||
|
}))
|
||||||
|
|
||||||
|
.def ("Add", FunctionPointer ([](Mesh & self, const Element2d & el)
|
||||||
|
{
|
||||||
|
return self.AddSurfaceElement (el);
|
||||||
|
}))
|
||||||
|
|
||||||
|
.def ("Add", FunctionPointer ([](Mesh & self, const Segment & el)
|
||||||
|
{
|
||||||
|
return self.AddSegment (el);
|
||||||
|
}))
|
||||||
|
|
||||||
|
.def ("Add", FunctionPointer ([](Mesh & self, const FaceDescriptor & fd)
|
||||||
|
{
|
||||||
|
return self.AddFaceDescriptor (fd);
|
||||||
|
}))
|
||||||
|
|
||||||
/*
|
/*
|
||||||
.def("__init__", bp::make_constructor
|
.def("__init__", bp::make_constructor
|
||||||
(FunctionPointer ([]()
|
(FunctionPointer ([]()
|
||||||
|
Loading…
Reference in New Issue
Block a user