mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-13 14:40:35 +05:00
Merge branch 'master' into test_refactoring_meshing_design
This commit is contained in:
commit
e784abb8f7
@ -853,6 +853,7 @@ namespace netgen
|
|||||||
for (int i = oldnp+1; i <= plainpoints.Size(); i++)
|
for (int i = oldnp+1; i <= plainpoints.Size(); i++)
|
||||||
{
|
{
|
||||||
Point<3> locp;
|
Point<3> locp;
|
||||||
|
upgeominfo.Elem(i) = *blgeominfo1;
|
||||||
int err =
|
int err =
|
||||||
TransformFromPlain (plainpoints.Elem(i), locp,
|
TransformFromPlain (plainpoints.Elem(i), locp,
|
||||||
upgeominfo.Elem(i), h);
|
upgeominfo.Elem(i), h);
|
||||||
|
@ -647,7 +647,7 @@ namespace netgen
|
|||||||
|
|
||||||
Box<3> bb = geom.GetBoundingBox();
|
Box<3> bb = geom.GetBoundingBox();
|
||||||
|
|
||||||
// int projecttype = PLANESPACE;
|
int projecttype = PLANESPACE;
|
||||||
|
|
||||||
static Timer tinit("init");
|
static Timer tinit("init");
|
||||||
tinit.Start();
|
tinit.Start();
|
||||||
|
@ -342,7 +342,9 @@ namespace netgen
|
|||||||
Point<3> & p3d,
|
Point<3> & p3d,
|
||||||
PointGeomInfo & gi,
|
PointGeomInfo & gi,
|
||||||
double h)
|
double h)
|
||||||
{
|
{
|
||||||
|
static Timer t("FromPlane"); RegionTimer reg(t);
|
||||||
|
|
||||||
if (projecttype == PLANESPACE)
|
if (projecttype == PLANESPACE)
|
||||||
{
|
{
|
||||||
// cout << "2d : " << pplane << endl;
|
// cout << "2d : " << pplane << endl;
|
||||||
@ -366,12 +368,75 @@ namespace netgen
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void OCCSurface :: Project (Point<3> & p, PointGeomInfo & gi)
|
void OCCSurface :: Project (Point<3> & ap, PointGeomInfo & gi)
|
||||||
{
|
{
|
||||||
|
static Timer t("OccSurface::Project"); RegionTimer reg(t);
|
||||||
|
|
||||||
|
|
||||||
|
// try Newton's method ...
|
||||||
|
|
||||||
|
gp_Pnt p(ap(0), ap(1), ap(2));
|
||||||
|
|
||||||
|
double u = gi.u;
|
||||||
|
double v = gi.v;
|
||||||
|
gp_Pnt x = occface->Value (u,v);
|
||||||
|
|
||||||
|
if (p.SquareDistance(x) <= sqr(PROJECTION_TOLERANCE)) return;
|
||||||
|
|
||||||
|
gp_Vec du, dv;
|
||||||
|
occface->D1(u,v,x,du,dv);
|
||||||
|
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
gp_Pnt xold;
|
||||||
|
gp_Vec n;
|
||||||
|
double det, lambda, mu;
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
count++;
|
||||||
|
|
||||||
|
n = du^dv;
|
||||||
|
|
||||||
|
det = Det3 (n.X(), du.X(), dv.X(),
|
||||||
|
n.Y(), du.Y(), dv.Y(),
|
||||||
|
n.Z(), du.Z(), dv.Z());
|
||||||
|
|
||||||
|
if (det < 1e-15)
|
||||||
|
break;
|
||||||
|
|
||||||
|
lambda = Det3 (n.X(), p.X()-x.X(), dv.X(),
|
||||||
|
n.Y(), p.Y()-x.Y(), dv.Y(),
|
||||||
|
n.Z(), p.Z()-x.Z(), dv.Z())/det;
|
||||||
|
|
||||||
|
mu = Det3 (n.X(), du.X(), p.X()-x.X(),
|
||||||
|
n.Y(), du.Y(), p.Y()-x.Y(),
|
||||||
|
n.Z(), du.Z(), p.Z()-x.Z())/det;
|
||||||
|
|
||||||
|
u += lambda;
|
||||||
|
v += mu;
|
||||||
|
|
||||||
|
xold = x;
|
||||||
|
occface->D1(u,v,x,du,dv);
|
||||||
|
|
||||||
|
if (xold.SquareDistance(x) < sqr(PROJECTION_TOLERANCE))
|
||||||
|
{
|
||||||
|
ap = Point<3> (x.X(), x.Y(), x.Z());
|
||||||
|
gi.u = u;
|
||||||
|
gi.v = v;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (count < 20);
|
||||||
|
|
||||||
|
|
||||||
|
// Newton did not converge, use OCC projection
|
||||||
|
|
||||||
|
|
||||||
// static int cnt = 0;
|
// static int cnt = 0;
|
||||||
// if (cnt++ % 1000 == 0) cout << "********************************************** OCCSurfce :: Project, cnt = " << cnt << endl;
|
// if (cnt++ % 1000 == 0) cout << "********************************************** OCCSurfce :: Project, cnt = " << cnt << endl;
|
||||||
|
|
||||||
gp_Pnt pnt(p(0), p(1), p(2));
|
gp_Pnt pnt = p; // (p(0), p(1), p(2));
|
||||||
|
|
||||||
//(*testout) << "pnt = " << pnt.X() << ", " << pnt.Y() << ", " << pnt.Z() << endl;
|
//(*testout) << "pnt = " << pnt.X() << ", " << pnt.Y() << ", " << pnt.Z() << endl;
|
||||||
|
|
||||||
@ -406,20 +471,20 @@ namespace netgen
|
|||||||
proj.LowerDistanceParameters (gi.u, gi.v);
|
proj.LowerDistanceParameters (gi.u, gi.v);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
double u,v;
|
// double u,v;
|
||||||
Handle( ShapeAnalysis_Surface ) su = new ShapeAnalysis_Surface( occface );
|
Handle( ShapeAnalysis_Surface ) su = new ShapeAnalysis_Surface( occface );
|
||||||
gp_Pnt2d suval = su->ValueOfUV ( pnt, BRep_Tool::Tolerance( topods_face ) );
|
auto toltool = BRep_Tool::Tolerance( topods_face );
|
||||||
|
|
||||||
|
gp_Pnt2d suval = su->ValueOfUV ( pnt, toltool);
|
||||||
suval.Coord( u, v);
|
suval.Coord( u, v);
|
||||||
pnt = occface->Value( u, v );
|
pnt = occface->Value( u, v );
|
||||||
|
|
||||||
//(*testout) << "pnt(proj) = " << pnt.X() << ", " << pnt.Y() << ", " << pnt.Z() << endl;
|
//(*testout) << "pnt(proj) = " << pnt.X() << ", " << pnt.Y() << ", " << pnt.Z() << endl;
|
||||||
gi.u = u;
|
gi.u = u;
|
||||||
gi.v = v;
|
gi.v = v;
|
||||||
|
|
||||||
|
|
||||||
gi.trignum = 1;
|
gi.trignum = 1;
|
||||||
|
|
||||||
p = Point<3> (pnt.X(), pnt.Y(), pnt.Z());
|
ap = Point<3> (pnt.X(), pnt.Y(), pnt.Z());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user