From 89c33f5b288225c17a2627e270e37919cbcd7682 Mon Sep 17 00:00:00 2001 From: Matthias Hochsteger Date: Tue, 25 Aug 2020 10:59:48 +0200 Subject: [PATCH] csg2d GenerateMesh in Python, fix arguments for Rectangle/Circle --- libsrc/geom2d/python_geom2d.cpp | 34 ++++++++++++++++++++++++++------- 1 file changed, 27 insertions(+), 7 deletions(-) diff --git a/libsrc/geom2d/python_geom2d.cpp b/libsrc/geom2d/python_geom2d.cpp index b44d44df..aa3b77c4 100644 --- a/libsrc/geom2d/python_geom2d.cpp +++ b/libsrc/geom2d/python_geom2d.cpp @@ -373,9 +373,8 @@ DLL_HEADER void ExportGeom2d(py::module &m) }) ) - // If we change to c++17 this can become optional .def("GenerateMesh", [](shared_ptr self, - MeshingParameters* pars, py::kwargs kwargs) + optional pars, py::kwargs kwargs) { MeshingParameters mp; if(pars) mp = *pars; @@ -391,7 +390,7 @@ DLL_HEADER void ExportGeom2d(py::module &m) if(result != 0) throw Exception("Meshing failed!"); return mesh; - }, py::arg("mp") = nullptr, + }, py::arg("mp") = nullopt, py::call_guard(), meshingparameter_description.c_str()) .def("_SetDomainTensorMeshing", &SplineGeometry2d::SetDomainTensorMeshing) @@ -423,19 +422,40 @@ DLL_HEADER void ExportGeom2d(py::module &m) self.RotateDeg(*deg, center); return self; }, py::arg("rad")=nullopt, py::arg("deg")=nullopt, py::arg("center")=Point<2>{0,0}) + ; - m.def("Rectangle", [](Point<2> pmin, Point<2> pmax, string bc, string mat) - { return Rectangle(pmin, pmax, bc,mat); }, - py::arg("pmin"), py::arg("pmax"), py::arg("bc")=BC_DEFAULT, py::arg("mat")=MAT_DEFAULT + m.def("Rectangle", [](Point<2> pmin, Point<2> pmax, string mat, string bc) + { return Rectangle(pmin, pmax, mat, bc); }, + py::arg("pmin"), py::arg("pmax"), py::arg("mat")=MAT_DEFAULT, py::arg("bc")=BC_DEFAULT ); - m.def("Circle", Circle, py::arg("center"), py::arg("radius"), py::arg("bc")=BC_DEFAULT, py::arg("mat")=MAT_DEFAULT); + m.def("Circle", Circle, py::arg("center"), py::arg("radius"), py::arg("mat")=MAT_DEFAULT, py::arg("bc")=BC_DEFAULT); py::class_(m, "CSG2d") .def(py::init<>()) .def("GenerateSplineGeometry", &CSG2d::GenerateSplineGeometry) .def("Add", &CSG2d::Add) + .def("GenerateMesh", [](CSG2d & self, optional pars, py::kwargs kwargs) + { + MeshingParameters mp; + if(pars) mp = *pars; + { + py::gil_scoped_acquire aq; + CreateMPfromKwargs(mp, kwargs); + } + auto mesh = make_shared(); + auto geo = self.GenerateSplineGeometry(); + mesh->SetGeometry(geo); + SetGlobalMesh (mesh); + ng_geometry = geo; + auto result = geo->GenerateMesh(mesh, mp); + if(result != 0) + throw Exception("Meshing failed!"); + return mesh; + }, py::arg("mp") = nullopt, + py::call_guard(), + meshingparameter_description.c_str()) ; py::class_(m, "EdgeInfo")