Skip to content

Commit

Permalink
parallel hessian based cov.
Browse files Browse the repository at this point in the history
  • Loading branch information
michel2323 committed Mar 30, 2018
1 parent 975c86d commit cc2a0c6
Show file tree
Hide file tree
Showing 3 changed files with 63 additions and 3 deletions.
9 changes: 6 additions & 3 deletions include/ad.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -832,23 +832,25 @@ void propagateAD(pVector<double>& m0, pMatrix<double>& cv0, System& sys,
drivers.integrate(m0);

if (degree > 1) {
for (size_t p = 0; p < dim; ++p) {
for (size_t p = start; p < end; ++p) {
// for (size_t p = 0; p < dim; ++p) {
for (size_t i = 0; i < dim; ++i) {
for (size_t j = 0; j < dim; ++j) {
m0[p] += (1.0/2.0)*H[p][i][j]*cv0[i][j];
}
}
}
}
paduprop_gather(m0);

if(paduprop_getrank() == 0) {
std::cout << "Propagating covariance" << std::endl;
}

// Propagate covariance

for (size_t pn = 0; pn < dim; ++pn) {
for (size_t pm = 0; pm < dim; ++pm) {
for (size_t pm = start; pm < end; ++pm) {
for (size_t pn = 0; pn < dim; ++pn) {
for (size_t i = 0; i < dim; ++i) {
for (size_t j = 0; j < dim; ++j) {
cv_temp[pn][pm] += 0.5*((J[pn][j]*J[pm][i] +
Expand All @@ -857,6 +859,7 @@ void propagateAD(pVector<double>& m0, pMatrix<double>& cv0, System& sys,
}
}
}
paduprop_gather(cv_temp);

if (degree > 2) {
if(paduprop_getrank() == 0) {
Expand Down
3 changes: 3 additions & 0 deletions include/parallel.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@ size_t paduprop_getend(size_t dim);
int paduprop_getrank();
int paduprop_getcommsize();
int paduprop_sum(pMatrix<double>&);
int paduprop_sum(pVector<double> &vec);
int paduprop_gather(pTensor3<double> &ten);
int paduprop_gather(pMatrix<double> &mat);
int paduprop_gather(pVector<double> &vec);

#endif // ADUPROP_PARALLEL_HPP_
54 changes: 54 additions & 0 deletions src/parallel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,12 @@ int paduprop_sum(pMatrix<double> &mat) {
return MPI_Allreduce(MPI_IN_PLACE, ptr, size, MPI_DOUBLE, MPI_SUM, MPI_COMM_WORLD);
}

int paduprop_sum(pVector<double> &vec) {
size_t size = vec.dim();
double *ptr = vec.get_datap();
return MPI_Allreduce(MPI_IN_PLACE, ptr, size, MPI_DOUBLE, MPI_SUM, MPI_COMM_WORLD);
}

int paduprop_gather(pTensor3<double> &ten) {
size_t dim = ten.get_d1();
size_t start = paduprop_getstart(dim);
Expand All @@ -110,3 +116,51 @@ int paduprop_gather(pTensor3<double> &ten) {
delete [] sendbuf;
return ierr;
}

int paduprop_gather(pMatrix<double> &mat) {
size_t dim = mat.nrows();
size_t start = paduprop_getstart(dim);
size_t end = paduprop_getend(dim);
size_t size = (end-start)*dim;
double *sendbuf = new double[size];
for(size_t i = 0; i < size; ++i) sendbuf[i] = *(&mat[0][start] + i);
int *recvcounts = new int[paduprop_getcommsize()];
int *displs = new int[paduprop_getcommsize()];
int count = 0;
for(int i = 0; i < paduprop_getcommsize(); ++i) {
displs[i] = count;
recvcounts[i] = (paduprop_getend(dim,i) - paduprop_getstart(dim,i))*dim;
count += recvcounts[i];
}
int ierr = MPI_Allgatherv(sendbuf, size, MPI_DOUBLE,
&mat[0][0], recvcounts, displs, MPI_DOUBLE,
MPI_COMM_WORLD);
delete [] recvcounts;
delete [] displs;
delete [] sendbuf;
return ierr;
}

int paduprop_gather(pVector<double> &vec) {
size_t dim = vec.dim();
size_t start = paduprop_getstart(dim);
size_t end = paduprop_getend(dim);
size_t size = end-start;
double *sendbuf = new double[size];
for(size_t i = 0; i < size; ++i) sendbuf[i] = vec[start+i];
int *recvcounts = new int[paduprop_getcommsize()];
int *displs = new int[paduprop_getcommsize()];
int count = 0;
for(int i = 0; i < paduprop_getcommsize(); ++i) {
displs[i] = count;
recvcounts[i] = (paduprop_getend(dim,i) - paduprop_getstart(dim,i));
count += recvcounts[i];
}
int ierr = MPI_Allgatherv(sendbuf, size, MPI_DOUBLE,
&vec[0], recvcounts, displs, MPI_DOUBLE,
MPI_COMM_WORLD);
delete [] recvcounts;
delete [] displs;
delete [] sendbuf;
return ierr;
}

0 comments on commit cc2a0c6

Please sign in to comment.