mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 14:10:34 +05:00
global enumeration of points for pickling (as an option)
This commit is contained in:
parent
5e09626466
commit
2c6e0e2bec
@ -1289,13 +1289,107 @@ namespace netgen
|
|||||||
if (comm.Rank() == 0)
|
if (comm.Rank() == 0)
|
||||||
archive & dimension;
|
archive & dimension;
|
||||||
|
|
||||||
// merge points
|
auto rank = comm.Rank();
|
||||||
|
|
||||||
auto & partop = GetParallelTopology();
|
auto & partop = GetParallelTopology();
|
||||||
|
|
||||||
|
// global enumration of points:
|
||||||
|
// not used now, but will be needed for refined meshes
|
||||||
|
// GridFunciton pickling is not compatible, now
|
||||||
|
// should go to paralleltopology
|
||||||
|
|
||||||
|
Array<PointIndex, PointIndex> global_pnums(points.Size());
|
||||||
|
global_pnums = -1;
|
||||||
|
int num_master_points = 0;
|
||||||
|
for (PointIndex pi : Range(points))
|
||||||
|
{
|
||||||
|
auto distprocs = partop.GetDistantPNums(pi-PointIndex::BASE);
|
||||||
|
// check sorted:
|
||||||
|
for (int j = 0; j+1 < distprocs.Size(); j++)
|
||||||
|
if (distprocs[j+1] < distprocs[j]) cout << "wrong sort" << endl;
|
||||||
|
if (distprocs.Size() == 0 || distprocs[0] > comm.Rank())
|
||||||
|
global_pnums[pi] = PointIndex::BASE+num_master_points++;
|
||||||
|
}
|
||||||
|
Array<int> first_master_point(comm.Size());
|
||||||
|
GetCommunicator().AllGather (num_master_points, first_master_point);
|
||||||
|
|
||||||
|
size_t num_glob_points = 0;
|
||||||
|
for (int i = 0; i < comm.Size(); i++)
|
||||||
|
{
|
||||||
|
int cur = first_master_point[i];
|
||||||
|
first_master_point[i] = num_glob_points;
|
||||||
|
num_glob_points += cur;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (PointIndex pi : Range(points))
|
||||||
|
if (global_pnums[pi] != -1)
|
||||||
|
global_pnums[pi] += first_master_point[comm.Rank()];
|
||||||
|
|
||||||
|
// ScatterDofData (global_nums);
|
||||||
|
|
||||||
|
Array<int> nsend(comm.Size()), nrecv(comm.Size());
|
||||||
|
nsend = 0;
|
||||||
|
nrecv = 0;
|
||||||
|
|
||||||
|
/** Count send/recv size **/
|
||||||
|
for (PointIndex pi : Range(points))
|
||||||
|
{
|
||||||
|
auto dps = partop.GetDistantPNums(pi-PointIndex::BASE);
|
||||||
|
if (!dps.Size()) continue;
|
||||||
|
if (rank < dps[0])
|
||||||
|
for(auto p:dps)
|
||||||
|
nsend[p]++;
|
||||||
|
else
|
||||||
|
nrecv[dps[0]]++;
|
||||||
|
}
|
||||||
|
|
||||||
|
Table<PointIndex> send_data(nsend);
|
||||||
|
Table<PointIndex> recv_data(nrecv);
|
||||||
|
|
||||||
|
/** Fill send_data **/
|
||||||
|
nsend = 0;
|
||||||
|
for (PointIndex pi : Range(points))
|
||||||
|
{
|
||||||
|
auto dps = partop.GetDistantPNums(pi-PointIndex::BASE);
|
||||||
|
if (dps.Size() && rank < dps[0])
|
||||||
|
for(auto p : dps)
|
||||||
|
send_data[p][nsend[p]++] = global_pnums[pi];
|
||||||
|
}
|
||||||
|
|
||||||
|
Array<MPI_Request> requests;
|
||||||
|
for (int i = 0; i < comm.Size(); i++)
|
||||||
|
{
|
||||||
|
if (nsend[i])
|
||||||
|
requests.Append (comm.ISend (send_data[i], i, 200));
|
||||||
|
if (nrecv[i])
|
||||||
|
requests.Append (comm.IRecv (recv_data[i], i, 200));
|
||||||
|
}
|
||||||
|
|
||||||
|
MyMPI_WaitAll (requests);
|
||||||
|
|
||||||
|
Array<int> cnt(comm.Size());
|
||||||
|
cnt = 0;
|
||||||
|
|
||||||
|
for (PointIndex pi : Range(points))
|
||||||
|
{
|
||||||
|
auto distprocs = partop.GetDistantPNums(pi-PointIndex::BASE);
|
||||||
|
if (distprocs.Size() > 0 && distprocs[0] < comm.Rank())
|
||||||
|
{
|
||||||
|
int master = comm.Size();
|
||||||
|
for (int j = 0; j < distprocs.Size(); j++)
|
||||||
|
master = min (master, distprocs[j]);
|
||||||
|
global_pnums[pi] = recv_data[master][cnt[master]++];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// merge points
|
||||||
Array<int, PointIndex> globnum(points.Size());
|
Array<int, PointIndex> globnum(points.Size());
|
||||||
int maxglob = 0;
|
int maxglob = 0;
|
||||||
for (auto pi : Range(points))
|
for (auto pi : Range(points))
|
||||||
{
|
{
|
||||||
globnum[pi] = partop.GetGlobalPNum(pi);
|
globnum[pi] = partop.GetGlobalPNum(pi);
|
||||||
|
// globnum[pi] = global_pnums[pi];
|
||||||
maxglob = max(globnum[pi], maxglob);
|
maxglob = max(globnum[pi], maxglob);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -177,6 +177,7 @@ namespace netgen
|
|||||||
PointIndex operator-- (int) { PointIndex hi(*this); i--; return hi; }
|
PointIndex operator-- (int) { PointIndex hi(*this); i--; return hi; }
|
||||||
PointIndex & operator++ () { i++; return *this; }
|
PointIndex & operator++ () { i++; return *this; }
|
||||||
PointIndex operator-- () { i--; return *this; }
|
PointIndex operator-- () { i--; return *this; }
|
||||||
|
PointIndex operator+= (int add) { i += add; return *this; }
|
||||||
void Invalidate() { i = PointIndex::BASE-1; }
|
void Invalidate() { i = PointIndex::BASE-1; }
|
||||||
bool IsValid() const { return i != PointIndex::BASE-1; }
|
bool IsValid() const { return i != PointIndex::BASE-1; }
|
||||||
#ifdef BASE0
|
#ifdef BASE0
|
||||||
|
Loading…
Reference in New Issue
Block a user