mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-13 14:40:35 +05:00
python csg
This commit is contained in:
parent
be3ee96678
commit
5bfa6a39df
@ -35,6 +35,47 @@ inline string ToString (const T& t)
|
||||
return ss.str();
|
||||
}
|
||||
|
||||
// a shadow solid tree using shared pointers.
|
||||
|
||||
class SPSolid
|
||||
{
|
||||
shared_ptr<SPSolid> s1, s2;
|
||||
Solid * solid;
|
||||
bool owner;
|
||||
public:
|
||||
enum optyp { TERM, SECTION, UNION, SUB };
|
||||
|
||||
SPSolid (Solid * as) : solid(as), owner(true), op(TERM) { ; }
|
||||
|
||||
SPSolid (optyp aop, shared_ptr<SPSolid> as1, shared_ptr<SPSolid> as2)
|
||||
: s1(as1), s2(as2), owner(true), op(aop)
|
||||
{
|
||||
if (aop == UNION)
|
||||
solid = new Solid (Solid::UNION, s1->GetSolid(), s2->GetSolid());
|
||||
else if (aop == SECTION)
|
||||
solid = new Solid (Solid::SECTION, s1->GetSolid(), s2->GetSolid());
|
||||
}
|
||||
|
||||
Solid * GetSolid() { return solid; }
|
||||
|
||||
void GiveUpOwner()
|
||||
{
|
||||
owner = false;
|
||||
if (s1) s1 -> GiveUpOwner();
|
||||
if (s2) s2 -> GiveUpOwner();
|
||||
}
|
||||
|
||||
void AddSurfaces(CSGeometry & geom)
|
||||
{
|
||||
if (op == TERM)
|
||||
geom.AddSurfaces (solid->GetPrimitive());
|
||||
if (s1) s1 -> AddSurfaces (geom);
|
||||
if (s2) s2 -> AddSurfaces (geom);
|
||||
}
|
||||
|
||||
private:
|
||||
optyp op;
|
||||
};
|
||||
|
||||
|
||||
namespace netgen
|
||||
@ -58,6 +99,40 @@ void ExportCSG()
|
||||
bp::scope local_scope(module);
|
||||
|
||||
|
||||
bp::class_<Point<3>> ("Point3d", bp::init<double,double,double>()) ;
|
||||
bp::class_<Vec<3>> ("Vec3d", bp::init<double,double,double>()) ;
|
||||
|
||||
bp::class_<SPSolid, shared_ptr<SPSolid>, boost::noncopyable> ("Solid", bp::no_init) ;
|
||||
|
||||
bp::def ("Sphere", FunctionPointer([](const Point<3> c, double r)
|
||||
{
|
||||
Sphere * sp = new Sphere (c, r);
|
||||
Solid * sol = new Solid (sp);
|
||||
return make_shared<SPSolid> (sol);
|
||||
}));
|
||||
bp::def ("Plane", FunctionPointer([](const Point<3> p, Vec<3> n)
|
||||
{
|
||||
Plane * sp = new Plane (p,n);
|
||||
Solid * sol = new Solid (sp);
|
||||
return make_shared<SPSolid> (sol);
|
||||
}));
|
||||
|
||||
bp::def ("OrthoBrick", FunctionPointer([](const Point<3> p1, Point<3> p2)
|
||||
{
|
||||
OrthoBrick * brick = new OrthoBrick (p1,p2);
|
||||
Solid * sol = new Solid (brick);
|
||||
return make_shared<SPSolid> (sol);
|
||||
}));
|
||||
|
||||
bp::def ("Or", FunctionPointer([](shared_ptr<SPSolid> s1, shared_ptr<SPSolid> s2)
|
||||
{
|
||||
return make_shared<SPSolid> (SPSolid::UNION, s1, s2);
|
||||
}));
|
||||
bp::def ("And", FunctionPointer([](shared_ptr<SPSolid> s1, shared_ptr<SPSolid> s2)
|
||||
{
|
||||
return make_shared<SPSolid> (SPSolid::SECTION, s1, s2);
|
||||
}));
|
||||
|
||||
|
||||
bp::class_<CSGeometry, boost::noncopyable> ("CSGeometry")
|
||||
.def("__init__", bp::make_constructor (FunctionPointer
|
||||
@ -69,15 +144,23 @@ void ExportCSG()
|
||||
geom -> FindIdenticSurfaces(1e-8 * geom->MaxSize());
|
||||
return geom;
|
||||
})))
|
||||
|
||||
.def("Add", FunctionPointer([] (CSGeometry & self, shared_ptr<SPSolid> solid)
|
||||
{
|
||||
solid->AddSurfaces (self);
|
||||
solid->GiveUpOwner();
|
||||
self.SetTopLevelObject (solid->GetSolid());
|
||||
}))
|
||||
|
||||
.add_property ("ntlo", &CSGeometry::GetNTopLevelObjects)
|
||||
;
|
||||
|
||||
|
||||
bp::def("GenerateMesh", FunctionPointer
|
||||
([](CSGeometry & geo, MeshingParameters & param)
|
||||
{
|
||||
Mesh * dummy = NULL;
|
||||
cout << "Genrate Mesh, params = "; // << param << endl;
|
||||
geo.FindIdenticSurfaces(1e-8 * geo.MaxSize());
|
||||
geo.GenerateMesh (dummy, param, 0, 6);
|
||||
return shared_ptr<Mesh> (dummy);
|
||||
}));
|
||||
|
Loading…
Reference in New Issue
Block a user