mirror of
https://gitlab.com/scemama/eplf
synced 2025-01-08 20:33:28 +01:00
EPLF MC OK
This commit is contained in:
parent
0d69dec304
commit
01ef6620cd
@ -105,10 +105,10 @@ END_PROVIDER
|
|||||||
exc = det_exc(k,l,3)
|
exc = det_exc(k,l,3)
|
||||||
|
|
||||||
if ( exc < 0 ) then
|
if ( exc < 0 ) then
|
||||||
phase = -0.5d0
|
phase = -1.0d0
|
||||||
exc = -exc
|
exc = -exc
|
||||||
else
|
else
|
||||||
phase = 0.5d0
|
phase = 1.0d0
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if ( exc == 0 ) then
|
if ( exc == 0 ) then
|
||||||
|
@ -114,24 +114,59 @@ BEGIN_PROVIDER [ real, grid_$X, (grid_x_num,grid_y_num,grid_z_num) ]
|
|||||||
enddo
|
enddo
|
||||||
|
|
||||||
IRP_IF MPI
|
IRP_IF MPI
|
||||||
|
! integer :: dim, ierr
|
||||||
|
! do iz=1,grid_z_num
|
||||||
|
! real :: buffer(grid_x_num*grid_y_num+1)
|
||||||
|
! icount = 0
|
||||||
|
! do iy=1,grid_y_num
|
||||||
|
! do ix=1,grid_x_num
|
||||||
|
! buffer(icount+ix) = grid_$X(ix,iy,iz)
|
||||||
|
! enddo
|
||||||
|
! icount = icount + grid_x_num
|
||||||
|
! enddo
|
||||||
|
! dim = grid_x_num * grid_y_num
|
||||||
|
! call MPI_REDUCE(buffer,grid_$X(1,1,iz),dim,mpi_real, &
|
||||||
|
! mpi_sum,0,MPI_COMM_WORLD,ierr)
|
||||||
|
! if (ierr /= MPI_SUCCESS) then
|
||||||
|
! call abrt(irp_here,'Unable to fetch buffer')
|
||||||
|
! endif
|
||||||
|
! call barrier
|
||||||
|
! enddo
|
||||||
|
|
||||||
|
! integer :: dim, ierr
|
||||||
|
! real :: buffer(grid_x_num*grid_y_num*grid_z_num)
|
||||||
|
! icount = 0
|
||||||
|
! do iz=1,grid_z_num
|
||||||
|
! do iy=1,grid_y_num
|
||||||
|
! do ix=1,grid_x_num
|
||||||
|
! buffer(icount+ix) = grid_$X(ix,iy,iz)
|
||||||
|
! enddo
|
||||||
|
! icount = icount + grid_x_num
|
||||||
|
! enddo
|
||||||
|
! enddo
|
||||||
|
! dim = grid_x_num * grid_y_num * grid_y_num
|
||||||
|
! call MPI_REDUCE(buffer,grid_$X,dim,mpi_real, &
|
||||||
|
! mpi_sum,0,MPI_COMM_WORLD,ierr)
|
||||||
|
! if (ierr /= MPI_SUCCESS) then
|
||||||
|
! call abrt(irp_here,'Unable to fetch buffer')
|
||||||
|
! endif
|
||||||
|
|
||||||
integer :: dim, ierr
|
integer :: dim, ierr
|
||||||
|
dim = grid_x_num
|
||||||
do iz=1,grid_z_num
|
do iz=1,grid_z_num
|
||||||
real :: buffer(grid_x_num*grid_y_num+1)
|
real :: buffer(grid_x_num)
|
||||||
icount = 0
|
|
||||||
do iy=1,grid_y_num
|
do iy=1,grid_y_num
|
||||||
do ix=1,grid_x_num
|
do ix=1,grid_x_num
|
||||||
buffer(icount+ix) = grid_$X(ix,iy,iz)
|
buffer(ix) = grid_$X(ix,iy,iz)
|
||||||
enddo
|
enddo
|
||||||
icount = icount + grid_x_num
|
call MPI_REDUCE(buffer,grid_$X(1,iy,iz),dim,mpi_real, &
|
||||||
enddo
|
|
||||||
dim = grid_x_num * grid_y_num
|
|
||||||
call MPI_REDUCE(buffer,grid_$X(1,1,iz),dim,mpi_real, &
|
|
||||||
mpi_sum,0,MPI_COMM_WORLD,ierr)
|
mpi_sum,0,MPI_COMM_WORLD,ierr)
|
||||||
if (ierr /= MPI_SUCCESS) then
|
if (ierr /= MPI_SUCCESS) then
|
||||||
call abrt(irp_here,'Unable to fetch buffer')
|
call abrt(irp_here,'Unable to fetch buffer')
|
||||||
endif
|
endif
|
||||||
call barrier
|
call barrier
|
||||||
enddo
|
enddo
|
||||||
|
enddo
|
||||||
IRP_ENDIF
|
IRP_ENDIF
|
||||||
|
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
Loading…
Reference in New Issue
Block a user