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();
|
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
|
namespace netgen
|
||||||
@ -58,26 +99,68 @@ void ExportCSG()
|
|||||||
bp::scope local_scope(module);
|
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")
|
bp::class_<CSGeometry, boost::noncopyable> ("CSGeometry")
|
||||||
.def("__init__", bp::make_constructor (FunctionPointer
|
.def("__init__", bp::make_constructor (FunctionPointer
|
||||||
([](const string & filename)
|
([](const string & filename)
|
||||||
{
|
{
|
||||||
cout << "load geometry";
|
cout << "load geometry";
|
||||||
ifstream ist(filename);
|
ifstream ist(filename);
|
||||||
shared_ptr<CSGeometry> geom(ParseCSG(ist));
|
shared_ptr<CSGeometry> geom(ParseCSG(ist));
|
||||||
geom -> FindIdenticSurfaces(1e-8 * geom->MaxSize());
|
geom -> FindIdenticSurfaces(1e-8 * geom->MaxSize());
|
||||||
return geom;
|
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)
|
.add_property ("ntlo", &CSGeometry::GetNTopLevelObjects)
|
||||||
;
|
;
|
||||||
|
|
||||||
|
|
||||||
bp::def("GenerateMesh", FunctionPointer
|
bp::def("GenerateMesh", FunctionPointer
|
||||||
([](CSGeometry & geo, MeshingParameters & param)
|
([](CSGeometry & geo, MeshingParameters & param)
|
||||||
{
|
{
|
||||||
Mesh * dummy = NULL;
|
Mesh * dummy = NULL;
|
||||||
cout << "Genrate Mesh, params = "; // << param << endl;
|
cout << "Genrate Mesh, params = "; // << param << endl;
|
||||||
|
geo.FindIdenticSurfaces(1e-8 * geo.MaxSize());
|
||||||
geo.GenerateMesh (dummy, param, 0, 6);
|
geo.GenerateMesh (dummy, param, 0, 6);
|
||||||
return shared_ptr<Mesh> (dummy);
|
return shared_ptr<Mesh> (dummy);
|
||||||
}));
|
}));
|
||||||
|
Loading…
Reference in New Issue
Block a user