mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-11 21:50:34 +05:00
less hash-table searching in buildedges
This commit is contained in:
parent
0605097bdc
commit
054386388e
@ -632,24 +632,16 @@ namespace ngcore
|
||||
size_t UsedElements () const
|
||||
{
|
||||
return used;
|
||||
/*
|
||||
size_t cnt = 0;
|
||||
for (size_t i = 0; i < size; i++)
|
||||
if (hash[i] != invalid)
|
||||
cnt++;
|
||||
return cnt;
|
||||
*/
|
||||
}
|
||||
|
||||
size_t Position (const T_HASH ind) const
|
||||
{
|
||||
size_t i = HashValue2(ind, mask);
|
||||
while (1)
|
||||
while (true)
|
||||
{
|
||||
if (hash[i] == ind) return i;
|
||||
if (hash[i] == invalid) return size_t(-1);
|
||||
i++;
|
||||
if (i >= size) i = 0;
|
||||
i = (i+1) & mask;
|
||||
}
|
||||
}
|
||||
|
||||
@ -668,7 +660,7 @@ namespace ngcore
|
||||
|
||||
size_t i = HashValue2 (ind, mask);
|
||||
|
||||
while (1)
|
||||
while (true)
|
||||
{
|
||||
if (hash[i] == invalid)
|
||||
{
|
||||
@ -682,8 +674,7 @@ namespace ngcore
|
||||
apos = i;
|
||||
return false;
|
||||
}
|
||||
i++;
|
||||
if (i >= size) i = 0;
|
||||
i = (i+1) & mask;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -523,32 +523,24 @@ namespace netgen
|
||||
v2eht.Set (v2, ednr);
|
||||
}
|
||||
|
||||
int cnti = 0;
|
||||
size_t usedold = v2eht.UsedElements();
|
||||
|
||||
for (int v2 : vert2vertcoarse[v])
|
||||
if (!v2eht.Used(v2))
|
||||
{
|
||||
cnti++;
|
||||
v2eht.Set (v2, 33); // some value
|
||||
}
|
||||
v2eht.Set (v2, 33); // some value
|
||||
|
||||
LoopOverEdges (*mesh, *this, v,
|
||||
[&] (INDEX_2 edge, int elnr, int loc_edge, int element_dim)
|
||||
{
|
||||
if (!v2eht.Used (edge.I2()))
|
||||
{
|
||||
cnti++;
|
||||
v2eht.Set (edge.I2(), 33); // something
|
||||
}
|
||||
v2eht.Set (edge[1], 33); // something
|
||||
});
|
||||
cnt[v] = cnti;
|
||||
|
||||
cnt[v] = v2eht.UsedElements()-usedold;
|
||||
}
|
||||
}, TasksPerThread(4) );
|
||||
|
||||
// accumulate number of edges
|
||||
int ned = edge2vert.Size();
|
||||
|
||||
// for (size_t v = 0; v < mesh->GetNV(); v++)
|
||||
for (size_t v : cnt.Range())
|
||||
{
|
||||
auto hv = cnt[v];
|
||||
@ -571,13 +563,14 @@ namespace netgen
|
||||
auto end = r.Next();
|
||||
// INDEX_CLOSED_HASHTABLE<int> v2eht(2*max_edge_on_vertex+10);
|
||||
ngcore::ClosedHashTable<int, int> v2eht(2*max_edge_on_vertex+10);
|
||||
|
||||
Array<int> vertex2;
|
||||
for (PointIndex v = begin+PointIndex::BASE;
|
||||
v < end+PointIndex::BASE; v++)
|
||||
{
|
||||
int ned = cnt[v];
|
||||
v2eht.DeleteData();
|
||||
vertex2.SetSize (0);
|
||||
vertex2.SetSize0 ();
|
||||
|
||||
for (int ednr : vert2edge[v])
|
||||
{
|
||||
@ -595,27 +588,42 @@ namespace netgen
|
||||
LoopOverEdges (*mesh, *this, v,
|
||||
[&](INDEX_2 edge, int elnr, int loc_edge, int element_dim)
|
||||
{
|
||||
size_t pos;
|
||||
if (v2eht.PositionCreate(edge[1], pos))
|
||||
{
|
||||
vertex2.Append (edge[1]);
|
||||
v2eht.SetData (pos, 33);
|
||||
}
|
||||
/*
|
||||
if (!v2eht.Used(edge.I2()))
|
||||
{
|
||||
vertex2.Append (edge.I2());
|
||||
v2eht.Set (edge.I2(), 33);
|
||||
}
|
||||
*/
|
||||
});
|
||||
|
||||
QuickSort (vertex2);
|
||||
|
||||
/*
|
||||
for (int j = 0; j < vertex2.Size(); j++)
|
||||
{
|
||||
v2eht.Set (vertex2[j], ned);
|
||||
// edge2vert[ned] = INDEX_2 (v, vertex2[j]);
|
||||
edge2vert[ned] = { v, vertex2[j] };
|
||||
ned++;
|
||||
}
|
||||
*/
|
||||
for (auto v2 : vertex2)
|
||||
{
|
||||
v2eht.Set (v2, ned);
|
||||
edge2vert[ned] = { v, v2 };
|
||||
ned++;
|
||||
}
|
||||
|
||||
LoopOverEdges (*mesh, *this, v,
|
||||
[&](INDEX_2 edge, int elnr, int loc_edge, int element_dim)
|
||||
{
|
||||
int edgenum = v2eht.Get(edge.I2());
|
||||
int edgenum = v2eht.Get(edge[1]);
|
||||
switch (element_dim)
|
||||
{
|
||||
case 3:
|
||||
|
Loading…
Reference in New Issue
Block a user