Copy neighbour lists only when reneighbouring happens, added measurements + logbook update
This commit is contained in:
		| @@ -179,8 +179,10 @@ double computeForce( | |||||||
|  |  | ||||||
|     checkCUDAError( "c_atom.x memcpy", cudaMemcpy(c_atom.x, atom->x, sizeof(MD_FLOAT) * atom->Nmax * 3, cudaMemcpyHostToDevice) ); |     checkCUDAError( "c_atom.x memcpy", cudaMemcpy(c_atom.x, atom->x, sizeof(MD_FLOAT) * atom->Nmax * 3, cudaMemcpyHostToDevice) ); | ||||||
|  |  | ||||||
|  |     if(reneighbourHappenend) { | ||||||
|         checkCUDAError( "c_neigh_numneigh memcpy", cudaMemcpy(c_neigh_numneigh, neighbor->numneigh, sizeof(int) * Nlocal, cudaMemcpyHostToDevice) ); |         checkCUDAError( "c_neigh_numneigh memcpy", cudaMemcpy(c_neigh_numneigh, neighbor->numneigh, sizeof(int) * Nlocal, cudaMemcpyHostToDevice) ); | ||||||
|         checkCUDAError( "c_neighs memcpy", cudaMemcpy(c_neighs, neighbor->neighbors, sizeof(int) * Nlocal * neighbor->maxneighs, cudaMemcpyHostToDevice) ); |         checkCUDAError( "c_neighs memcpy", cudaMemcpy(c_neighs, neighbor->neighbors, sizeof(int) * Nlocal * neighbor->maxneighs, cudaMemcpyHostToDevice) ); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     const int num_threads_per_block = num_threads; // this should be multiple of 32 as operations are performed at the level of warps |     const int num_threads_per_block = num_threads; // this should be multiple of 32 as operations are performed at the level of warps | ||||||
|     const int num_blocks = ceil((float)Nlocal / (float)num_threads_per_block); |     const int num_blocks = ceil((float)Nlocal / (float)num_threads_per_block); | ||||||
|   | |||||||
| @@ -279,7 +279,6 @@ int main(int argc, char** argv) | |||||||
|         initialIntegrate(¶m, &atom); |         initialIntegrate(¶m, &atom); | ||||||
|  |  | ||||||
|         const bool doReneighbour = (n + 1) % param.every == 0; |         const bool doReneighbour = (n + 1) % param.every == 0; | ||||||
|         const bool doesReneighbourNextRound = (n + 2) % param.every == 0; |  | ||||||
|  |  | ||||||
|         if(doReneighbour) { |         if(doReneighbour) { | ||||||
|             timer[NEIGH] += reneighbour(¶m, &atom, &neighbor); |             timer[NEIGH] += reneighbour(¶m, &atom, &neighbor); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user