mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-13 22:50:33 +05:00
use surfindex as hash-key in FindOpenSegments
This commit is contained in:
parent
54fa0d81ec
commit
71758de667
@ -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];
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user