mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-26 21:00:34 +05:00
on the way to thread-save meshing
This commit is contained in:
parent
5b430b57bd
commit
a582fc6231
@ -413,7 +413,7 @@ namespace netgen
|
||||
geom.GetSurface((mesh.GetFaceDescriptor(k).SurfNr()));
|
||||
|
||||
|
||||
Meshing2Surfaces meshing(*surf, geom.BoundingBox());
|
||||
Meshing2Surfaces meshing(*surf, mparam, geom.BoundingBox());
|
||||
meshing.SetStartTime (starttime);
|
||||
|
||||
double eps = 1e-8 * geom.MaxSize();
|
||||
@ -482,7 +482,7 @@ namespace netgen
|
||||
mparam.checkoverlap = 0;
|
||||
|
||||
MESHING2_RESULT res =
|
||||
meshing.GenerateMesh (mesh, maxh, k);
|
||||
meshing.GenerateMesh (mesh, mparam, maxh, k);
|
||||
|
||||
if (res != MESHING2_OK)
|
||||
{
|
||||
@ -531,7 +531,7 @@ namespace netgen
|
||||
meshopt.SetMetricWeight (mparam.elsizeweight);
|
||||
meshopt.SetWriteStatus (0);
|
||||
|
||||
meshopt.ImproveMesh (mesh);
|
||||
meshopt.ImproveMesh (mesh, mparam);
|
||||
}
|
||||
|
||||
{
|
||||
@ -553,7 +553,7 @@ namespace netgen
|
||||
meshopt.SetMetricWeight (mparam.elsizeweight);
|
||||
meshopt.SetWriteStatus (0);
|
||||
|
||||
meshopt.ImproveMesh (mesh);
|
||||
meshopt.ImproveMesh (mesh, mparam);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -723,7 +723,7 @@ namespace netgen
|
||||
|
||||
if (mparam.uselocalh)
|
||||
{
|
||||
mesh->CalcLocalH();
|
||||
mesh->CalcLocalH(mparam.grading);
|
||||
mesh->DeleteMesh();
|
||||
|
||||
FindPoints (geom, *mesh);
|
||||
@ -757,7 +757,7 @@ namespace netgen
|
||||
|
||||
if (mparam.uselocalh && 0)
|
||||
{
|
||||
mesh->CalcLocalH();
|
||||
mesh->CalcLocalH(mparam.grading);
|
||||
mesh->DeleteMesh();
|
||||
|
||||
FindPoints (geom, *mesh);
|
||||
|
@ -15,8 +15,9 @@ Meshing2Surfaces :: Meshing2Surfaces (const Surface & asurface)
|
||||
}
|
||||
*/
|
||||
Meshing2Surfaces :: Meshing2Surfaces (const Surface & asurf,
|
||||
const MeshingParameters & mp,
|
||||
const Box<3> & abb)
|
||||
: Meshing2(abb), surface(asurf)
|
||||
: Meshing2(mp, abb), surface(asurf)
|
||||
{
|
||||
;
|
||||
}
|
||||
|
@ -14,7 +14,8 @@ namespace netgen
|
||||
///
|
||||
// Meshing2Surfaces (const Surface & asurf);
|
||||
///
|
||||
Meshing2Surfaces (const Surface & asurf, const Box<3> & aboundingbox);
|
||||
Meshing2Surfaces (const Surface & asurf, const MeshingParameters & mp,
|
||||
const Box<3> & aboundingbox);
|
||||
|
||||
protected:
|
||||
///
|
||||
|
@ -125,8 +125,8 @@ namespace netgen
|
||||
return *strlistflags.Get(name);
|
||||
else
|
||||
{
|
||||
static Array<char*> hstra(0);
|
||||
return hstra;
|
||||
static Array<char*> dummy_array(0);
|
||||
return dummy_array;
|
||||
}
|
||||
}
|
||||
|
||||
@ -137,8 +137,8 @@ namespace netgen
|
||||
return *numlistflags.Get(name);
|
||||
else
|
||||
{
|
||||
static Array<double> hnuma(0);
|
||||
return hnuma;
|
||||
static Array<double> dummy_array(0);
|
||||
return dummy_array;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -350,7 +350,7 @@ namespace netgen
|
||||
mesh->SetLocalH (pmin, pmax, mparam.grading);
|
||||
mesh->SetGlobalH (h);
|
||||
|
||||
mesh->CalcLocalH();
|
||||
mesh->CalcLocalH(mparam.grading);
|
||||
|
||||
int bnp = mesh->GetNP(); // boundary points
|
||||
|
||||
@ -452,7 +452,7 @@ namespace netgen
|
||||
|
||||
mparam.quad = hquad || geometry.GetDomainQuadMeshing (domnr);
|
||||
|
||||
Meshing2 meshing (Box<3> (pmin, pmax));
|
||||
Meshing2 meshing (mparam, Box<3> (pmin, pmax));
|
||||
|
||||
Array<int, PointIndex::BASE> compress(bnp);
|
||||
compress = -1;
|
||||
@ -491,7 +491,7 @@ namespace netgen
|
||||
meshing.Delaunay (*mesh, domnr, mparam);
|
||||
else
|
||||
*/
|
||||
meshing.GenerateMesh (*mesh, h, domnr);
|
||||
meshing.GenerateMesh (*mesh, mparam, h, domnr);
|
||||
|
||||
for (SurfaceElementIndex sei = oldnf; sei < mesh->GetNSE(); sei++)
|
||||
(*mesh)[sei].SetIndex (domnr);
|
||||
|
@ -2152,7 +2152,7 @@ int Ng_Bisect_WithInfo ( const char * refinementfile, double ** qualityloss, int
|
||||
}
|
||||
|
||||
if(!mesh->LocalHFunctionGenerated())
|
||||
mesh->CalcLocalH();
|
||||
mesh->CalcLocalH(mparam.grading);
|
||||
|
||||
mesh->LocalHFunction().SetGrading (mparam.grading);
|
||||
|
||||
|
@ -160,39 +160,12 @@ namespace netgen
|
||||
return *this;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
double & DenseMatrix :: operator() (int i, int j)
|
||||
{
|
||||
if (i >= 1 && j >= 1 && i <= height && j <= width)
|
||||
return Elem(i,j);
|
||||
else (*myerr) << "DenseMatrix: index (" << i << "," << j << ") out of range (1.."
|
||||
<< height << ",1.." << width << ")\n";
|
||||
static double dummy = 0;
|
||||
return dummy;
|
||||
}
|
||||
|
||||
double DenseMatrix :: operator() (int i, int j) const
|
||||
{
|
||||
if (i >= 1 && j >= 1 && i <= height && j <= width)
|
||||
return Get(i,j);
|
||||
else (*myerr) << "DenseMatrix: index (" << i << "," << j << ") out of range (1.."
|
||||
<< height << ",1.." << width << ")\n";
|
||||
|
||||
static double dummy = 0;
|
||||
return dummy;
|
||||
}
|
||||
*/
|
||||
|
||||
DenseMatrix & DenseMatrix :: operator= (double v)
|
||||
{
|
||||
int i;
|
||||
double * p = data;
|
||||
|
||||
if (data)
|
||||
for (i = width*height; i > 0; i--, p++)
|
||||
for (int i = width*height; i > 0; i--, p++)
|
||||
*p = v;
|
||||
|
||||
return *this;
|
||||
@ -202,11 +175,10 @@ namespace netgen
|
||||
|
||||
DenseMatrix & DenseMatrix :: operator*= (double v)
|
||||
{
|
||||
int i;
|
||||
double * p = data;
|
||||
|
||||
if (data)
|
||||
for (i = width*height; i > 0; i--, p++)
|
||||
for (int i = width*height; i > 0; i--, p++)
|
||||
*p *= v;
|
||||
|
||||
return *this;
|
||||
|
@ -47,10 +47,8 @@ double MinFunction :: FuncGrad (const Vector & x, Vector & g) const
|
||||
/*
|
||||
int n = x.Size();
|
||||
|
||||
static Vector xr;
|
||||
static Vector xl;
|
||||
xr.SetSize(n);
|
||||
xl.SetSize(n);
|
||||
Vector xr(n);
|
||||
Vector xl(n);
|
||||
|
||||
double eps = 1e-6;
|
||||
double fl, fr;
|
||||
|
@ -15,8 +15,8 @@ public:
|
||||
///
|
||||
MeshOptimize2d ();
|
||||
///
|
||||
void ImproveMesh (Mesh & mesh2d);
|
||||
void ImproveMeshJacobian (Mesh & mesh2d);
|
||||
void ImproveMesh (Mesh & mesh2d, const MeshingParameters & mp);
|
||||
void ImproveMeshJacobian (Mesh & mesh2d, const MeshingParameters & mp);
|
||||
void ImproveVolumeMesh (Mesh & mesh);
|
||||
void ProjectBoundaryPoints(Array<int> & surfaceindex,
|
||||
const Array<Point<3>* > & from, Array<Point<3>* > & dest);
|
||||
|
@ -161,7 +161,7 @@ void MeshOptimize3d :: CombineImprove (Mesh & mesh,
|
||||
{
|
||||
const Element & elem = mesh[hasonepi[k]];
|
||||
double err = CalcTetBadness (mesh[elem[0]], mesh[elem[1]],
|
||||
mesh[elem[2]], mesh[elem[3]], 0);
|
||||
mesh[elem[2]], mesh[elem[3]], 0, mparam);
|
||||
bad2 += err;
|
||||
oneperr[k] = err;
|
||||
}
|
||||
|
@ -22,11 +22,11 @@ public:
|
||||
|
||||
inline double
|
||||
CalcBad (const Mesh::T_POINTS & points, const Element & elem,
|
||||
double h)
|
||||
double h, const MeshingParameters & mp = mparam)
|
||||
{
|
||||
if (elem.GetType() == TET)
|
||||
return CalcTetBadness (points[elem[0]], points[elem[1]],
|
||||
points[elem[2]], points[elem[3]], h);
|
||||
points[elem[2]], points[elem[3]], h, mp);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -34,7 +34,8 @@ CalcBad (const Mesh::T_POINTS & points, const Element & elem,
|
||||
|
||||
|
||||
extern double CalcTotalBad (const Mesh::T_POINTS & points,
|
||||
const Mesh::T_VOLELEMENTS & elements);
|
||||
const Mesh::T_VOLELEMENTS & elements,
|
||||
const MeshingParameters & mp = mparam);
|
||||
|
||||
extern int WrongOrientation (const Mesh::T_POINTS & points, const Element & el);
|
||||
|
||||
|
@ -1731,12 +1731,6 @@ namespace netgen
|
||||
void Mesh :: FindOpenElements (int dom)
|
||||
{
|
||||
static int timer = NgProfiler::CreateTimer ("Mesh::FindOpenElements");
|
||||
static int timera = NgProfiler::CreateTimer ("Mesh::FindOpenElements A");
|
||||
static int timerb = NgProfiler::CreateTimer ("Mesh::FindOpenElements B");
|
||||
static int timerc = NgProfiler::CreateTimer ("Mesh::FindOpenElements C");
|
||||
static int timerd = NgProfiler::CreateTimer ("Mesh::FindOpenElements D");
|
||||
static int timere = NgProfiler::CreateTimer ("Mesh::FindOpenElements E");
|
||||
|
||||
NgProfiler::RegionTimer reg (timer);
|
||||
|
||||
int np = GetNP();
|
||||
@ -1747,7 +1741,6 @@ namespace netgen
|
||||
|
||||
numonpoint = 0;
|
||||
|
||||
NgProfiler::StartTimer (timera);
|
||||
for (ElementIndex ei = 0; ei < ne; ei++)
|
||||
{
|
||||
const Element & el = (*this)[ei];
|
||||
@ -1784,13 +1777,6 @@ namespace netgen
|
||||
elsonpoint.Add (el[j], ei);
|
||||
}
|
||||
}
|
||||
NgProfiler::StopTimer (timera);
|
||||
|
||||
|
||||
|
||||
|
||||
NgProfiler::StartTimer (timerb);
|
||||
|
||||
|
||||
|
||||
Array<char, 1> hasface(GetNFD());
|
||||
@ -1865,15 +1851,11 @@ namespace netgen
|
||||
}
|
||||
|
||||
|
||||
NgProfiler::StopTimer (timerb);
|
||||
|
||||
int ii;
|
||||
PointIndex pi;
|
||||
SurfaceElementIndex sei;
|
||||
Element2d hel;
|
||||
|
||||
NgProfiler::RegionTimer regc (timerc);
|
||||
|
||||
|
||||
INDEX_3_CLOSED_HASHTABLE<INDEX_2> faceht(100);
|
||||
openelements.SetSize(0);
|
||||
@ -2016,8 +1998,6 @@ namespace netgen
|
||||
BuildBoundaryEdges();
|
||||
|
||||
|
||||
NgProfiler::RegionTimer regd (timerd);
|
||||
|
||||
for (int i = 1; i <= openelements.Size(); i++)
|
||||
{
|
||||
const Element2d & sel = openelements.Get(i);
|
||||
@ -2041,7 +2021,6 @@ namespace netgen
|
||||
}
|
||||
|
||||
|
||||
NgProfiler::RegionTimer rege (timere);
|
||||
|
||||
/*
|
||||
for (i = 1; i <= GetNSeg(); i++)
|
||||
@ -2542,13 +2521,14 @@ namespace netgen
|
||||
|
||||
|
||||
|
||||
void Mesh :: CalcLocalH ()
|
||||
void Mesh :: CalcLocalH (double grading)
|
||||
{
|
||||
if (!lochfunc)
|
||||
{
|
||||
Point3d pmin, pmax;
|
||||
GetBox (pmin, pmax);
|
||||
SetLocalH (pmin, pmax, mparam.grading);
|
||||
// SetLocalH (pmin, pmax, mparam.grading);
|
||||
SetLocalH (pmin, pmax, grading);
|
||||
}
|
||||
|
||||
PrintMessage (3,
|
||||
@ -2675,7 +2655,7 @@ namespace netgen
|
||||
}
|
||||
|
||||
|
||||
void Mesh :: CalcLocalHFromPointDistances(void)
|
||||
void Mesh :: CalcLocalHFromPointDistances(double grading)
|
||||
{
|
||||
PrintMessage (3, "Calculating local h from point distances");
|
||||
|
||||
@ -2684,7 +2664,8 @@ namespace netgen
|
||||
Point3d pmin, pmax;
|
||||
GetBox (pmin, pmax);
|
||||
|
||||
SetLocalH (pmin, pmax, mparam.grading);
|
||||
// SetLocalH (pmin, pmax, mparam.grading);
|
||||
SetLocalH (pmin, pmax, grading);
|
||||
}
|
||||
|
||||
PointIndex i,j;
|
||||
@ -2709,7 +2690,7 @@ namespace netgen
|
||||
}
|
||||
|
||||
|
||||
void Mesh :: CalcLocalHFromSurfaceCurvature (double elperr)
|
||||
void Mesh :: CalcLocalHFromSurfaceCurvature (double grading, double elperr)
|
||||
{
|
||||
PrintMessage (3, "Calculating local h from surface curvature");
|
||||
|
||||
@ -2718,7 +2699,8 @@ namespace netgen
|
||||
Point3d pmin, pmax;
|
||||
GetBox (pmin, pmax);
|
||||
|
||||
SetLocalH (pmin, pmax, mparam.grading);
|
||||
// SetLocalH (pmin, pmax, mparam.grading);
|
||||
SetLocalH (pmin, pmax, grading);
|
||||
}
|
||||
|
||||
|
||||
@ -3047,11 +3029,11 @@ namespace netgen
|
||||
|
||||
|
||||
|
||||
double Mesh :: ElementError (int eli) const
|
||||
double Mesh :: ElementError (int eli, const MeshingParameters & mp) const
|
||||
{
|
||||
const Element & el = volelements.Get(eli);
|
||||
return CalcTetBadness (points.Get(el[0]), points.Get(el[1]),
|
||||
points.Get(el[2]), points.Get(el[3]), -1);
|
||||
points.Get(el[2]), points.Get(el[3]), -1, mp);
|
||||
}
|
||||
|
||||
void Mesh :: AddLockedPoint (PointIndex pi)
|
||||
@ -4145,11 +4127,11 @@ namespace netgen
|
||||
const int element,
|
||||
bool consider3D) const
|
||||
{
|
||||
static Vec3d col1, col2, col3;
|
||||
static Vec3d rhs, sol;
|
||||
Vec3d col1, col2, col3;
|
||||
Vec3d rhs, sol;
|
||||
const double eps = 1e-6;
|
||||
|
||||
static Array<Element2d> loctrigs;
|
||||
Array<Element2d> loctrigs;
|
||||
|
||||
|
||||
//SZ
|
||||
@ -4425,12 +4407,11 @@ namespace netgen
|
||||
double lami[3],
|
||||
const int element) const
|
||||
{
|
||||
|
||||
static Vec3d col1, col2, col3;
|
||||
static Vec3d rhs, sol;
|
||||
Vec3d col1, col2, col3;
|
||||
Vec3d rhs, sol;
|
||||
const double eps = 1.e-4;
|
||||
|
||||
static Array<Element> loctets;
|
||||
Array<Element> loctets;
|
||||
|
||||
VolumeElement(element).GetTets (loctets);
|
||||
|
||||
@ -5003,8 +4984,8 @@ namespace netgen
|
||||
|
||||
void Mesh :: GetSurfaceElementsOfFace (int facenr, Array<SurfaceElementIndex> & sei) const
|
||||
{
|
||||
static int timer = NgProfiler::CreateTimer ("GetSurfaceElementsOfFace");
|
||||
NgProfiler::RegionTimer reg (timer);
|
||||
static int timer = NgProfiler::CreateTimer ("GetSurfaceElementsOfFace");
|
||||
NgProfiler::RegionTimer reg (timer);
|
||||
|
||||
|
||||
/*
|
||||
|
@ -311,7 +311,7 @@ namespace netgen
|
||||
|
||||
|
||||
///
|
||||
DLL_HEADER double ElementError (int eli) const;
|
||||
DLL_HEADER double ElementError (int eli, const MeshingParameters & mp) const;
|
||||
|
||||
///
|
||||
DLL_HEADER void AddLockedPoint (PointIndex pi);
|
||||
@ -382,7 +382,7 @@ namespace netgen
|
||||
*/
|
||||
DLL_HEADER double AverageH (int surfnr = 0) const;
|
||||
/// Calculates localh
|
||||
DLL_HEADER void CalcLocalH ();
|
||||
DLL_HEADER void CalcLocalH (double grading);
|
||||
///
|
||||
DLL_HEADER void SetLocalH (const Point3d & pmin, const Point3d & pmax, double grading);
|
||||
///
|
||||
@ -391,9 +391,9 @@ namespace netgen
|
||||
DLL_HEADER void RestrictLocalHLine (const Point3d & p1, const Point3d & p2,
|
||||
double hloc);
|
||||
/// number of elements per radius
|
||||
DLL_HEADER void CalcLocalHFromSurfaceCurvature(double elperr);
|
||||
DLL_HEADER void CalcLocalHFromSurfaceCurvature(double grading, double elperr);
|
||||
///
|
||||
DLL_HEADER void CalcLocalHFromPointDistances(void);
|
||||
DLL_HEADER void CalcLocalHFromPointDistances(double grading);
|
||||
///
|
||||
DLL_HEADER void RestrictLocalH (resthtype rht, int nr, double loch);
|
||||
///
|
||||
|
@ -22,7 +22,7 @@ namespace netgen
|
||||
|
||||
Array<INDEX_2> connectednodes;
|
||||
|
||||
if (&mesh3d.LocalHFunction() == NULL) mesh3d.CalcLocalH();
|
||||
if (&mesh3d.LocalHFunction() == NULL) mesh3d.CalcLocalH(mp.grading);
|
||||
|
||||
mesh3d.Compress();
|
||||
|
||||
|
@ -41,7 +41,7 @@ namespace netgen
|
||||
{
|
||||
MeshOptimize2d meshopt;
|
||||
meshopt.SetMetricWeight (1);
|
||||
meshopt.ImproveMesh(mesh);
|
||||
meshopt.ImproveMesh(mesh, mp);
|
||||
break;
|
||||
}
|
||||
|
||||
|
@ -7,24 +7,23 @@ namespace netgen
|
||||
|
||||
|
||||
// global variable for visualization
|
||||
// static Array<Point3d> locpoints;
|
||||
// static Array<int> legalpoints;
|
||||
// static Array<Point2d> plainpoints;
|
||||
// static Array<int> plainzones;
|
||||
// static Array<INDEX_2> loclines;
|
||||
// // static int geomtrig;
|
||||
// //static const char * rname;
|
||||
// static int cntelem, trials, nfaces;
|
||||
// static int oldnl;
|
||||
// static int qualclass;
|
||||
|
||||
static Array<Point3d> locpoints;
|
||||
static Array<int> legalpoints;
|
||||
static Array<Point2d> plainpoints;
|
||||
static Array<int> plainzones;
|
||||
static Array<INDEX_2> loclines;
|
||||
// static int geomtrig;
|
||||
//static const char * rname;
|
||||
static int cntelem, trials, nfaces;
|
||||
static int oldnl;
|
||||
static int qualclass;
|
||||
|
||||
|
||||
Meshing2 :: Meshing2 (const Box<3> & aboundingbox)
|
||||
Meshing2 :: Meshing2 (const MeshingParameters & mp, const Box<3> & aboundingbox)
|
||||
{
|
||||
boundingbox = aboundingbox;
|
||||
|
||||
LoadRules (NULL);
|
||||
|
||||
LoadRules (NULL, mp.quad);
|
||||
// LoadRules ("rules/quad.rls");
|
||||
// LoadRules ("rules/triangle.rls");
|
||||
|
||||
@ -73,8 +72,8 @@ namespace netgen
|
||||
canuse = 0;
|
||||
ruleused = 0;
|
||||
|
||||
cntelem = 0;
|
||||
trials = 0;
|
||||
// cntelem = 0;
|
||||
// trials = 0;
|
||||
}
|
||||
|
||||
void Meshing2 :: EndMesh ()
|
||||
@ -194,7 +193,7 @@ namespace netgen
|
||||
|
||||
|
||||
|
||||
MESHING2_RESULT Meshing2 :: GenerateMesh (Mesh & mesh, double gh, int facenr)
|
||||
MESHING2_RESULT Meshing2 :: GenerateMesh (Mesh & mesh, const MeshingParameters & mp, double gh, int facenr)
|
||||
{
|
||||
static int timer = NgProfiler::CreateTimer ("surface meshing");
|
||||
|
||||
@ -227,6 +226,17 @@ namespace netgen
|
||||
double h, his, hshould;
|
||||
|
||||
|
||||
Array<Point3d> locpoints;
|
||||
Array<int> legalpoints;
|
||||
Array<Point2d> plainpoints;
|
||||
Array<int> plainzones;
|
||||
Array<INDEX_2> loclines;
|
||||
int cntelem = 0, trials = 0, nfaces = 0;
|
||||
int oldnl = 0;
|
||||
int qualclass;
|
||||
|
||||
|
||||
|
||||
// test for 3d overlaps
|
||||
Box3dTree surfeltree (boundingbox.PMin(),
|
||||
boundingbox.PMax());
|
||||
@ -419,7 +429,7 @@ namespace netgen
|
||||
|
||||
//(*testout) << "locpoints " << locpoints << endl;
|
||||
|
||||
if (qualclass > mparam.giveuptol2d)
|
||||
if (qualclass > mp.giveuptol2d)
|
||||
{
|
||||
PrintMessage (3, "give up with qualclass ", qualclass);
|
||||
PrintMessage (3, "number of frontlines = ", adfront->GetNFL());
|
||||
@ -704,7 +714,7 @@ namespace netgen
|
||||
|
||||
|
||||
|
||||
if (mparam.checkchartboundary)
|
||||
if (mp.checkchartboundary)
|
||||
{
|
||||
for (int i = 1; i <= chartboundpoints.Size(); i++)
|
||||
{
|
||||
@ -961,7 +971,7 @@ namespace netgen
|
||||
}
|
||||
|
||||
|
||||
if (found && mparam.checkoverlap)
|
||||
if (found && mp.checkoverlap)
|
||||
{
|
||||
// cout << "checkoverlap" << endl;
|
||||
// test for overlaps
|
||||
|
@ -43,16 +43,16 @@ class Meshing2
|
||||
|
||||
public:
|
||||
///
|
||||
DLL_HEADER Meshing2 (const Box<3> & aboundingbox);
|
||||
DLL_HEADER Meshing2 (const MeshingParameters & mp, const Box<3> & aboundingbox);
|
||||
|
||||
///
|
||||
DLL_HEADER virtual ~Meshing2 ();
|
||||
|
||||
/// Load rules, either from file, or compiled rules
|
||||
void LoadRules (const char * filename);
|
||||
void LoadRules (const char * filename, bool quad);
|
||||
|
||||
///
|
||||
DLL_HEADER MESHING2_RESULT GenerateMesh (Mesh & mesh, double gh, int facenr);
|
||||
DLL_HEADER MESHING2_RESULT GenerateMesh (Mesh & mesh, const MeshingParameters & mp, double gh, int facenr);
|
||||
|
||||
DLL_HEADER void Delaunay (Mesh & mesh, int domainnr, const MeshingParameters & mp);
|
||||
DLL_HEADER void BlockFillLocalH (Mesh & mesh, const MeshingParameters & mp);
|
||||
|
@ -192,7 +192,8 @@ namespace netgen
|
||||
// static double teterrpow = 2;
|
||||
|
||||
double CalcTetBadness (const Point3d & p1, const Point3d & p2,
|
||||
const Point3d & p3, const Point3d & p4, double h)
|
||||
const Point3d & p3, const Point3d & p4, double h,
|
||||
const MeshingParameters & mp)
|
||||
{
|
||||
double vol, l, ll, lll, ll1, ll2, ll3, ll4, ll5, ll6;
|
||||
double err;
|
||||
@ -224,7 +225,7 @@ namespace netgen
|
||||
h * h * ( 1 / ll1 + 1 / ll2 + 1 / ll3 +
|
||||
1 / ll4 + 1 / ll5 + 1 / ll6 ) - 12;
|
||||
|
||||
double teterrpow = mparam.opterrpow;
|
||||
double teterrpow = mp.opterrpow;
|
||||
if(teterrpow < 1) teterrpow = 1;
|
||||
|
||||
if (teterrpow == 1) return err;
|
||||
@ -235,7 +236,8 @@ namespace netgen
|
||||
|
||||
double CalcTetBadnessGrad (const Point3d & p1, const Point3d & p2,
|
||||
const Point3d & p3, const Point3d & p4, double h,
|
||||
int pi, Vec<3> & grad)
|
||||
int pi, Vec<3> & grad,
|
||||
const MeshingParameters & mp)
|
||||
{
|
||||
double vol, l, ll, lll;
|
||||
double err;
|
||||
@ -350,7 +352,7 @@ namespace netgen
|
||||
|
||||
double errpow;
|
||||
|
||||
double teterrpow = mparam.opterrpow;
|
||||
double teterrpow = mp.opterrpow;
|
||||
if(teterrpow < 1) teterrpow = 1;
|
||||
|
||||
if (teterrpow == 1)
|
||||
|
@ -46,18 +46,16 @@ extern int CheckCode ();
|
||||
|
||||
|
||||
///
|
||||
extern double CalcTetBadness (const Point3d & p1,
|
||||
const Point3d & p2,
|
||||
const Point3d & p3,
|
||||
const Point3d & p4,
|
||||
double h);
|
||||
extern double CalcTetBadness (const Point3d & p1, const Point3d & p2,
|
||||
const Point3d & p3, const Point3d & p4,
|
||||
double h,
|
||||
const MeshingParameters & mp = mparam);
|
||||
///
|
||||
extern double CalcTetBadnessGrad (const Point3d & p1,
|
||||
const Point3d & p2,
|
||||
const Point3d & p3,
|
||||
const Point3d & p4,
|
||||
double h, int pi,
|
||||
Vec<3> & grad);
|
||||
extern double CalcTetBadnessGrad (const Point3d & p1, const Point3d & p2,
|
||||
const Point3d & p3, const Point3d & p4,
|
||||
double h, int pi,
|
||||
Vec<3> & grad,
|
||||
const MeshingParameters & mp = mparam);
|
||||
|
||||
|
||||
/** Calculates volume of an element.
|
||||
|
@ -452,7 +452,7 @@ namespace netgen
|
||||
DenseMatrix & trans) const
|
||||
{
|
||||
int np = GetNP();
|
||||
static DenseMatrix pmat(2, np), dshape(2, np);
|
||||
DenseMatrix pmat(2, np), dshape(2, np);
|
||||
pmat.SetSize (2, np);
|
||||
dshape.SetSize (2, np);
|
||||
|
||||
@ -665,8 +665,8 @@ namespace netgen
|
||||
{
|
||||
int i, j;
|
||||
int nip = GetNIP();
|
||||
static DenseMatrix trans(2,2);
|
||||
static DenseMatrix pmat;
|
||||
DenseMatrix trans(2,2);
|
||||
DenseMatrix pmat;
|
||||
|
||||
pmat.SetSize (2, GetNP());
|
||||
GetPointMatrix (points, pmat);
|
||||
@ -783,8 +783,8 @@ namespace netgen
|
||||
}
|
||||
|
||||
int nip = GetNIP();
|
||||
static DenseMatrix trans(2,2), dtrans(2,2);
|
||||
static DenseMatrix pmat, vmat;
|
||||
DenseMatrix trans(2,2), dtrans(2,2);
|
||||
DenseMatrix pmat, vmat;
|
||||
|
||||
pmat.SetSize (2, GetNP());
|
||||
vmat.SetSize (2, GetNP());
|
||||
@ -846,8 +846,8 @@ namespace netgen
|
||||
{
|
||||
int i, j;
|
||||
int nip = GetNIP();
|
||||
static DenseMatrix trans(2,2);
|
||||
static DenseMatrix pmat;
|
||||
DenseMatrix trans(2,2);
|
||||
DenseMatrix pmat;
|
||||
|
||||
pmat.SetSize (2, GetNP());
|
||||
|
||||
@ -1727,7 +1727,7 @@ namespace netgen
|
||||
DenseMatrix & trans) const
|
||||
{
|
||||
int np = GetNP();
|
||||
static DenseMatrix pmat(3, np), dshape(3, np);
|
||||
DenseMatrix pmat(3, np), dshape(3, np);
|
||||
pmat.SetSize (3, np);
|
||||
dshape.SetSize (3, np);
|
||||
|
||||
@ -2037,8 +2037,8 @@ namespace netgen
|
||||
double Element :: CalcJacobianBadness (const T_POINTS & points) const
|
||||
{
|
||||
int nip = GetNIP();
|
||||
static DenseMatrix trans(3,3);
|
||||
static DenseMatrix pmat;
|
||||
DenseMatrix trans(3,3);
|
||||
DenseMatrix pmat;
|
||||
|
||||
pmat.SetSize (3, GetNP());
|
||||
GetPointMatrix (points, pmat);
|
||||
@ -2073,8 +2073,8 @@ namespace netgen
|
||||
{
|
||||
int i, j, k;
|
||||
int nip = GetNIP();
|
||||
static DenseMatrix trans(3,3), dtrans(3,3), hmat(3,3);
|
||||
static DenseMatrix pmat, vmat;
|
||||
DenseMatrix trans(3,3), dtrans(3,3), hmat(3,3);
|
||||
DenseMatrix pmat, vmat;
|
||||
|
||||
pmat.SetSize (3, GetNP());
|
||||
vmat.SetSize (3, GetNP());
|
||||
@ -2148,8 +2148,8 @@ namespace netgen
|
||||
int pi, Vec<3> & grad) const
|
||||
{
|
||||
int nip = GetNIP();
|
||||
static DenseMatrix trans(3,3), dtrans(3,3), hmat(3,3);
|
||||
static DenseMatrix pmat, vmat;
|
||||
DenseMatrix trans(3,3), dtrans(3,3), hmat(3,3);
|
||||
DenseMatrix pmat, vmat;
|
||||
|
||||
pmat.SetSize (3, GetNP());
|
||||
vmat.SetSize (3, GetNP());
|
||||
|
@ -1,8 +1,6 @@
|
||||
#include <mystdlib.h>
|
||||
#include "meshing.hpp"
|
||||
|
||||
// #define MARK
|
||||
// #include <prof.h>
|
||||
|
||||
|
||||
namespace netgen
|
||||
@ -203,7 +201,7 @@ int vnetrule :: IsTriangleInFreeZone (const Point3d & p1,
|
||||
int infreeset, cannot = 0;
|
||||
|
||||
|
||||
static Array<int> pfi(3), pfi2(3);
|
||||
ArrayMem<int,3> pfi(3), pfi2(3);
|
||||
|
||||
// convert from local index to freeset index
|
||||
int i, j;
|
||||
@ -253,7 +251,7 @@ int vnetrule :: IsTriangleInFreeSet (const Point3d & p1, const Point3d & p2,
|
||||
double hpx, hpy, hpz, v1x, v1y, v1z, v2x, v2y, v2z;
|
||||
int act1, act2, act3, it;
|
||||
int cntout;
|
||||
static Array<int> activefaces;
|
||||
Array<int> activefaces;
|
||||
int isin;
|
||||
|
||||
|
||||
@ -870,7 +868,7 @@ int vnetrule :: IsQuadInFreeZone (const Point3d & p1,
|
||||
int infreeset, cannot = 0;
|
||||
|
||||
|
||||
static Array<int> pfi(4), pfi2(4);
|
||||
ArrayMem<int,4> pfi(4), pfi2(4);
|
||||
|
||||
// convert from local index to freeset index
|
||||
int i, j;
|
||||
@ -933,7 +931,7 @@ int vnetrule :: IsQuadInFreeSet (const Point3d & p1, const Point3d & p2,
|
||||
return 1;
|
||||
}
|
||||
|
||||
static Array<int> pi3(3);
|
||||
ArrayMem<int,3> pi3(3);
|
||||
int res;
|
||||
|
||||
pi3.Elem(1) = pi.Get(1);
|
||||
|
@ -493,7 +493,7 @@ void netrule :: LoadRule (istream & ist)
|
||||
extern const char * triarules[];
|
||||
extern const char * quadrules[];
|
||||
|
||||
void Meshing2 :: LoadRules (const char * filename)
|
||||
void Meshing2 :: LoadRules (const char * filename, bool quad)
|
||||
{
|
||||
char buf[256];
|
||||
istream * ist;
|
||||
@ -520,7 +520,8 @@ void Meshing2 :: LoadRules (const char * filename)
|
||||
/* connect tetrules to one string */
|
||||
const char ** hcp;
|
||||
|
||||
if (!mparam.quad)
|
||||
// if (!mparam.quad)
|
||||
if (!quad)
|
||||
{
|
||||
hcp = triarules;
|
||||
PrintMessage (3, "load internal triangle rules");
|
||||
@ -544,7 +545,8 @@ void Meshing2 :: LoadRules (const char * filename)
|
||||
tr1.reserve(len+1);
|
||||
|
||||
|
||||
if (!mparam.quad)
|
||||
// if (!mparam.quad)
|
||||
if (!quad)
|
||||
hcp = triarules;
|
||||
else
|
||||
hcp = quadrules;
|
||||
|
@ -77,26 +77,25 @@ int Meshing3 :: ApplyRules
|
||||
int loktestmode;
|
||||
|
||||
|
||||
static Array<int> pused; // point is already mapped
|
||||
static Array<char> fused; // face is already mapped
|
||||
static Array<int> pmap; // map of reference point to local point
|
||||
static Array<char> pfixed; // point mapped by face-map
|
||||
static Array<int> fmapi; // face in reference is mapped to face nr ...
|
||||
static Array<int> fmapr; // face in reference is rotated to map
|
||||
static Array<Point3d> transfreezone; // transformed free-zone
|
||||
static int cnt = 0;
|
||||
static INDEX_2_CLOSED_HASHTABLE<int> ledges(100); // edges in local environment
|
||||
Array<int> pused; // point is already mapped
|
||||
Array<char> fused; // face is already mapped
|
||||
Array<int> pmap; // map of reference point to local point
|
||||
Array<char> pfixed; // point mapped by face-map
|
||||
Array<int> fmapi; // face in reference is mapped to face nr ...
|
||||
Array<int> fmapr; // face in reference is rotated to map
|
||||
Array<Point3d> transfreezone; // transformed free-zone
|
||||
INDEX_2_CLOSED_HASHTABLE<int> ledges(100); // edges in local environment
|
||||
|
||||
static Array<Point3d> tempnewpoints;
|
||||
static Array<MiniElement2d> tempnewfaces;
|
||||
static Array<int> tempdelfaces;
|
||||
static Array<Element> tempelements;
|
||||
static Array<Box3d> triboxes; // bounding boxes of local faces
|
||||
Array<Point3d> tempnewpoints;
|
||||
Array<MiniElement2d> tempnewfaces;
|
||||
Array<int> tempdelfaces;
|
||||
Array<Element> tempelements;
|
||||
Array<Box3d> triboxes; // bounding boxes of local faces
|
||||
|
||||
Array<int, PointIndex::BASE> pnearness;
|
||||
Array<int> fnearness;
|
||||
|
||||
static Array<int, PointIndex::BASE> pnearness;
|
||||
static Array<int> fnearness;
|
||||
|
||||
static int cnt = 0;
|
||||
cnt++;
|
||||
|
||||
delfaces.SetSize (0);
|
||||
|
@ -8,84 +8,6 @@ namespace netgen
|
||||
|
||||
static const MeshOptimize2d * meshthis;
|
||||
|
||||
|
||||
#ifdef OLD
|
||||
|
||||
void CalcTriangleBadness (double x2, double x3, double y3, double metricweight,
|
||||
double h, double & badness, double & g1x, double & g1y)
|
||||
{
|
||||
// badness = sqrt(3.0) /36 * circumference^2 / area - 1
|
||||
// p1 = (0, 0), p2 = (x2, 0), p3 = (x3, y3);
|
||||
|
||||
Vec2d v23;
|
||||
double l12, l13, l23, cir, area;
|
||||
static const double c = sqrt(3.0) / 36;
|
||||
double c1, c2, c3, c4;
|
||||
|
||||
v23.X() = x3 - x2;
|
||||
v23.Y() = y3;
|
||||
|
||||
l12 = x2;
|
||||
l13 = sqrt (x3*x3 + y3*y3);
|
||||
l23 = v23.Length();
|
||||
|
||||
cir = l12 + l13 + l23;
|
||||
area = 0.5 * x2 * y3;
|
||||
|
||||
if (area <= 1e-24 * cir * cir)
|
||||
{
|
||||
g1x = 0;
|
||||
g1y = 0;
|
||||
badness = 1e10;
|
||||
return;
|
||||
}
|
||||
|
||||
badness = c * cir * cir / area - 1;
|
||||
|
||||
c1 = 2 * c * cir / area;
|
||||
c2 = 0.5 * c * cir * cir / (area * area);
|
||||
|
||||
g1x = c1 * ( - 1 - x3 / l13) - c2 * (-v23.Y());
|
||||
g1y = c1 * ( - y3 / l13) - c2 * ( v23.X());
|
||||
|
||||
// metricweight = 0.1;
|
||||
if (metricweight > 0)
|
||||
{
|
||||
// area = (x2 - x1) * (y3 - y1) - (x3 - x1) * (y2 - y1);
|
||||
// add: metricweight * (area / h^2 + h^2 / area - 2)
|
||||
|
||||
const double area = x2 * y3;
|
||||
const double dareax1 = -y3;
|
||||
const double dareay1 = x3 - x2;
|
||||
|
||||
const double areahh = area / (h * h);
|
||||
const double fac = metricweight * (areahh - 1 / areahh) / area;
|
||||
|
||||
badness += metricweight * (areahh + 1 / areahh - 2);
|
||||
g1x += fac * dareax1;
|
||||
g1y += fac * dareay1;
|
||||
|
||||
/*
|
||||
// add: metricweight * (l1^2/h^2 + l2^2/h^2 + l3^2/h2 + h^2/l1^2 + h^2/l2^2 + h^2/l3^2 - 6)
|
||||
double h2 = h*h;
|
||||
double l1 = x2*x2;
|
||||
double l2 = x3*x3+y3*y3;
|
||||
double l3 = (x2-x3)*(x2-x3)+y3*y3;
|
||||
double dl1dx = 2*(-x2);
|
||||
double dl1dy = 0;
|
||||
double dl2dx = -2*x3;
|
||||
double dl2dy = -2*y3;
|
||||
|
||||
badness += (l1/h2 + l2/h2 + l3/h2 +h2/l1 + h2/l2 + h2/l3-6) * metricweight;
|
||||
|
||||
g1x += metricweight * (dl1dx/h2-h2/(l1*l1)*dl1dx + dl2dx/h2-h2/(l2*l2)*dl2dx);
|
||||
g1y += metricweight * (dl1dy/h2-h2/(l1*l1)*dl1dy + dl2dy/h2-h2/(l2*l2)*dl2dy);
|
||||
*/
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
static const double c_trig = 0.14433756; // sqrt(3.0) / 12
|
||||
static const double c_trig4 = 0.57735026; // sqrt(3.0) / 3
|
||||
|
||||
@ -162,38 +84,6 @@ namespace netgen
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#ifdef OLD
|
||||
double CalcTriangleBadness (const Point3d & p1,
|
||||
const Point3d & p2,
|
||||
const Point3d & p3,
|
||||
double metricweight,
|
||||
double h)
|
||||
{
|
||||
double badness;
|
||||
double g1x, g1y;
|
||||
|
||||
Vec3d e1 (p1, p2);
|
||||
Vec3d e2 (p1, p3);
|
||||
|
||||
double e1l = e1.Length() + 1e-24;
|
||||
e1 /= e1l;
|
||||
double e1e2 = (e1 * e2);
|
||||
e2.Add (-e1e2, e1);
|
||||
double e2l = e2.Length();
|
||||
|
||||
CalcTriangleBadness ( e1l, e1e2, e2l,
|
||||
metricweight, h, badness, g1x, g1y);
|
||||
return badness;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
|
||||
double CalcTriangleBadness (const Point3d & p1,
|
||||
const Point3d & p2,
|
||||
const Point3d & p3,
|
||||
@ -274,6 +164,7 @@ namespace netgen
|
||||
class Opti2SurfaceMinFunction : public MinFunction
|
||||
{
|
||||
const Mesh & mesh;
|
||||
|
||||
public:
|
||||
Opti2SurfaceMinFunction (const Mesh & amesh)
|
||||
: mesh(amesh)
|
||||
@ -416,6 +307,7 @@ namespace netgen
|
||||
class Opti2EdgeMinFunction : public MinFunction
|
||||
{
|
||||
const Mesh & mesh;
|
||||
|
||||
public:
|
||||
Opti2EdgeMinFunction (const Mesh & amesh)
|
||||
: mesh(amesh) { } ;
|
||||
@ -650,7 +542,7 @@ namespace netgen
|
||||
;
|
||||
}
|
||||
|
||||
void MeshOptimize2d :: ImproveMesh (Mesh & mesh)
|
||||
void MeshOptimize2d :: ImproveMesh (Mesh & mesh, const MeshingParameters & mp)
|
||||
{
|
||||
if (!faceindex)
|
||||
{
|
||||
@ -658,7 +550,7 @@ namespace netgen
|
||||
|
||||
for (faceindex = 1; faceindex <= mesh.GetNFD(); faceindex++)
|
||||
{
|
||||
ImproveMesh (mesh);
|
||||
ImproveMesh (mesh, mp);
|
||||
if (multithread.terminate)
|
||||
throw NgException ("Meshing stopped");
|
||||
}
|
||||
@ -702,7 +594,7 @@ namespace netgen
|
||||
|
||||
Array<MeshPoint, PointIndex::BASE> savepoints(mesh.GetNP());
|
||||
|
||||
uselocalh = mparam.uselocalh;
|
||||
uselocalh = mp.uselocalh;
|
||||
|
||||
|
||||
Array<int, PointIndex::BASE> nelementsonpoint(mesh.GetNP());
|
||||
@ -724,7 +616,7 @@ namespace netgen
|
||||
}
|
||||
|
||||
|
||||
loch = mparam.maxh;
|
||||
loch = mp.maxh;
|
||||
locmetricweight = metricweight;
|
||||
meshthis = this;
|
||||
|
||||
|
@ -23,7 +23,6 @@ namespace netgen
|
||||
void MinFunctionSum :: Grad (const Vector & x, Vector & g) const
|
||||
{
|
||||
g = 0.;
|
||||
// static Vector gi(3);
|
||||
VectorMem<3> gi;
|
||||
for(int i=0; i<functions.Size(); i++)
|
||||
{
|
||||
@ -38,7 +37,7 @@ namespace netgen
|
||||
{
|
||||
double retval = 0;
|
||||
g = 0.;
|
||||
static Vector gi(3);
|
||||
VectorMem<3> gi;
|
||||
for(int i=0; i<functions.Size(); i++)
|
||||
{
|
||||
retval += functions[i]->FuncGrad(x,gi);
|
||||
@ -121,10 +120,6 @@ namespace netgen
|
||||
double PointFunction1 ::
|
||||
FuncDeriv (const Vector & x, const Vector & dir, double & deriv) const
|
||||
{
|
||||
/*
|
||||
static Vector hx(3);
|
||||
static double eps = 1e-6;
|
||||
*/
|
||||
VectorMem<3> hx;
|
||||
const double eps = 1e-6;
|
||||
|
||||
@ -150,8 +145,8 @@ namespace netgen
|
||||
|
||||
double PointFunction1 :: FuncGrad (const Vector & x, Vector & g) const
|
||||
{
|
||||
static Vector hx(3);
|
||||
static double eps = 1e-6;
|
||||
VectorMem<3> hx;
|
||||
double eps = 1e-6;
|
||||
|
||||
hx = x;
|
||||
for (int i = 0; i < 3; i++)
|
||||
@ -247,9 +242,8 @@ namespace netgen
|
||||
|
||||
int i;
|
||||
double badness = 0;
|
||||
static Vector hv(4);
|
||||
static Vector res;
|
||||
res.SetSize (m.Height());
|
||||
VectorMem<4> hv;
|
||||
Vector res(m.Height());
|
||||
|
||||
for (i = 0;i < 3; i++)
|
||||
hv(i) = vp(i);
|
||||
@ -270,8 +264,8 @@ namespace netgen
|
||||
|
||||
double CheapPointFunction1 :: FuncGrad (const Vector & x, Vector & g) const
|
||||
{
|
||||
static Vector hx(3);
|
||||
static double eps = 1e-6;
|
||||
VectorMem<3> hx;
|
||||
double eps = 1e-6;
|
||||
|
||||
hx = x;
|
||||
for (int i = 0; i < 3; i++)
|
||||
@ -546,8 +540,8 @@ namespace netgen
|
||||
|
||||
double CheapPointFunction :: PointFunctionValue (const Point<3> & pp) const
|
||||
{
|
||||
static Vector p4(4);
|
||||
static Vector di;
|
||||
VectorMem<4> p4;
|
||||
Vector di;
|
||||
int n = m.Height();
|
||||
|
||||
p4(0) = pp(0);
|
||||
@ -574,8 +568,8 @@ namespace netgen
|
||||
|
||||
double CheapPointFunction :: PointFunctionValueGrad (const Point<3> & pp, Vec<3> & grad) const
|
||||
{
|
||||
static Vector p4(4);
|
||||
static Vector di;
|
||||
VectorMem<4> p4;
|
||||
Vector di;
|
||||
|
||||
int n = m.Height();
|
||||
|
||||
@ -686,7 +680,7 @@ namespace netgen
|
||||
{
|
||||
int n = x.Size();
|
||||
|
||||
static Vector hx;
|
||||
Vector hx;
|
||||
hx.SetSize(n);
|
||||
|
||||
double eps = 1e-8;
|
||||
@ -800,7 +794,7 @@ namespace netgen
|
||||
{
|
||||
Vec3d n, vgrad;
|
||||
Point3d pp1;
|
||||
static Vector freegrad(3);
|
||||
VectorMem<3> freegrad;
|
||||
|
||||
CalcNewPoint (x, pp1);
|
||||
|
||||
@ -893,7 +887,7 @@ double Opti3EdgeMinFunction :: FuncGrad (const Vector & x, Vector & grad) const
|
||||
Vec3d n1, n2, v1, vgrad;
|
||||
Point3d pp1;
|
||||
double badness;
|
||||
static Vector freegrad(3);
|
||||
VectorMem<3> freegrad;
|
||||
|
||||
CalcNewPoint (x, pp1);
|
||||
|
||||
@ -923,7 +917,8 @@ double Opti3EdgeMinFunction :: FuncGrad (const Vector & x, Vector & grad) const
|
||||
|
||||
|
||||
double CalcTotalBad (const Mesh::T_POINTS & points,
|
||||
const Mesh::T_VOLELEMENTS & elements)
|
||||
const Mesh::T_VOLELEMENTS & elements,
|
||||
const MeshingParameters & mp)
|
||||
{
|
||||
double sum = 0;
|
||||
double elbad;
|
||||
@ -931,7 +926,7 @@ double CalcTotalBad (const Mesh::T_POINTS & points,
|
||||
tets_in_qualclass.SetSize(20);
|
||||
tets_in_qualclass = 0;
|
||||
|
||||
double teterrpow = mparam.opterrpow;
|
||||
double teterrpow = mp.opterrpow;
|
||||
|
||||
for (int i = 1; i <= elements.Size(); i++)
|
||||
{
|
||||
|
@ -156,7 +156,7 @@ void CutOffAndCombine (Mesh & mesh, const Mesh & othermesh)
|
||||
mesh.AddLockedPoint (pmat.Elem(i));
|
||||
|
||||
mesh.CalcSurfacesOfNode();
|
||||
mesh.CalcLocalH();
|
||||
mesh.CalcLocalH(mparam.grading);
|
||||
}
|
||||
|
||||
|
||||
|
@ -112,8 +112,8 @@ namespace netgen
|
||||
|
||||
gp_Pnt2d parmid;
|
||||
|
||||
parmid.SetX(0.3*(par0.X()+par1.X()+par2.X()));
|
||||
parmid.SetY(0.3*(par0.Y()+par1.Y()+par2.Y()));
|
||||
parmid.SetX( (par0.X()+par1.X()+par2.X()) / 3 );
|
||||
parmid.SetY( (par0.Y()+par1.Y()+par2.Y()) / 3 );
|
||||
|
||||
if (depth%3 == 0)
|
||||
{
|
||||
|
@ -320,7 +320,7 @@ int STLSurfaceMeshing (STLGeometry & geom,
|
||||
mesh.CalcSurfacesOfNode();
|
||||
optmesh.EdgeSwapping (mesh, 0);
|
||||
mesh.CalcSurfacesOfNode();
|
||||
optmesh.ImproveMesh (mesh);
|
||||
optmesh.ImproveMesh (mesh, mparam);
|
||||
}
|
||||
|
||||
mesh.Compress();
|
||||
@ -606,7 +606,7 @@ void STLSurfaceMeshing1 (STLGeometry & geom,
|
||||
return;
|
||||
|
||||
PrintMessage(5,"Meshing surface ", fnr, "/", mesh.GetNFD());
|
||||
MeshingSTLSurface meshing (geom);
|
||||
MeshingSTLSurface meshing (geom, mparam);
|
||||
|
||||
meshing.SetStartTime (starttime);
|
||||
|
||||
@ -666,7 +666,7 @@ void STLSurfaceMeshing1 (STLGeometry & geom,
|
||||
/*
|
||||
(*testout) << "start meshing with h = " << h << endl;
|
||||
*/
|
||||
meshing.GenerateMesh (mesh, h, fnr); // face index
|
||||
meshing.GenerateMesh (mesh, mparam, h, fnr); // face index
|
||||
|
||||
extern void Render();
|
||||
Render();
|
||||
@ -727,7 +727,7 @@ void STLSurfaceOptimization (STLGeometry & geom,
|
||||
}
|
||||
case 'm':
|
||||
{
|
||||
optmesh.ImproveMesh(mesh);
|
||||
optmesh.ImproveMesh(mesh, mparam);
|
||||
break;
|
||||
}
|
||||
case 'c':
|
||||
@ -749,8 +749,9 @@ void STLSurfaceOptimization (STLGeometry & geom,
|
||||
|
||||
|
||||
|
||||
MeshingSTLSurface :: MeshingSTLSurface (STLGeometry & ageom)
|
||||
: Meshing2(ageom.GetBoundingBox()), geom(ageom)
|
||||
MeshingSTLSurface :: MeshingSTLSurface (STLGeometry & ageom,
|
||||
const MeshingParameters & mp)
|
||||
: Meshing2(mp, ageom.GetBoundingBox()), geom(ageom)
|
||||
{
|
||||
;
|
||||
}
|
||||
|
@ -23,7 +23,7 @@ class MeshingSTLSurface : public Meshing2
|
||||
int transformationtrig;
|
||||
public:
|
||||
///
|
||||
MeshingSTLSurface (STLGeometry & ageom);
|
||||
MeshingSTLSurface (STLGeometry & ageom, const MeshingParameters & mp);
|
||||
|
||||
protected:
|
||||
///
|
||||
|
@ -1451,7 +1451,8 @@ int STLMeshingDummy (STLGeometry* stlgeometry, Mesh*& mesh, MeshingParameters &
|
||||
stlgeometry->GetBoundingBox().PMax() + Vec3d(10, 10, 10),
|
||||
mparam.grading);
|
||||
mesh -> LoadLocalMeshSize (mparam.meshsizefilename);
|
||||
mesh -> CalcLocalHFromSurfaceCurvature (stlparam.resthsurfmeshcurvfac);
|
||||
mesh -> CalcLocalHFromSurfaceCurvature (mparam.grading,
|
||||
stlparam.resthsurfmeshcurvfac);
|
||||
mparam.optimize2d = "cmsmSm";
|
||||
STLSurfaceOptimization (*stlgeometry, *mesh, mparam);
|
||||
#ifdef STAT_STREAM
|
||||
@ -1502,7 +1503,7 @@ int STLMeshingDummy (STLGeometry* stlgeometry, Mesh*& mesh, MeshingParameters &
|
||||
stlgeometry->GetBoundingBox().PMax() + Vec3d(10, 10, 10),
|
||||
mparam.grading);
|
||||
mesh -> LoadLocalMeshSize (mparam.meshsizefilename);
|
||||
mesh -> CalcLocalH ();
|
||||
mesh -> CalcLocalH (mparam.grading);
|
||||
}
|
||||
|
||||
|
||||
|
@ -571,7 +571,8 @@ namespace netgen
|
||||
stlgeometry -> RestrictLocalH(*mesh, mparam.maxh);
|
||||
|
||||
if (stlparam.resthsurfmeshcurvenable)
|
||||
mesh -> CalcLocalHFromSurfaceCurvature (stlparam.resthsurfmeshcurvfac);
|
||||
mesh -> CalcLocalHFromSurfaceCurvature (mparam.grading,
|
||||
stlparam.resthsurfmeshcurvfac);
|
||||
}
|
||||
|
||||
return TCL_OK;
|
||||
|
@ -4454,7 +4454,7 @@ namespace netgen
|
||||
int argc, tcl_const char *argv[])
|
||||
{
|
||||
int i;
|
||||
static char buf[1000];
|
||||
char buf[1000];
|
||||
buf[0] = 0;
|
||||
|
||||
if (argc >= 2)
|
||||
|
@ -379,7 +379,7 @@ namespace netgen
|
||||
mesh->GetNE(), " Elements.");
|
||||
|
||||
mesh->SetGlobalH (mparam.maxh);
|
||||
mesh->CalcLocalH();
|
||||
mesh->CalcLocalH(mparam.grading);
|
||||
|
||||
return TCL_OK;
|
||||
}
|
||||
@ -1024,7 +1024,7 @@ namespace netgen
|
||||
}
|
||||
|
||||
mesh->SetGlobalH (mparam.maxh);
|
||||
mesh->CalcLocalH();
|
||||
mesh->CalcLocalH(mparam.grading);
|
||||
|
||||
return TCL_OK;
|
||||
}
|
||||
@ -1083,7 +1083,7 @@ namespace netgen
|
||||
Mesh othermesh;
|
||||
othermesh.Load (argv[1]);
|
||||
othermesh.SetGlobalH (mparam.maxh);
|
||||
othermesh.CalcLocalH();
|
||||
othermesh.CalcLocalH(mparam.grading);
|
||||
|
||||
CutOffAndCombine (*mesh, othermesh);
|
||||
return TCL_OK;
|
||||
@ -1644,7 +1644,7 @@ namespace netgen
|
||||
*/
|
||||
|
||||
if(!mesh->LocalHFunctionGenerated())
|
||||
mesh->CalcLocalH();
|
||||
mesh->CalcLocalH(mparam.grading);
|
||||
|
||||
mesh->LocalHFunction().SetGrading (mparam.grading);
|
||||
ref . Bisect (*mesh, biopt);
|
||||
|
@ -366,7 +366,7 @@ namespace nglib
|
||||
//MeshingParameters mparam;
|
||||
mp->Transfer_Parameters();
|
||||
|
||||
m->CalcLocalH();
|
||||
m->CalcLocalH(mparam.grading);
|
||||
|
||||
MeshVolume (mparam, *m);
|
||||
RemoveIllegalElements (*m);
|
||||
|
Loading…
Reference in New Issue
Block a user