Skip to content

Commit

Permalink
Sample mesh manager bug fix (#258)
Browse files Browse the repository at this point in the history
* Bug fix.

* Cleaning up a few things.
  • Loading branch information
dylan-copeland authored Jan 3, 2024
1 parent 27234b3 commit 55a46a6
Show file tree
Hide file tree
Showing 6 changed files with 34 additions and 35 deletions.
1 change: 0 additions & 1 deletion examples/prom/dg_advection_global_rom.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -704,7 +704,6 @@ int main(int argc, char *argv[])
if (merge)
{
mergeTimer.Start();
std::unique_ptr<CAROM::BasisGenerator> basis_generator;
options = new CAROM::Options(U->Size(), max_num_snapshots, 1, update_right_SV);
generator = new CAROM::BasisGenerator(*options, isIncremental, basisName);
for (int paramID=0; paramID<nsets; ++paramID)
Expand Down
1 change: 0 additions & 1 deletion examples/prom/linear_elasticity_global_rom.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -244,7 +244,6 @@ int main(int argc, char* argv[])
if (merge)
{
mergeTimer.Start();
std::unique_ptr<CAROM::BasisGenerator> basis_generator;
options = new CAROM::Options(fespace->GetTrueVSize(), max_num_snapshots, 1,
update_right_SV);
generator = new CAROM::BasisGenerator(*options, isIncremental, basisName);
Expand Down
1 change: 0 additions & 1 deletion examples/prom/maxwell_global_rom.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -238,7 +238,6 @@ int main(int argc, char *argv[])
if (merge)
{
mergeTimer.Start();
std::unique_ptr<CAROM::BasisGenerator> basis_generator;
options = new CAROM::Options(fespace->GetTrueVSize(), max_num_snapshots, 1,
update_right_SV);
generator = new CAROM::BasisGenerator(*options, isIncremental, basisName);
Expand Down
1 change: 0 additions & 1 deletion examples/prom/poisson_global_rom.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -247,7 +247,6 @@ int main(int argc, char *argv[])
if (merge)
{
mergeTimer.Start();
std::unique_ptr<CAROM::BasisGenerator> basis_generator;
options = new CAROM::Options(fespace.GetTrueVSize(), max_num_snapshots, 1,
update_right_SV);
generator = new CAROM::BasisGenerator(*options, isIncremental, basisName);
Expand Down
1 change: 0 additions & 1 deletion examples/prom/poisson_local_rom_greedy.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -617,7 +617,6 @@ int main(int argc, char *argv[])
if (calc_rel_error || (offline && basisIdentifiers.size() == 1))
{
mergeTimer.Start();
std::unique_ptr<CAROM::BasisGenerator> basis_generator;
options = new CAROM::Options(fespace.GetTrueVSize(), max_num_snapshots, 1,
update_right_SV);
generator = new CAROM::BasisGenerator(*options, isIncremental, loadBasisName);
Expand Down
64 changes: 34 additions & 30 deletions lib/mfem/SampleMesh.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@ void FindStencilElements(const vector<int>& sample_dofs_gid,
for (int i = 0; i < dofs.Size(); i++)
{
const int dof_i = dofs[i] >= 0 ? dofs[i] : -1 - dofs[i];
//int ltdof = fespace.GetLocalTDofNumber(dof_i);
int global_dof = fespace.GetGlobalTDofNumber(dof_i);
if (global_dof == *it)
{
Expand Down Expand Up @@ -115,7 +114,6 @@ void GetLocalSampleMeshElements(ParMesh& pmesh, ParFiniteElementSpace& fespace,

// Construct the map of local true dofs to global true dofs.
map<int, int> ltdof2gtdof;
//const int ndofs = fespace.GetNDofs();
const int ndofs = fespace.GetVSize();
for (int i = 0; i < fespace.GetVSize(); ++i) {
int ltdof = fespace.GetLocalTDofNumber(i);
Expand Down Expand Up @@ -390,8 +388,8 @@ void BuildSampleMesh(ParMesh& pmesh, vector<ParFiniteElementSpace*> & fespace,
int numElVert = elVert.Size(); // number of vertices per element
MFEM_VERIFY(numElVert > 0, "");

vector<int> my_element_vgid(
numElVert*local_num_elems); // vertex global indices, for each element
// vertex global indices, for each element
vector<int> my_element_vgid(numElVert*local_num_elems);
vector<double> my_element_coords(d*numElVert*local_num_elems);

for (set<int>::iterator it = elems.begin(); it != elems.end(); ++it) {
Expand All @@ -411,7 +409,7 @@ void BuildSampleMesh(ParMesh& pmesh, vector<ParFiniteElementSpace*> & fespace,
Array<int> dofs;
H1DummySpace.GetElementDofs(elId, dofs);
MFEM_VERIFY(numElVert == dofs.Size(),
""); // Assuming a bijection between vertices and H1 dummy space DOF's.
"Assuming a bijection between vertices and H1 dummy space DOF's");

for (int i = 0; i < numElVert; ++i) {
my_element_vgid[conn_idx++] = H1DummySpace.GetGlobalTDofNumber(dofs[i]);
Expand Down Expand Up @@ -464,10 +462,10 @@ void BuildSampleMesh(ParMesh& pmesh, vector<ParFiniteElementSpace*> & fespace,
delete [] cts;
delete [] offsets;

// element_vgid holds vertices as global ids. Vertices may be shared
// element_vgid holds vertices as global ids. Vertices may be shared
// between elements so we don't know the number of unique vertices in the
// sample mesh. Find all the unique vertices and construct the map of
// global dof ids to local dof ids (vertices). Keep track of the number of
// sample mesh. Find all the unique vertices and construct the map of
// global dof ids to local dof ids (vertices). Keep track of the number of
// unique vertices.
set<int> unique_gdofs;
map<int, int> unique_gdofs_first_appearance;
Expand Down Expand Up @@ -534,8 +532,12 @@ void BuildSampleMesh(ParMesh& pmesh, vector<ParFiniteElementSpace*> & fespace,
}

void GetLocalDofsToLocalElementMap(ParFiniteElementSpace& fespace,
const vector<int>& dofs, const vector<int>& localNumDofs, const set<int>& elems,
vector<int>& dofToElem, vector<int>& dofToElemDof, const bool useTDof)
const vector<int>& dofs,
const vector<int>& localNumDofs,
const set<int>& elems,
vector<int>& dofToElem,
vector<int>& dofToElemDof,
const bool useTDof)
{
int myid;
MPI_Comm_rank(MPI_COMM_WORLD, &myid);
Expand Down Expand Up @@ -568,8 +570,9 @@ void GetLocalDofsToLocalElementMap(ParFiniteElementSpace& fespace,
if (ltdof == dofs[myoffset + i]) // dofs contains true DOF's.
#endif
{
dofToElem[i] =
elId; // Possibly overwrite another element index, which is fine since we just want any element index.
// Possibly overwrite another element index, which is fine
// since we just want any element index.
dofToElem[i] = elId;
dofToElemDof[i] = j;
}
}
Expand Down Expand Up @@ -622,8 +625,8 @@ void Set_s2sp(const int myid, const int num_procs, vector<int> const& spNtrue,
// Gather all the sample DOF to element and element DOF indices.
vector<int> mySampleToElement(2*local_num_sample_dofs[myid]);

mySampleToElement.assign(mySampleToElement.size(),
-1); // Initialize with invalid values, to verify later that everything was set.
// Initialize with invalid values, to verify later that everything was set.
mySampleToElement.assign(mySampleToElement.size(), -1);

for (int s=0; s<nspaces; ++s) // Loop over subspaces
{
Expand Down Expand Up @@ -673,9 +676,8 @@ void Set_s2sp(const int myid, const int num_procs, vector<int> const& spNtrue,
spaceOS[i] = spaceOS[i-1] + spfespace[i-1]->GetVSize();

s2sp.resize(global_num_sample_dofs);

s2sp.assign(s2sp.size(),
-1); // Initialize with invalid values, to verify later that everything was set.
// Initialize with invalid values, to verify later that everything was set.
s2sp.assign(s2sp.size(), -1);

for (int s=0; s<nspaces; ++s)
os[s] = 0;
Expand Down Expand Up @@ -852,8 +854,6 @@ void Finish_s2sp_augmented(const int rank, const int nprocs,
MFEM_VERIFY(it->second == sp, "");
}
}

//gid[(2*i) + 1] = s2sp[dofs_sub_to_sdofs[s][os + i]];
}
}

Expand All @@ -863,7 +863,6 @@ void Finish_s2sp_augmented(const int rank, const int nprocs,
for (int i=0; i<local_num_dofs_sub[s][p]; ++i)
{
const int g = allgid[offsets[p] + (2*i)];
//const int sp = allgid[offsets[p] + (2*i) + 1]; ?? //why isn't this used? because it already set gi2sp, which is now used.

map<int, int>::const_iterator it = gi2sp.find(g);
MFEM_VERIFY(it != gi2sp.end() && it->first == g, "");
Expand All @@ -883,11 +882,14 @@ void Finish_s2sp_augmented(const int rank, const int nprocs,
{
if (s2sp_[i] == -1)
s2sp_[i] = s2sp[i];

MFEM_VERIFY(s2sp_[i] >= 0 && s2sp_[i] == s2sp[i], "");
else
MFEM_VERIFY(s2sp_[i] == s2sp[i], "Consistency check");
}
}
}

for (int i=0; i<s2sp_.size(); ++i)
MFEM_VERIFY(s2sp_[i] >= 0 && s2sp_[i] == s2sp[i], "");
}
#endif

Expand Down Expand Up @@ -1162,7 +1164,8 @@ void SampleMeshManager::SetSampleMaps()
}
}

// For each variable v and each of the num_sample_dofs_per_proc[v][p] samples, set s2sp_var[v][] to be its index in sample_dofs
// For each variable v and each of the num_sample_dofs_per_proc[v][p]
// samples, set s2sp_var[v][] to be its index in sample_dofs.
s2sp_var.resize(nvar);
for (int v=0; v<nvar; ++v)
{
Expand All @@ -1179,7 +1182,8 @@ void SampleMeshManager::SetSampleMaps()
{
const int sample = sample_dofs_var[v][os + j];

// Note: this has quadratic complexity and could be improved with a std::map<int, int>, but it should not be a bottleneck.
// Note: this has quadratic complexity and could be improved
// with a std::map<int, int>, but it should not be a bottleneck.
int k = -1;
int cnt = 0;
for (set<int>::const_iterator it = sample_dofs_proc[space][p].begin();
Expand Down Expand Up @@ -1440,16 +1444,16 @@ void GatherDistributedMatrixRows_aux(const CAROM::Matrix& B, const int rdim,
if (allos0[i] <= all_sprows[sti] && all_sprows[sti] < allos1[i])
{
MFEM_VERIFY(0 <= st2sp[sti] - ossp && st2sp[sti] - ossp < Bsp.numRows(), "");
// Note that this may redundantly overwrite some rows corresponding to shared DOF's.
MPI_Recv(&Bsp(st2sp[sti] - ossp, 0), rdim, MPI_DOUBLE,
i, offsets[i]+j, MPI_COMM_WORLD,
&status); // Note that this may redundantly overwrite some rows corresponding to shared DOF's.
i, offsets[i]+j, MPI_COMM_WORLD, &status);
}
#else
if (allos0[i] <= all_sprows[Bsp_row] && all_sprows[Bsp_row] < allos1[i])
{
// Note that this may redundantly overwrite some rows corresponding to shared DOF's.
MPI_Recv(&Bsp(st2sp[Bsp_row], 0), rdim, MPI_DOUBLE,
i, offsets[i]+j, MPI_COMM_WORLD,
&status); // Note that this may redundantly overwrite some rows corresponding to shared DOF's.
i, offsets[i]+j, MPI_COMM_WORLD, &status);
}
#endif
++Bsp_row;
Expand Down Expand Up @@ -1623,8 +1627,8 @@ void SampleMeshManager::CreateSampleMesh()
MPI_INT, &all_sprows[0], &local_num_stencil_dofs[0],
offsets, MPI_INT, MPI_COMM_WORLD);

// Note that all_stencil_dofs may contain DOF's on different processes that are identical (shared DOF's), which is fine
// (see comments in Set_s2sp).
// Note that all_stencil_dofs may contain DOF's on different processes that
// are identical (shared DOF's), which is fine (see comments in Set_s2sp).

delete [] offsets;

Expand Down

0 comments on commit 55a46a6

Please sign in to comment.