mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-11 21:50:34 +05:00
fixing delaunay2d point search, non-parallel for small meshes
This commit is contained in:
parent
de83f0ca14
commit
cddfb4a0b5
@ -18,6 +18,19 @@ namespace ngcore
|
|||||||
size_t size = entrysize.Size();
|
size_t size = entrysize.Size();
|
||||||
size_t * index = new size_t[size+1];
|
size_t * index = new size_t[size+1];
|
||||||
|
|
||||||
|
if (entrysize.Size() < 100)
|
||||||
|
{
|
||||||
|
size_t mysum = 0;
|
||||||
|
for (size_t i = 0; i < entrysize.Size(); i++)
|
||||||
|
{
|
||||||
|
index[i] = mysum;
|
||||||
|
mysum += entrysize[i];
|
||||||
|
}
|
||||||
|
index[entrysize.Size()] = mysum;
|
||||||
|
return index;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Array<size_t> partial_sums(TaskManager::GetNumThreads()+1);
|
Array<size_t> partial_sums(TaskManager::GetNumThreads()+1);
|
||||||
partial_sums[0] = 0;
|
partial_sums[0] = 0;
|
||||||
ParallelJob
|
ParallelJob
|
||||||
|
@ -337,6 +337,25 @@ namespace ngcore
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (antasks == 1)
|
||||||
|
{
|
||||||
|
if (trace)
|
||||||
|
trace->StartJob(jobnr, afunc.target_type());
|
||||||
|
jobnr++;
|
||||||
|
if (startup_function) (*startup_function)();
|
||||||
|
TaskInfo ti;
|
||||||
|
ti.task_nr = 0;
|
||||||
|
ti.ntasks = 1;
|
||||||
|
ti.thread_nr = 0; ti.nthreads = 1;
|
||||||
|
{
|
||||||
|
RegionTracer t(ti.thread_nr, jobnr, RegionTracer::ID_JOB, ti.task_nr);
|
||||||
|
afunc(ti);
|
||||||
|
}
|
||||||
|
if (cleanup_function) (*cleanup_function)();
|
||||||
|
if (trace)
|
||||||
|
trace->StopJob();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (trace)
|
if (trace)
|
||||||
trace->StartJob(jobnr, afunc.target_type());
|
trace->StartJob(jobnr, afunc.target_type());
|
||||||
|
@ -45,8 +45,10 @@ namespace netgen
|
|||||||
Point<2> p1 = P2(mesh[pnums[0]]);
|
Point<2> p1 = P2(mesh[pnums[0]]);
|
||||||
Point<2> p2 = P2(mesh[pnums[1]]);
|
Point<2> p2 = P2(mesh[pnums[1]]);
|
||||||
Point<2> p3 = P2(mesh[pnums[2]]);
|
Point<2> p3 = P2(mesh[pnums[2]]);
|
||||||
|
|
||||||
Vec<2> v1 = p2-p1;
|
Vec<2> v1 = p2-p1;
|
||||||
Vec<2> v2 = p3-p1;
|
Vec<2> v2 = p3-p1;
|
||||||
|
/*
|
||||||
Mat<2,2> mat, inv;
|
Mat<2,2> mat, inv;
|
||||||
mat(0,0) = v1*v1;
|
mat(0,0) = v1*v1;
|
||||||
mat(0,1) = v1*v2;
|
mat(0,1) = v1*v2;
|
||||||
@ -60,7 +62,22 @@ namespace netgen
|
|||||||
|
|
||||||
c = p1 + sol(0) * v1 + sol(1) * v2;
|
c = p1 + sol(0) * v1 + sol(1) * v2;
|
||||||
rad2 = Dist2(c, p1);
|
rad2 = Dist2(c, p1);
|
||||||
r = sqrt(rad2);
|
r = sqrt(rad2);
|
||||||
|
*/
|
||||||
|
|
||||||
|
// without normal equation ...
|
||||||
|
Mat<2,2> mat, inv;
|
||||||
|
mat(0,0) = v1(0); mat(0,1) = v1(1);
|
||||||
|
mat(1,0) = v2(0); mat(1,1) = v2(1);
|
||||||
|
CalcInverse (mat, inv);
|
||||||
|
Vec<2> rhs, sol;
|
||||||
|
rhs(0) = 0.5 * v1*v1;
|
||||||
|
rhs(1) = 0.5 * v2*v2;
|
||||||
|
sol = inv * rhs;
|
||||||
|
c = p1 + sol;
|
||||||
|
|
||||||
|
rad2 = Dist2(c, p1);
|
||||||
|
r = sqrt(rad2);
|
||||||
}
|
}
|
||||||
|
|
||||||
Point<2> Center() const { return c; }
|
Point<2> Center() const { return c; }
|
||||||
@ -246,6 +263,7 @@ namespace netgen
|
|||||||
|
|
||||||
if(definitive_overlapping_trig==-1)
|
if(definitive_overlapping_trig==-1)
|
||||||
{
|
{
|
||||||
|
static Timer t("slow check"); RegionTimer reg(t);
|
||||||
PrintMessage (5, "Warning in delaunay tree - didn't find overlapping circle, check all trigs again");
|
PrintMessage (5, "Warning in delaunay tree - didn't find overlapping circle, check all trigs again");
|
||||||
for(auto i_trig : trigs.Range())
|
for(auto i_trig : trigs.Range())
|
||||||
{
|
{
|
||||||
@ -257,7 +275,8 @@ namespace netgen
|
|||||||
double rad2 = trig.Radius2();
|
double rad2 = trig.Radius2();
|
||||||
double d2 = Dist2 (trig.Center(), newp);
|
double d2 = Dist2 (trig.Center(), newp);
|
||||||
|
|
||||||
if (d2 < 0.999 * rad2)
|
// if (d2 < 0.999 * rad2)
|
||||||
|
if (d2 < (1-1e-10)*rad2)
|
||||||
{
|
{
|
||||||
definitive_overlapping_trig = i_trig;
|
definitive_overlapping_trig = i_trig;
|
||||||
break;
|
break;
|
||||||
|
@ -6410,7 +6410,9 @@ namespace netgen
|
|||||||
for (SurfaceElementIndex ei : myrange)
|
for (SurfaceElementIndex ei : myrange)
|
||||||
for (PointIndex pi : (*this)[ei].PNums())
|
for (PointIndex pi : (*this)[ei].PNums())
|
||||||
creator.Add (pi, ei);
|
creator.Add (pi, ei);
|
||||||
}, ngcore::TasksPerThread(4));
|
},
|
||||||
|
// ngcore::TasksPerThread(4));
|
||||||
|
(surfelements.Size()>100) ? ngcore::TasksPerThread(4) : 1);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -6432,7 +6434,8 @@ namespace netgen
|
|||||||
{
|
{
|
||||||
for (PointIndex pi : myrange)
|
for (PointIndex pi : myrange)
|
||||||
QuickSort(elementsonnode[pi]);
|
QuickSort(elementsonnode[pi]);
|
||||||
});
|
},
|
||||||
|
(surfelements.Size()>100) ? ngcore::TasksPerThread(1) : 1);
|
||||||
|
|
||||||
return move(elementsonnode);
|
return move(elementsonnode);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user