mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-05 11:00:10 +01:00
MPI broadcast works
This commit is contained in:
parent
5469ba87ea
commit
e111130454
@ -6,7 +6,7 @@
|
|||||||
# --align=32 : Align all provided arrays on a 32-byte boundary
|
# --align=32 : Align all provided arrays on a 32-byte boundary
|
||||||
#
|
#
|
||||||
[COMMON]
|
[COMMON]
|
||||||
FC : mpif90
|
FC : mpiifort
|
||||||
LAPACK_LIB : -mkl=parallel
|
LAPACK_LIB : -mkl=parallel
|
||||||
IRPF90 : irpf90
|
IRPF90 : irpf90
|
||||||
IRPF90_FLAGS : --ninja --align=32 -DMPI
|
IRPF90_FLAGS : --ninja --align=32 -DMPI
|
||||||
@ -52,12 +52,11 @@ FCFLAGS : -xSSE4.2 -O2 -ip -ftz
|
|||||||
[DEBUG]
|
[DEBUG]
|
||||||
FC : -g -traceback
|
FC : -g -traceback
|
||||||
FCFLAGS : -xSSE2 -C -fpe0
|
FCFLAGS : -xSSE2 -C -fpe0
|
||||||
IRPF90_FLAGS : --openmp
|
|
||||||
|
|
||||||
# OpenMP flags
|
# OpenMP flags
|
||||||
#################
|
#################
|
||||||
#
|
#
|
||||||
[OPENMP]
|
[OPENMP]
|
||||||
FC : -openmp
|
FC : -qopenmp
|
||||||
IRPF90_FLAGS : --openmp
|
IRPF90_FLAGS : --openmp
|
||||||
|
|
||||||
|
3
configure
vendored
3
configure
vendored
@ -525,11 +525,12 @@ def create_ninja_and_rc(l_installed):
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
with open('/dev/null', 'w') as dnull:
|
with open('/dev/null', 'w') as dnull:
|
||||||
subprocess.check_call(" ".join(l), shell=True,stderr=dnull)
|
subprocess.check_call(" ".join(l), shell=True, stderr=dnull)
|
||||||
except:
|
except:
|
||||||
print "[ FAIL ]"
|
print "[ FAIL ]"
|
||||||
print "Check the validity of the config file provided ({0})".format(sys.argv[1])
|
print "Check the validity of the config file provided ({0})".format(sys.argv[1])
|
||||||
print "Exit..."
|
print "Exit..."
|
||||||
|
raise
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
|
@ -90,20 +90,19 @@ program fci_zmq
|
|||||||
call write_double(6,correlation_energy_ratio, 'Correlation ratio')
|
call write_double(6,correlation_energy_ratio, 'Correlation ratio')
|
||||||
print *, ''
|
print *, ''
|
||||||
|
|
||||||
print *, ''
|
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=============================''))'
|
||||||
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=========================''))'
|
|
||||||
write(*,fmt)
|
write(*,fmt)
|
||||||
write(fmt,*) '(12X,', N_states_p, '(6X,A5,1X,I6,8X))'
|
write(fmt,*) '(12X,', N_states_p, '(6X,A7,1X,I6,10X))'
|
||||||
write(*,fmt) ('State',k, k=1,N_states_p)
|
write(*,fmt) ('State',k, k=1,N_states_p)
|
||||||
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=========================''))'
|
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=============================''))'
|
||||||
write(*,fmt)
|
write(*,fmt)
|
||||||
write(fmt,*) '(A12,', N_states_p, '(1X,F12.8,13X))'
|
write(fmt,*) '(A12,', N_states_p, '(1X,F14.8,15X))'
|
||||||
write(*,fmt) '# E ', CI_energy(1:N_states_p)
|
write(*,fmt) '# E ', CI_energy(1:N_states_p)
|
||||||
if (N_states_p > 1) then
|
if (N_states_p > 1) then
|
||||||
write(*,fmt) '# Excit. (au)', CI_energy(1:N_states_p)-CI_energy(1)
|
write(*,fmt) '# Excit. (au)', CI_energy(1:N_states_p)-CI_energy(1)
|
||||||
write(*,fmt) '# Excit. (eV)', (CI_energy(1:N_states_p)-CI_energy(1))*27.211396641308d0
|
write(*,fmt) '# Excit. (eV)', (CI_energy(1:N_states_p)-CI_energy(1))*27.211396641308d0
|
||||||
endif
|
endif
|
||||||
write(fmt,*) '(A12,', 2*N_states_p, '(1X,F12.8))'
|
write(fmt,*) '(A12,', 2*N_states_p, '(1X,F14.8))'
|
||||||
write(*,fmt) '# PT2'//pt2_string, (pt2(k), error(k), k=1,N_states_p)
|
write(*,fmt) '# PT2'//pt2_string, (pt2(k), error(k), k=1,N_states_p)
|
||||||
write(*,'(A)') '#'
|
write(*,'(A)') '#'
|
||||||
write(*,fmt) '# E+PT2 ', (CI_energy(k)+pt2(k),error(k), k=1,N_states_p)
|
write(*,fmt) '# E+PT2 ', (CI_energy(k)+pt2(k),error(k), k=1,N_states_p)
|
||||||
@ -113,8 +112,6 @@ program fci_zmq
|
|||||||
write(*,fmt) '# Excit. (eV)', ( (CI_energy(k)+pt2(k)-CI_energy(1)-pt2(1))*27.211396641308d0, &
|
write(*,fmt) '# Excit. (eV)', ( (CI_energy(k)+pt2(k)-CI_energy(1)-pt2(1))*27.211396641308d0, &
|
||||||
dsqrt(error(k)*error(k)+error(1)*error(1))*27.211396641308d0, k=1,N_states_p)
|
dsqrt(error(k)*error(k)+error(1)*error(1))*27.211396641308d0, k=1,N_states_p)
|
||||||
endif
|
endif
|
||||||
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=========================''))'
|
|
||||||
write(*,fmt)
|
|
||||||
print *, ''
|
print *, ''
|
||||||
|
|
||||||
print *, 'N_det = ', N_det
|
print *, 'N_det = ', N_det
|
||||||
@ -207,19 +204,19 @@ program fci_zmq
|
|||||||
|
|
||||||
N_states_p = min(N_det,N_states)
|
N_states_p = min(N_det,N_states)
|
||||||
print *, ''
|
print *, ''
|
||||||
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=========================''))'
|
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=============================''))'
|
||||||
write(*,fmt)
|
write(*,fmt)
|
||||||
write(fmt,*) '(12X,', N_states_p, '(6X,A5,1X,I6,8X))'
|
write(fmt,*) '(12X,', N_states_p, '(6X,A7,1X,I6,10X))'
|
||||||
write(*,fmt) ('State',k, k=1,N_states_p)
|
write(*,fmt) ('State',k, k=1,N_states_p)
|
||||||
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=========================''))'
|
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=============================''))'
|
||||||
write(*,fmt)
|
write(*,fmt)
|
||||||
write(fmt,*) '(A12,', N_states_p, '(1X,F12.8,13X))'
|
write(fmt,*) '(A12,', N_states_p, '(1X,F14.8,15X))'
|
||||||
write(*,fmt) '# E ', CI_energy(1:N_states_p)
|
write(*,fmt) '# E ', CI_energy(1:N_states_p)
|
||||||
if (N_states_p > 1) then
|
if (N_states_p > 1) then
|
||||||
write(*,fmt) '# Excit. (au)', CI_energy(1:N_states_p)-CI_energy(1)
|
write(*,fmt) '# Excit. (au)', CI_energy(1:N_states_p)-CI_energy(1)
|
||||||
write(*,fmt) '# Excit. (eV)', (CI_energy(1:N_states_p)-CI_energy(1))*27.211396641308d0
|
write(*,fmt) '# Excit. (eV)', (CI_energy(1:N_states_p)-CI_energy(1))*27.211396641308d0
|
||||||
endif
|
endif
|
||||||
write(fmt,*) '(A12,', 2*N_states_p, '(1X,F12.8))'
|
write(fmt,*) '(A12,', 2*N_states_p, '(1X,F14.8))'
|
||||||
write(*,fmt) '# PT2'//pt2_string, (pt2(k), error(k), k=1,N_states_p)
|
write(*,fmt) '# PT2'//pt2_string, (pt2(k), error(k), k=1,N_states_p)
|
||||||
write(*,'(A)') '#'
|
write(*,'(A)') '#'
|
||||||
write(*,fmt) '# E+PT2 ', (CI_energy(k)+pt2(k),error(k), k=1,N_states_p)
|
write(*,fmt) '# E+PT2 ', (CI_energy(k)+pt2(k),error(k), k=1,N_states_p)
|
||||||
@ -229,7 +226,7 @@ program fci_zmq
|
|||||||
write(*,fmt) '# Excit. (eV)', ( (CI_energy(k)+pt2(k)-CI_energy(1)-pt2(1))*27.211396641308d0, &
|
write(*,fmt) '# Excit. (eV)', ( (CI_energy(k)+pt2(k)-CI_energy(1)-pt2(1))*27.211396641308d0, &
|
||||||
dsqrt(error(k)*error(k)+error(1)*error(1))*27.211396641308d0, k=1,N_states_p)
|
dsqrt(error(k)*error(k)+error(1)*error(1))*27.211396641308d0, k=1,N_states_p)
|
||||||
endif
|
endif
|
||||||
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=========================''))'
|
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=============================''))'
|
||||||
write(*,fmt)
|
write(*,fmt)
|
||||||
print *, ''
|
print *, ''
|
||||||
|
|
||||||
|
@ -13,6 +13,7 @@ program selection_slave
|
|||||||
end
|
end
|
||||||
|
|
||||||
subroutine provide_everything
|
subroutine provide_everything
|
||||||
|
PROVIDE mpi_master
|
||||||
PROVIDE H_apply_buffer_allocated mo_bielec_integrals_in_map psi_det_generators psi_coef_generators psi_det_sorted_bit psi_selectors n_det_generators n_states generators_bitmask zmq_context
|
PROVIDE H_apply_buffer_allocated mo_bielec_integrals_in_map psi_det_generators psi_coef_generators psi_det_sorted_bit psi_selectors n_det_generators n_states generators_bitmask zmq_context
|
||||||
PROVIDE pt2_e0_denominator mo_tot_num N_int fragment_count
|
PROVIDE pt2_e0_denominator mo_tot_num N_int fragment_count
|
||||||
end
|
end
|
||||||
@ -100,6 +101,9 @@ subroutine run_wf
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
end do
|
end do
|
||||||
|
IRP_IF MPI
|
||||||
|
call MPI_finalize(i)
|
||||||
|
IRP_ENDIF
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,3 +1,23 @@
|
|||||||
|
BEGIN_PROVIDER [ integer, mpi_bit_kind ]
|
||||||
|
use bitmasks
|
||||||
|
include 'mpif.h'
|
||||||
|
implicit none
|
||||||
|
BEGIN_DOC
|
||||||
|
! MPI bit kind type
|
||||||
|
END_DOC
|
||||||
|
IRP_IF MPI
|
||||||
|
if (bit_kind == 4) then
|
||||||
|
mpi_bit_kind = MPI_INTEGER4
|
||||||
|
else if (bit_kind == 8) then
|
||||||
|
mpi_bit_kind = MPI_INTEGER8
|
||||||
|
else
|
||||||
|
stop 'Wrong bit kind in mpi_bit_kind'
|
||||||
|
endif
|
||||||
|
IRP_ELSE
|
||||||
|
mpi_bit_kind = -1
|
||||||
|
IRP_ENDIF
|
||||||
|
END_PROVIDER
|
||||||
|
|
||||||
BEGIN_PROVIDER [ logical, mpi_initialized ]
|
BEGIN_PROVIDER [ logical, mpi_initialized ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
@ -32,12 +52,14 @@ END_PROVIDER
|
|||||||
print *, 'ierr = ', ierr
|
print *, 'ierr = ', ierr
|
||||||
stop 'Unable to get MPI rank'
|
stop 'Unable to get MPI rank'
|
||||||
endif
|
endif
|
||||||
|
call write_int(6,mpi_rank,'MPI rank')
|
||||||
|
|
||||||
call MPI_COMM_SIZE (MPI_COMM_WORLD, mpi_size, ierr)
|
call MPI_COMM_SIZE (MPI_COMM_WORLD, mpi_size, ierr)
|
||||||
if (ierr /= 0) then
|
if (ierr /= 0) then
|
||||||
print *, 'ierr = ', ierr
|
print *, 'ierr = ', ierr
|
||||||
stop 'Unable to get MPI size'
|
stop 'Unable to get MPI size'
|
||||||
endif
|
endif
|
||||||
|
call write_int(6,mpi_size,'MPI size')
|
||||||
|
|
||||||
IRP_ELSE
|
IRP_ELSE
|
||||||
mpi_rank = 0
|
mpi_rank = 0
|
||||||
|
@ -25,6 +25,7 @@ except ImportError:
|
|||||||
"quantum_package.rc"))
|
"quantum_package.rc"))
|
||||||
|
|
||||||
print "\n".join(["", "Error:", "source %s" % f, ""])
|
print "\n".join(["", "Error:", "source %s" % f, ""])
|
||||||
|
raise
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
|
||||||
@ -825,6 +826,7 @@ if __name__ == "__main__":
|
|||||||
arguments = pickle.load(handle)
|
arguments = pickle.load(handle)
|
||||||
except IOError:
|
except IOError:
|
||||||
print "You need to create first my friend"
|
print "You need to create first my friend"
|
||||||
|
raise
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
elif arguments["create"]:
|
elif arguments["create"]:
|
||||||
@ -927,6 +929,7 @@ if __name__ == "__main__":
|
|||||||
"- Or install a module that needs {0} with a main "]
|
"- Or install a module that needs {0} with a main "]
|
||||||
|
|
||||||
print "\n".join(l_msg).format(module.rel)
|
print "\n".join(l_msg).format(module.rel)
|
||||||
|
raise
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
# ~#~#~#~#~#~#~#~#~#~#~#~ #
|
# ~#~#~#~#~#~#~#~#~#~#~#~ #
|
||||||
|
@ -2,7 +2,6 @@ module bitmasks
|
|||||||
integer, parameter :: bit_kind_shift = 6 ! 5: 32 bits, 6: 64 bits
|
integer, parameter :: bit_kind_shift = 6 ! 5: 32 bits, 6: 64 bits
|
||||||
integer, parameter :: bit_kind_size = 64
|
integer, parameter :: bit_kind_size = 64
|
||||||
integer, parameter :: bit_kind = 8
|
integer, parameter :: bit_kind = 8
|
||||||
integer, parameter :: mpi_bit_kind = 8
|
|
||||||
integer, parameter :: d_hole1 = 1
|
integer, parameter :: d_hole1 = 1
|
||||||
integer, parameter :: d_part1 = 2
|
integer, parameter :: d_part1 = 2
|
||||||
integer, parameter :: d_hole2 = 3
|
integer, parameter :: d_hole2 = 3
|
||||||
|
@ -132,7 +132,7 @@ subroutine davidson_diag_hjj_sjj(dets_in,u_in,H_jj,s2_out,energies,dim_in,sze,N_
|
|||||||
+ 4.d0*(N_st_diag*itermax)+nproc*(4.d0*N_det_alpha_unique+2.d0*N_st_diag*sze)))/(1024.d0**3)
|
+ 4.d0*(N_st_diag*itermax)+nproc*(4.d0*N_det_alpha_unique+2.d0*N_st_diag*sze)))/(1024.d0**3)
|
||||||
call write_double(iunit, r1, 'Memory(Gb)')
|
call write_double(iunit, r1, 'Memory(Gb)')
|
||||||
write(iunit,'(A)') ''
|
write(iunit,'(A)') ''
|
||||||
write_buffer = '===='
|
write_buffer = '====='
|
||||||
do i=1,N_st
|
do i=1,N_st
|
||||||
write_buffer = trim(write_buffer)//' ================ =========== ==========='
|
write_buffer = trim(write_buffer)//' ================ =========== ==========='
|
||||||
enddo
|
enddo
|
||||||
@ -142,7 +142,7 @@ subroutine davidson_diag_hjj_sjj(dets_in,u_in,H_jj,s2_out,energies,dim_in,sze,N_
|
|||||||
write_buffer = trim(write_buffer)//' Energy S^2 Residual '
|
write_buffer = trim(write_buffer)//' Energy S^2 Residual '
|
||||||
enddo
|
enddo
|
||||||
write(iunit,'(A)') write_buffer(1:6+41*N_states)
|
write(iunit,'(A)') write_buffer(1:6+41*N_states)
|
||||||
write_buffer = '===='
|
write_buffer = '====='
|
||||||
do i=1,N_st
|
do i=1,N_st
|
||||||
write_buffer = trim(write_buffer)//' ================ =========== ==========='
|
write_buffer = trim(write_buffer)//' ================ =========== ==========='
|
||||||
enddo
|
enddo
|
||||||
@ -426,7 +426,7 @@ subroutine davidson_diag_hjj_sjj(dets_in,u_in,H_jj,s2_out,energies,dim_in,sze,N_
|
|||||||
energies(k) = lambda(k)
|
energies(k) = lambda(k)
|
||||||
s2_out(k) = s2(k)
|
s2_out(k) = s2(k)
|
||||||
enddo
|
enddo
|
||||||
write_buffer = '===== '
|
write_buffer = '======'
|
||||||
do i=1,N_st
|
do i=1,N_st
|
||||||
write_buffer = trim(write_buffer)//' ================ =========== ==========='
|
write_buffer = trim(write_buffer)//' ================ =========== ==========='
|
||||||
enddo
|
enddo
|
||||||
|
Loading…
Reference in New Issue
Block a user