mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 14:10:34 +05:00
some operators for Pnt/Vec, nicer namings for gp_Ax3 etc
This commit is contained in:
parent
5ea2322865
commit
0c809f4d2b
@ -77,10 +77,15 @@ DLL_HEADER void ExportNgOCCBasic(py::module &m)
|
|||||||
str << "(" << p.X() << ", " << p.Y() << ", " << p.Z() << ")";
|
str << "(" << p.X() << ", " << p.Y() << ", " << p.Z() << ")";
|
||||||
return str.str();
|
return str.str();
|
||||||
})
|
})
|
||||||
// .def(py::self - py::self)
|
.def("__repr__", [] (const gp_Pnt & p) {
|
||||||
.def("__sub__", [](gp_Pnt p1, gp_Pnt p2) { return gp_Vec(p1.X()-p2.X(), p1.Y()-p2.Y(), p1.Z()-p2.Z()); })
|
stringstream str;
|
||||||
.def("__add__", [](gp_Pnt p, gp_Vec v) { return gp_Pnt(p.X()+v.X(), p.Y()+v.Y(), p.Z()+v.Z()); })
|
str << "(" << p.X() << ", " << p.Y() << ", " << p.Z() << ")";
|
||||||
.def("__sub__", [](gp_Pnt p, gp_Vec v) { return gp_Pnt(p.X()-v.X(), p.Y()-v.Y(), p.Z()-v.Z()); })
|
return str.str();
|
||||||
|
})
|
||||||
|
|
||||||
|
.def("__sub__", [](gp_Pnt p1, gp_Pnt p2) { return gp_Vec(p2, p1); })
|
||||||
|
.def("__add__", [](gp_Pnt p, gp_Vec v) { return p.Translated(v); }) // gp_Pnt(p.X()+v.X(), p.Y()+v.Y(), p.Z()+v.Z()); })
|
||||||
|
.def("__sub__", [](gp_Pnt p, gp_Vec v) { return p.Translated(-v); }) // gp_Pnt(p.X()-v.X(), p.Y()-v.Y(), p.Z()-v.Z()); })
|
||||||
;
|
;
|
||||||
|
|
||||||
py::class_<gp_Vec>(m, "gp_Vec")
|
py::class_<gp_Vec>(m, "gp_Vec")
|
||||||
@ -101,10 +106,15 @@ DLL_HEADER void ExportNgOCCBasic(py::module &m)
|
|||||||
str << "(" << p.X() << ", " << p.Y() << ", " << p.Z() << ")";
|
str << "(" << p.X() << ", " << p.Y() << ", " << p.Z() << ")";
|
||||||
return str.str();
|
return str.str();
|
||||||
})
|
})
|
||||||
.def("__add__", [](gp_Vec v1, gp_Vec v2) { return v1+v2; }) // return gp_Vec(v1.X()+v2.X(), v1.Y()+v2.Y(), v1.Z()+v2.Z()); })
|
.def("__repr__", [] (const gp_Vec & p) {
|
||||||
.def("__sub__", [](gp_Vec v1, gp_Vec v2) { return v1-v2; }) // gp_Vec(v1.X()-v2.X(), v1.Y()-v2.Y(), v1.Z()-v2.Z()); })
|
stringstream str;
|
||||||
.def("__rmul__", [](gp_Vec v, double s) { return s*v; }) // gp_Vec(s*v.X(), s*v.Y(), s*v.Z()); })
|
str << "(" << p.X() << ", " << p.Y() << ", " << p.Z() << ")";
|
||||||
.def("__neg__", [](gp_Vec v) { return -v; }) // gp_Vec(-v.X(), -v.Y(), -v.Z()); })
|
return str.str();
|
||||||
|
})
|
||||||
|
.def("__add__", [](gp_Vec v1, gp_Vec v2) { return v1+v2; })
|
||||||
|
.def("__sub__", [](gp_Vec v1, gp_Vec v2) { return v1-v2; })
|
||||||
|
.def("__rmul__", [](gp_Vec v, double s) { return s*v; })
|
||||||
|
.def("__neg__", [](gp_Vec v) { return -v; })
|
||||||
.def("__xor__", [](gp_Vec v1, gp_Vec v2) { return v1^v2; })
|
.def("__xor__", [](gp_Vec v1, gp_Vec v2) { return v1^v2; })
|
||||||
;
|
;
|
||||||
|
|
||||||
@ -126,7 +136,7 @@ DLL_HEADER void ExportNgOCCBasic(py::module &m)
|
|||||||
})
|
})
|
||||||
;
|
;
|
||||||
|
|
||||||
py::class_<gp_Ax1>(m, "gp_Ax1")
|
py::class_<gp_Ax1>(m, "Axis") // "gp_Ax1")
|
||||||
.def(py::init([](gp_Pnt p, gp_Dir d) {
|
.def(py::init([](gp_Pnt p, gp_Dir d) {
|
||||||
return gp_Ax1(p,d);
|
return gp_Ax1(p,d);
|
||||||
}))
|
}))
|
||||||
@ -140,7 +150,7 @@ DLL_HEADER void ExportNgOCCBasic(py::module &m)
|
|||||||
}))
|
}))
|
||||||
;
|
;
|
||||||
|
|
||||||
py::class_<gp_Ax3>(m, "gp_Ax3")
|
py::class_<gp_Ax3>(m, "Axes") // "gp_Ax3")
|
||||||
.def(py::init([](gp_Pnt p, gp_Dir N, gp_Dir Vx) {
|
.def(py::init([](gp_Pnt p, gp_Dir N, gp_Dir Vx) {
|
||||||
return gp_Ax3(p,N, Vx);
|
return gp_Ax3(p,N, Vx);
|
||||||
}), py::arg("p")=gp_Pnt(0,0,0), py::arg("n")=gp_Vec(0,0,1), py::arg("h")=gp_Vec(1,0,0))
|
}), py::arg("p")=gp_Pnt(0,0,0), py::arg("n")=gp_Vec(0,0,1), py::arg("h")=gp_Vec(1,0,0))
|
||||||
@ -160,7 +170,24 @@ DLL_HEADER void ExportNgOCCBasic(py::module &m)
|
|||||||
.def(py::init([] (double x, double y) {
|
.def(py::init([] (double x, double y) {
|
||||||
return gp_Pnt2d(x, y);
|
return gp_Pnt2d(x, y);
|
||||||
}))
|
}))
|
||||||
|
.def_property("x", [](gp_Pnt2d&p) { return p.X(); }, [](gp_Pnt2d&p,double x) { p.SetX(x); })
|
||||||
|
.def_property("y", [](gp_Pnt2d&p) { return p.Y(); }, [](gp_Pnt2d&p,double y) { p.SetY(y); })
|
||||||
|
.def("__str__", [] (const gp_Pnt2d & p) {
|
||||||
|
stringstream str;
|
||||||
|
str << "(" << p.X() << ", " << p.Y() << ")";
|
||||||
|
return str.str();
|
||||||
|
})
|
||||||
|
.def("__repr__", [] (const gp_Pnt2d & p) {
|
||||||
|
stringstream str;
|
||||||
|
str << "(" << p.X() << ", " << p.Y() << ")";
|
||||||
|
return str.str();
|
||||||
|
})
|
||||||
|
|
||||||
|
.def("__sub__", [](gp_Pnt2d p1, gp_Pnt2d p2) { return gp_Vec2d(p1.X()-p2.X(), p1.Y()-p2.Y()); })
|
||||||
|
.def("__add__", [](gp_Pnt2d p, gp_Vec2d v) { return p.Translated(v); })
|
||||||
|
.def("__sub__", [](gp_Pnt2d p, gp_Vec2d v) { return p.Translated(-v); })
|
||||||
;
|
;
|
||||||
|
|
||||||
py::class_<gp_Vec2d>(m, "gp_Vec2d")
|
py::class_<gp_Vec2d>(m, "gp_Vec2d")
|
||||||
.def(py::init([] (py::tuple vec)
|
.def(py::init([] (py::tuple vec)
|
||||||
{
|
{
|
||||||
@ -172,6 +199,23 @@ DLL_HEADER void ExportNgOCCBasic(py::module &m)
|
|||||||
.def(py::init([] (double x, double y) {
|
.def(py::init([] (double x, double y) {
|
||||||
return gp_Vec2d(x, y);
|
return gp_Vec2d(x, y);
|
||||||
}))
|
}))
|
||||||
|
.def_property("x", [](gp_Vec2d&p) { return p.X(); }, [](gp_Vec2d&p,double x) { p.SetX(x); })
|
||||||
|
.def_property("y", [](gp_Vec2d&p) { return p.Y(); }, [](gp_Vec2d&p,double y) { p.SetY(y); })
|
||||||
|
.def("__str__", [] (const gp_Vec & p) {
|
||||||
|
stringstream str;
|
||||||
|
str << "(" << p.X() << ", " << p.Y() << ")";
|
||||||
|
return str.str();
|
||||||
|
})
|
||||||
|
.def("__repr__", [] (const gp_Vec & p) {
|
||||||
|
stringstream str;
|
||||||
|
str << "(" << p.X() << ", " << p.Y() << ")";
|
||||||
|
return str.str();
|
||||||
|
})
|
||||||
|
.def("__add__", [](gp_Vec2d v1, gp_Vec2d v2) { return v1+v2; })
|
||||||
|
.def("__sub__", [](gp_Vec2d v1, gp_Vec2d v2) { return v1-v2; })
|
||||||
|
.def("__rmul__", [](gp_Vec2d v, double s) { return s*v; })
|
||||||
|
.def("__neg__", [](gp_Vec2d v) { return -v; })
|
||||||
|
.def("__xor__", [](gp_Vec2d v1, gp_Vec2d v2) { return v1^v2; })
|
||||||
;
|
;
|
||||||
|
|
||||||
py::class_<gp_Dir2d>(m, "gp_Dir2d")
|
py::class_<gp_Dir2d>(m, "gp_Dir2d")
|
||||||
@ -187,6 +231,18 @@ DLL_HEADER void ExportNgOCCBasic(py::module &m)
|
|||||||
}))
|
}))
|
||||||
;
|
;
|
||||||
|
|
||||||
|
m.def("Pnt", [](double x, double y) { return gp_Pnt2d(x,y); });
|
||||||
|
m.def("Pnt", [](double x, double y, double z) { return gp_Pnt(x,y,z); });
|
||||||
|
m.def("Pnt", [](std::vector<double> p)
|
||||||
|
{
|
||||||
|
if (p.size() == 2)
|
||||||
|
return py::cast(gp_Pnt2d(p[0], p[1]));
|
||||||
|
if (p.size() == 3)
|
||||||
|
return py::cast(gp_Pnt(p[0], p[1], p[2]));
|
||||||
|
throw Exception("OCC-Points only in 2D or 3D");
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
py::class_<gp_Ax2d>(m, "gp_Ax2d")
|
py::class_<gp_Ax2d>(m, "gp_Ax2d")
|
||||||
.def(py::init([](gp_Pnt2d p, gp_Dir2d d) {
|
.def(py::init([](gp_Pnt2d p, gp_Dir2d d) {
|
||||||
return gp_Ax2d(p,d);
|
return gp_Ax2d(p,d);
|
||||||
|
@ -78,10 +78,11 @@ void ExtractEdgeData( const TopoDS_Edge & edge, int index, std::vector<double> *
|
|||||||
double s0, s1;
|
double s0, s1;
|
||||||
Handle(Geom_Curve) c = BRep_Tool::Curve(edge, s0, s1);
|
Handle(Geom_Curve) c = BRep_Tool::Curve(edge, s0, s1);
|
||||||
|
|
||||||
for (int i = 0; i < 50; i++)
|
constexpr int num = 100;
|
||||||
|
for (int i = 0; i < num; i++)
|
||||||
{
|
{
|
||||||
auto p0 = occ2ng(c->Value (s0 + i*(s1-s0)/50.0));
|
auto p0 = occ2ng(c->Value (s0 + i*(s1-s0)/num));
|
||||||
auto p1 = occ2ng(c->Value (s0 + (i+1)*(s1-s0)/50.0));
|
auto p1 = occ2ng(c->Value (s0 + (i+1)*(s1-s0)/num));
|
||||||
for(auto k : Range(3))
|
for(auto k : Range(3))
|
||||||
{
|
{
|
||||||
p[0].push_back(p0[k]);
|
p[0].push_back(p0[k]);
|
||||||
|
@ -1,2 +1,10 @@
|
|||||||
from .libngpy._NgOCC import *
|
from .libngpy._NgOCC import *
|
||||||
from .meshing import meshsize
|
from .meshing import meshsize
|
||||||
|
|
||||||
|
|
||||||
|
gp_Ax3 = Axes
|
||||||
|
gp_Ax1 = Axis
|
||||||
|
|
||||||
|
Translation = gp_Trsf.Translation
|
||||||
|
Rotation = gp_Trsf.Rotation
|
||||||
|
Mirror = gp_Trsf.Mirror
|
||||||
|
Loading…
Reference in New Issue
Block a user