use surfindex as hash-key in FindOpenSegments

This commit is contained in:
Joachim Schöberl 2019-09-24 10:34:36 +02:00
parent 54fa0d81ec
commit 71758de667

View File

@ -2219,9 +2219,9 @@ namespace netgen
// int i, j, k; // int i, j, k;
// new version, general elements // new version, general elements
// hash index: pnum1-2 // hash index: pnum1-2, surfnr
// hash data : surfnr, surfel-nr (pos) or segment nr(neg) // hash data : surfel-nr (pos) or segment nr(neg)
INDEX_2_HASHTABLE<INDEX_2> faceht(4 * GetNSE()+GetNSeg()+1); INDEX_3_HASHTABLE<int> faceht(4 * GetNSE()+GetNSeg()+1);
PrintMessage (5, "Test Opensegments"); PrintMessage (5, "Test Opensegments");
for (int i = 1; i <= GetNSeg(); i++) for (int i = 1; i <= GetNSeg(); i++)
@ -2230,8 +2230,8 @@ namespace netgen
if (surfnr == 0 || seg.si == surfnr) if (surfnr == 0 || seg.si == surfnr)
{ {
INDEX_2 key(seg[0], seg[1]); INDEX_3 key(seg[0], seg[1], seg.si);
INDEX_2 data(seg.si, -i); int data = -i;
if (faceht.Used (key)) if (faceht.Used (key))
{ {
@ -2244,6 +2244,8 @@ namespace netgen
} }
/*
// not possible with surfnr as hash-index
for (int i = 1; i <= GetNSeg(); i++) for (int i = 1; i <= GetNSeg(); i++)
{ {
const Segment & seg = LineSegment (i); const Segment & seg = LineSegment (i);
@ -2258,6 +2260,8 @@ namespace netgen
} }
} }
} }
*/
// bool buggy = false; // bool buggy = false;
// ofstream bout("buggy.out"); // ofstream bout("buggy.out");
@ -2271,15 +2275,18 @@ namespace netgen
{ {
for (int j = 1; j <= el.GetNP(); j++) for (int j = 1; j <= el.GetNP(); j++)
{ {
INDEX_2 seg (el.PNumMod(j), el.PNumMod(j+1)); INDEX_3 seg (el.PNumMod(j), el.PNumMod(j+1), el.GetIndex());
INDEX_2 data; int data;
if (seg.I1() < PointIndex::BASE || seg.I2() < PointIndex::BASE) if (seg.I1() < PointIndex::BASE || seg.I2() < PointIndex::BASE)
cerr << "seg = " << seg << endl; cerr << "seg = " << seg << endl;
if (faceht.Used(seg)) if (faceht.Used(seg))
{ {
faceht.Set (seg, 0);
/*
data = faceht.Get(seg); data = faceht.Get(seg);
if (data.I1() == el.GetIndex()) if (data.I1() == el.GetIndex())
{ {
data.I1() = 0; data.I1() = 0;
@ -2290,46 +2297,16 @@ namespace netgen
// buggy = true; // buggy = true;
PrintWarning ("hash table si not fitting for segment: ", PrintWarning ("hash table si not fitting for segment: ",
seg.I1(), "-", seg.I2(), " other = ", seg.I1(), "-", seg.I2(), " other = ",
data.I2()); data.I2(), ", surfnr = ", surfnr);
// cout << "me: index = " << el.GetIndex() << ", el = " << el << endl;
/*
bout << "has index = " << seg << endl;
bout << "hash value = " << faceht.HashValue (seg) << endl;
if (data.I2() > 0)
{
int io = data.I2();
cout << "other trig: index = " << SurfaceElement(io).GetIndex()
<< ", el = " << SurfaceElement(io) << endl;
}
else
{
cout << "other seg " << -data.I2() << ", si = " << data.I1() << endl;
}
bout << "me: index = " << el.GetIndex() << ", el = " << el << endl;
if (data.I2() > 0)
{
int io = data.I2();
bout << "other trig: index = " << SurfaceElement(io).GetIndex()
<< ", el = " << SurfaceElement(io) << endl;
}
else
{
bout << "other seg " << -data.I2() << ", si = " << data.I1() << endl;
} }
*/ */
} }
}
else else
{ {
Swap (seg.I1(), seg.I2()); Swap (seg.I1(), seg.I2());
data.I1() = el.GetIndex(); // data.I1() = el.GetIndex();
data.I2() = i; // data.I2() = i;
faceht.Set (seg, i);
faceht.Set (seg, data);
} }
} }
} }
@ -2365,21 +2342,21 @@ namespace netgen
for (int i = 1; i <= faceht.GetNBags(); i++) for (int i = 1; i <= faceht.GetNBags(); i++)
for (int j = 1; j <= faceht.GetBagSize(i); j++) for (int j = 1; j <= faceht.GetBagSize(i); j++)
{ {
INDEX_2 i2; INDEX_3 i2;
INDEX_2 data; int data;
faceht.GetData (i, j, i2, data); faceht.GetData (i, j, i2, data);
if (data.I1()) // surfnr if (data) // surfnr
{ {
Segment seg; Segment seg;
seg[0] = i2.I1(); seg[0] = i2.I1();
seg[1] = i2.I2(); seg[1] = i2.I2();
seg.si = data.I1(); seg.si = i2.I3();
// find geomdata: // find geomdata:
if (data.I2() > 0) if (data > 0)
{ {
// segment due to triangle // segment due to triangle
const Element2d & el = SurfaceElement (data.I2()); const Element2d & el = SurfaceElement (data);
for (int k = 1; k <= el.GetNP(); k++) for (int k = 1; k <= el.GetNP(); k++)
{ {
if (seg[0] == el.PNum(k)) if (seg[0] == el.PNum(k))
@ -2393,7 +2370,7 @@ namespace netgen
else else
{ {
// segment due to line // segment due to line
const Segment & lseg = LineSegment (-data.I2()); const Segment & lseg = LineSegment (-data);
seg.geominfo[0] = lseg.geominfo[0]; seg.geominfo[0] = lseg.geominfo[0];
seg.geominfo[1] = lseg.geominfo[1]; seg.geominfo[1] = lseg.geominfo[1];