mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-10-24 17:54:47 +01:00 
			
		
		
		
	Dirichlet improved
This commit is contained in:
		| @@ -131,7 +131,6 @@ class CartesianStencilAccelerator { | |||||||
|   int           _checkerboard; |   int           _checkerboard; | ||||||
|   int           _npoints; // Move to template param? |   int           _npoints; // Move to template param? | ||||||
|   int           _osites; |   int           _osites; | ||||||
|   int           _dirichlet; |  | ||||||
|   StencilVector _directions; |   StencilVector _directions; | ||||||
|   StencilVector _distances; |   StencilVector _distances; | ||||||
|   StencilVector _comms_send; |   StencilVector _comms_send; | ||||||
| @@ -650,16 +649,14 @@ public: | |||||||
|   /// Introduce a block structure and switch off comms on boundaries |   /// Introduce a block structure and switch off comms on boundaries | ||||||
|   void DirichletBlock(const Coordinate &dirichlet_block) |   void DirichletBlock(const Coordinate &dirichlet_block) | ||||||
|   { |   { | ||||||
|     this->_dirichlet = 1; |  | ||||||
|     for(int ii=0;ii<this->_npoints;ii++){ |     for(int ii=0;ii<this->_npoints;ii++){ | ||||||
|       int dimension    = this->_directions[ii]; |       int dimension    = this->_directions[ii]; | ||||||
|       int displacement = this->_distances[ii]; |       int displacement = this->_distances[ii]; | ||||||
|       int shift = displacement; |  | ||||||
|       int gd = _grid->_gdimensions[dimension]; |       int gd = _grid->_gdimensions[dimension]; | ||||||
|       int fd = _grid->_fdimensions[dimension]; |       int fd = _grid->_fdimensions[dimension]; | ||||||
|       int pd = _grid->_processors [dimension]; |       int pd = _grid->_processors [dimension]; | ||||||
|       int ld = gd/pd; |  | ||||||
|       int pc = _grid->_processor_coor[dimension]; |       int pc = _grid->_processor_coor[dimension]; | ||||||
|  |       int ld = fd/pd; | ||||||
|       /////////////////////////////////////////// |       /////////////////////////////////////////// | ||||||
|       // Figure out dirichlet send and receive |       // Figure out dirichlet send and receive | ||||||
|       // on this leg of stencil. |       // on this leg of stencil. | ||||||
| @@ -668,7 +665,7 @@ public: | |||||||
|       int block = dirichlet_block[dimension]; |       int block = dirichlet_block[dimension]; | ||||||
|       this->_comms_send[ii] = comm_dim; |       this->_comms_send[ii] = comm_dim; | ||||||
|       this->_comms_recv[ii] = comm_dim; |       this->_comms_recv[ii] = comm_dim; | ||||||
|       if ( block ) { |       if ( block && comm_dim ) { | ||||||
| 	assert(abs(displacement) < ld ); | 	assert(abs(displacement) < ld ); | ||||||
|        |        | ||||||
| 	if( displacement > 0 ) { | 	if( displacement > 0 ) { | ||||||
| @@ -677,16 +674,16 @@ public: | |||||||
| 	  // |    |    | | 	  // |    |    | | ||||||
| 	  //           noR | 	  //           noR | ||||||
| 	  // noS | 	  // noS | ||||||
| 	  if ( (ld*(pc+1) ) % block == 0 ) this->_comms_recv[ii] = 0; | 	  if ( ( (ld*(pc+1) ) % block ) == 0 ) this->_comms_recv[ii] = 0; | ||||||
| 	  if ( ( ld*pc ) % block == 0    ) this->_comms_send[ii] = 0; | 	  if ( ( (ld*pc     ) % block ) == 0 ) this->_comms_send[ii] = 0; | ||||||
| 	} else { | 	} else { | ||||||
| 	  // High side, low side | 	  // High side, low side | ||||||
| 	  // | <--B--->| | 	  // | <--B--->| | ||||||
| 	  // |    |    | | 	  // |    |    | | ||||||
| 	  //           noS | 	  //           noS | ||||||
| 	  // noR | 	  // noR | ||||||
| 	  if ( (ld*(pc+1) ) % block == 0 ) this->_comms_send[ii] = 0; | 	  if ( ( (ld*(pc+1) ) % block ) == 0 ) this->_comms_send[ii] = 0; | ||||||
| 	  if ( ( ld*pc ) % block    == 0 ) this->_comms_recv[ii] = 0; | 	  if ( ( (ld*pc     ) % block ) == 0 ) this->_comms_recv[ii] = 0; | ||||||
| 	} | 	} | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| @@ -698,7 +695,6 @@ public: | |||||||
| 		   const std::vector<int> &distances, | 		   const std::vector<int> &distances, | ||||||
| 		   Parameters p) | 		   Parameters p) | ||||||
|   { |   { | ||||||
|     this->_dirichlet = 0; |  | ||||||
|     face_table_computed=0; |     face_table_computed=0; | ||||||
|     _grid    = grid; |     _grid    = grid; | ||||||
|     this->parameters=p; |     this->parameters=p; | ||||||
| @@ -715,6 +711,8 @@ public: | |||||||
|     this->_comms_recv.resize(npoints);  |     this->_comms_recv.resize(npoints);  | ||||||
|     this->same_node.resize(npoints); |     this->same_node.resize(npoints); | ||||||
|  |  | ||||||
|  |     if ( p.dirichlet.size() ) DirichletBlock(p.dirichlet); // comms send/recv set up | ||||||
|  |  | ||||||
|     _unified_buffer_size=0; |     _unified_buffer_size=0; | ||||||
|     surface_list.resize(0); |     surface_list.resize(0); | ||||||
|  |  | ||||||
| @@ -1106,6 +1104,7 @@ public: | |||||||
| 	  Gather_plane_simple_table(face_table[face_idx],rhs,send_buf,compress,u_comm_offset,so); | 	  Gather_plane_simple_table(face_table[face_idx],rhs,send_buf,compress,u_comm_offset,so); | ||||||
| 	face_idx++; | 	face_idx++; | ||||||
|  |  | ||||||
|  |  | ||||||
| 	int duplicate = CheckForDuplicate(dimension,sx,comm_proc,(void *)&recv_buf[u_comm_offset],0,bytes,cbmask); | 	int duplicate = CheckForDuplicate(dimension,sx,comm_proc,(void *)&recv_buf[u_comm_offset],0,bytes,cbmask); | ||||||
| 	if ( (!duplicate) ) { // Force comms for now | 	if ( (!duplicate) ) { // Force comms for now | ||||||
|  |  | ||||||
| @@ -1206,7 +1205,7 @@ public: | |||||||
| 				  face_table[face_idx].size()*sizeof(face_table_host[0])); | 				  face_table[face_idx].size()*sizeof(face_table_host[0])); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	//	if ( comms_send ) | 	if ( comms_send ) | ||||||
| 	  Gather_plane_exchange_table(face_table[face_idx],rhs,spointers,dimension,sx,cbmask,compress,permute_type); | 	  Gather_plane_exchange_table(face_table[face_idx],rhs,spointers,dimension,sx,cbmask,compress,permute_type); | ||||||
| 	face_idx++; | 	face_idx++; | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user