37 use,
intrinsic :: iso_fortran_env
72 integer :: w90_what, w90_mode
73 integer(int64) :: w90_what_default
77 integer :: ii, nik, iter, nst
79 type(restart_t) :: restart
80 type(electrons_t),
pointer :: sys
81 logical :: w90_spinors, scdm_proj, w90_scdm
82 integer :: w90_nntot, w90_num_bands, w90_num_kpts
83 integer,
allocatable :: w90_nnk_list(:,:)
84 character(len=80) :: w90_prefix
85 integer :: w90_num_wann
86 real(real64),
allocatable :: w90_proj_centers(:,:)
87 integer,
allocatable :: w90_proj_lmr(:,:)
89 integer,
allocatable :: w90_spin_proj_component(:)
90 real(real64),
allocatable :: w90_spin_proj_axis(:,:)
91 integer :: w90_num_exclude
92 logical,
allocatable :: exclude_list(:)
93 integer,
allocatable :: band_index(:)
94 logical :: read_td_states
95 integer :: w90_spin_channel
96 logical :: w90_bloch_sums = .false.
99 integer,
allocatable :: jpvt(:)
100 complex(real64),
allocatable :: uk(:,:,:)
101 complex(real64),
allocatable :: psi(:,:)
102 complex(real64),
allocatable :: chi(:,:), chi_diag(:,:),chi2(:,:)
103 real(real64),
allocatable :: chi_eigenval(:), occ_temp(:)
104 real(real64) :: scdm_mu, scdm_sigma, smear, kvec(3), factor(3)
105 integer :: ist, jst, ik, idir, sender
107 integer(int64) :: how
131 if (w90_prefix ==
'w90')
then
132 message(1) =
"oct-wannier90: the prefix is set by default to w90"
162 if (w90_mode == 0)
then
163 message(1) =
"Wannier90Mode must be set to a value different from 0."
185 w90_what_default = option__wannier90files__w90_mmn + option__wannier90files__w90_amn + option__wannier90files__w90_eig
186 if (sys%st%d%ispin ==
spinors) w90_what_default = w90_what_default + option__wannier90files__w90_spn
227 if (sys%kpoints%use_symmetries)
then
228 message(1) =
'oct-wannier90: k-points symmetries are not allowed'
231 if (sys%kpoints%use_time_reversal)
then
232 message(1) =
'oct-wannier90: time-reversal symmetry is not allowed'
235 if (sys%kpoints%reduced%nshifts > 1)
then
236 message(1) =
'oct-wannier90: Wannier90 does not allow for multiple shifts of the k-point grid'
244 w90_spinors = .false.
256 do idir = sys%space%periodic_dim+1, sys%space%dim
257 factor(idir) =
m_two * sys%gr%box%bounding_box_l(idir)
259 call sys%ions%latt%scale(factor)
262 select case (w90_mode)
263 case (option__wannier90mode__w90_setup)
267 case (option__wannier90mode__w90_output)
270 case (option__wannier90mode__w90_wannier)
286 if (read_td_states)
then
288 sys%mc, ierr, sys%gr)
291 sys%mc, ierr, sys%gr)
299 if (dim == sys%st%d%dim .and. nik == sys%kpoints%reduced%npoints .and. nst >= sys%st%nst)
then
301 ierr, iter, label =
": wannier90", skip=exclude_list)
303 write(
message(1),
'(a)')
'Restart structure not commensurate.'
311 message(1) =
"Wannier90Mode is set to an unsupported value."
315 safe_deallocate_a(exclude_list)
316 safe_deallocate_a(band_index)
317 safe_deallocate_a(w90_nnk_list)
318 safe_deallocate_a(w90_proj_centers)
319 safe_deallocate_a(w90_proj_lmr)
321 safe_deallocate_p(sys)
333 type(
ions_t),
intent(in) :: ions
335 class(
space_t),
intent(in) :: space
337 character(len=80) :: filename
338 integer :: w90_win, ia, axis(3), npath
342 assert(space%dim == 3)
345 filename = trim(adjustl(w90_prefix)) //
'.win'
348 write(w90_win,
'(a)')
'# this file has been created by the Octopus wannier90 utility'
349 write(w90_win,
'(a)')
' '
352 write(w90_win,
'(a)')
'begin unit_cell_cart'
353 write(w90_win,
'(a)')
'Ang'
357 write(w90_win,
'(a)')
'end unit_cell_cart'
358 write(w90_win,
'(a)')
' '
360 write(w90_win,
'(a)')
'begin atoms_frac'
361 do ia = 1, ions%natoms
362 write(w90_win,
'(a,2x,f13.8,f13.8,f13.8)') trim(ions%atom(ia)%label), ions%latt%cart_to_red(ions%pos(:, ia))
364 write(w90_win,
'(a)')
'end atoms_frac'
365 write(w90_win,
'(a)')
' '
368 write(w90_win,
'(a)')
'use_bloch_phases = .true.'
369 write(w90_win,
'(a)')
' '
371 write(w90_win,
'(a10,i4)')
'num_bands ', sys%st%nst
372 write(w90_win,
'(a9,i4)')
'num_wann ', sys%st%nst
373 write(w90_win,
'(a)')
' '
375 if (sys%st%d%ispin ==
spinors)
then
376 write(w90_win,
'(a)')
'spinors = .true.'
379 if (w90_spin_channel == 1)
then
380 write(w90_win,
'(a)')
'spin = up'
381 else if (w90_spin_channel == 2)
then
382 write(w90_win,
'(a)')
'spin = down'
384 message(1) =
'Wannier90SpinChannel value is invalid.'
390 write(w90_win,
'(a)')
'write_u_matrices = .true.'
391 write(w90_win,
'(a)')
'write_xyz = .true.'
392 write(w90_win,
'(a)')
' '
394 if (kpoints%reduced%npoints == 1)
then
395 write(w90_win,
'(a)')
'gamma_only = .true.'
396 write(w90_win,
'(a)')
' '
399 message(1) =
'oct-wannier90: need Monkhorst-Pack grid. Please specify %KPointsGrid'
404 npath = kpoints%nkpt_in_path()
406 axis(1:3) = kpoints%nik_axis(1:3)
407 assert(product(kpoints%nik_axis(1:3)) == kpoints%reduced%npoints - npath)
409 write(w90_win,
'(a8,i4,i4,i4)')
'mp_grid =', axis(1:3)
410 write(w90_win,
'(a)')
' '
411 write(w90_win,
'(a)')
'begin kpoints '
414 do ii = 1, kpoints%reduced%npoints-npath
415 write(w90_win,
'(f13.8,f13.8,f13.8)') - kpoints%reduced%red_point(1:3,ii)
417 write(w90_win,
'(a)')
'end kpoints '
436 if (read_td_states)
then
438 sys%mc, ierr, sys%gr)
441 sys%mc, ierr, sys%gr)
449 if (dim == sys%st%d%dim .and. nik == sys%kpoints%reduced%npoints .and. nst >= sys%st%nst)
then
451 ierr, iter, label =
": wannier90", skip=exclude_list)
453 write(
message(1),
'(a)')
'Restart structure not commensurate.'
461 safe_allocate(jpvt(1:sys%gr%np_global*sys%st%d%dim))
462 safe_allocate(psi(1:sys%gr%np, 1:sys%st%d%dim))
463 safe_allocate(occ_temp(1:w90_num_bands))
466 do ist = 1, w90_num_bands
467 occ_temp(ist)= sys%st%occ(ist, 1)
468 sys%st%occ(ist, 1)=
m_half*erfc((sys%st%eigenval(ist, 1)-scdm_mu) / scdm_sigma)
474 do ist = 1, w90_num_bands
475 sys%st%occ(ist, 1) = occ_temp(ist)
478 safe_allocate(uk(1:w90_num_bands, 1:w90_num_bands, 1:nik))
481 safe_allocate(chi(1:w90_num_bands, 1:w90_num_bands))
482 safe_allocate(chi_diag(1:w90_num_bands, 1:w90_num_bands))
483 safe_allocate(chi2(1:w90_num_bands, 1:w90_num_bands))
484 safe_allocate(chi_eigenval(1:w90_num_bands))
486 chi(1:w90_num_bands, 1:w90_num_bands) =
m_zero
489 kvec(:) = sys%kpoints%reduced%point(:, ik)
492 ik_real = (ik-1)*2 + w90_spin_channel
497 do ist = 1, w90_num_bands
501 sender = sys%st%d%kpt%mpi_grp%rank
503 call sys%st%d%kpt%mpi_grp%allreduce_inplace(sender, 1, mpi_integer, mpi_max)
505 call sys%st%d%kpt%mpi_grp%bcast(psi, sys%gr%np*sys%st%d%dim, mpi_double_complex, sender)
506 smear=
m_half * erfc((sys%st%eigenval(ist, ik_real) - scdm_mu) / scdm_sigma)
508 do jst = 1, w90_num_bands
509 chi(ist, jst) = smear * conjg(psi(jpvt(jst), 1)) &
510 *
exp(
m_zi * dot_product(sys%gr%x(1:3, jpvt(jst)), kvec(1:3)))
516 chi_diag = matmul(conjg(transpose(chi)), chi)
518 chi2 = conjg(transpose(chi_diag))
521 if (any(chi_eigenval(:) .lt.
m_zero))
then
522 message(1) =
'SCDM Wannierization failed because chi matrix is'
523 message(2) =
'ill conditioned. Try increasingin scdm_sigma and/or'
528 do ist = 1, w90_num_bands
529 chi_eigenval(ist) =
m_one /
sqrt(chi_eigenval(ist))
530 chi2(ist, 1:w90_num_bands) = chi_eigenval(ist) * chi2(ist, 1:w90_num_bands)
534 uk(:,:,ik) = matmul(chi, matmul(chi_diag,chi2))
538 safe_deallocate_a(chi)
539 safe_deallocate_a(psi)
540 safe_deallocate_a(chi_diag)
541 safe_deallocate_a(chi2)
542 safe_deallocate_a(chi_eigenval)
543 safe_deallocate_a(jpvt)
544 safe_deallocate_a(occ_temp)
548 if (
bitand(w90_what, option__wannier90files__w90_mmn) /= 0)
then
552 if (
bitand(w90_what, option__wannier90files__w90_unk) /= 0)
then
553 call write_unk(sys%space, sys%gr, sys%st, formatted=.false.)
556 if (
bitand(w90_what, option__wannier90files__w90_amn) /= 0)
then
560 if (
bitand(w90_what, option__wannier90files__w90_eig) /= 0)
then
564 if (
bitand(w90_what, option__wannier90files__w90_spn) /= 0)
then
568 safe_deallocate_a(uk)
569 safe_deallocate_a(w90_spin_proj_component)
570 safe_deallocate_a(w90_spin_proj_axis)
577 integer :: w90_nnkp, itemp, dummyint, io, spin_channel_win
578 character(len=80) :: filename, dummy, dummy1, dummy2, line
579 logical :: exist, parse_is_ok
580 real(real64) :: dummyr(7)
584 w90_num_kpts = product(sys%kpoints%nik_axis(1:3))
585 assert(w90_num_kpts == sys%st%nik)
591 filename = trim(adjustl(w90_prefix)) //
'.nnkp'
593 message(1) =
"oct-wannier90: Parsing "//filename
596 inquire(file=filename,exist=exist)
597 if (.not. exist)
then
598 message(1) =
'oct-wannier90: Cannot find specified Wannier90 nnkp file.'
599 write(
message(2),
'(a)')
'Please run wannier90.x -pp '// trim(adjustl(w90_prefix)) //
' first.'
603 parse_is_ok = .false.
608 read(w90_nnkp, *, iostat=io) dummy, dummy1
609 if (io == iostat_end)
exit
611 if (dummy ==
'begin' .and. dummy1 ==
'kpoints')
then
612 read(w90_nnkp,*) itemp
613 if (itemp /= w90_num_kpts)
then
614 message(1) =
'oct-wannier90: wannier90 setup seems to have been done with a different number of k-points.'
624 if (.not. parse_is_ok)
then
625 message(1) =
'oct-wannier90: Did not find the kpoints block in nnkp file'
628 parse_is_ok = .false.
634 read(w90_nnkp, *, iostat=io) dummy, dummy1
635 if (io == iostat_end)
exit
637 if (dummy ==
'begin' .and. dummy1 ==
'nnkpts')
then
638 read(w90_nnkp,*) w90_nntot
639 safe_allocate(w90_nnk_list(1:5, 1:w90_num_kpts * w90_nntot))
640 do ii = 1, w90_num_kpts * w90_nntot
641 read(w90_nnkp,*) w90_nnk_list(1:5, ii)
644 read(w90_nnkp,*) dummy
645 if (dummy /=
'end')
then
646 message(1) =
'oct-wannier90: There dont seem to be enough k-points in nnkpts file to.'
654 if (.not. parse_is_ok)
then
655 message(1) =
'oct-wannier90: Did not find nnkpts block in nnkp file'
661 safe_allocate(exclude_list(1:sys%st%nst))
663 exclude_list(1:sys%st%nst) = .false.
666 read(w90_nnkp, *, iostat=io) dummy, dummy1
667 if (io == iostat_end)
exit
668 if (dummy ==
'begin' .and. dummy1 ==
'exclude_bands')
then
669 read(w90_nnkp, *) w90_num_exclude
670 do ii = 1, w90_num_exclude
671 read(w90_nnkp, *) itemp
672 if(itemp > sys%st%nst)
then
673 message(1) =
'oct-wannier90: The exclude_bands list contains a state index higher than the number of states.'
676 exclude_list(itemp) = .
true.
679 read(w90_nnkp, *) dummy
680 if (dummy /=
'end')
then
681 message(1) =
'oct-wannier90: There dont seem to be enough bands in exclude_bands list.'
690 w90_num_bands = sys%st%nst - w90_num_exclude
692 safe_allocate(band_index(1:sys%st%nst))
694 do ii = 1, sys%st%nst
695 if (exclude_list(ii)) cycle
697 band_index(ii) = itemp
700 if (
bitand(w90_what, option__wannier90files__w90_amn) /= 0 &
701 .or. w90_mode == option__wannier90mode__w90_wannier )
then
706 read(w90_nnkp, *, iostat=io) dummy, dummy1
707 if (io == iostat_end)
then
708 message(1) =
'oct-wannier90: Did not find projections block in w90.nnkp file'
712 if (dummy ==
'begin' .and. (dummy1 ==
'projections' .or. dummy1 ==
'spinor_projections'))
then
714 if (dummy1 ==
'spinor_projections')
then
716 if (sys%st%d%ispin /=
spinors)
then
717 message(1) =
'oct-wannier90: Spinor = .true. is only valid with spinors wavefunctions.'
721 message(1) =
'oct-wannier90: Spinor interface incomplete. Note there is no quantization axis implemented'
724 if (sys%st%d%ispin ==
spinors)
then
725 message(1) =
'oct-wannier90: Octopus has spinors wavefunctions but spinor_projections is not defined.'
726 message(2) =
'oct-wannier90: Please check the input file for wannier 90.'
731 read(w90_nnkp, *) w90_nproj
734 w90_num_wann = w90_nproj
736 if(w90_nproj == 0) w90_num_wann = w90_num_bands
738 safe_allocate(w90_proj_centers(1:3, 1:w90_nproj))
739 safe_allocate(w90_proj_lmr(1:w90_nproj, 1:3))
740 if (w90_spinors)
then
741 safe_allocate(w90_spin_proj_component(1:w90_nproj))
743 if (w90_spinors)
then
744 safe_allocate(w90_spin_proj_axis(1:w90_nproj, 1:3))
748 read(w90_nnkp, *) w90_proj_centers(1:3, ii), w90_proj_lmr(ii, 1:3)
750 read(w90_nnkp, *) dummyr(1:7)
751 if (w90_spinors)
then
752 read(w90_nnkp, *) w90_spin_proj_component(ii), w90_spin_proj_axis(ii, 1:3)
754 if (w90_spin_proj_component(ii) == -1) w90_spin_proj_component(ii) = 2
758 read(w90_nnkp, *) dummy
759 if (dummy /=
'end')
then
760 message(1) =
'oct-wannier90: There dont seem to be enough projections in nnkpts file to.'
770 read(w90_nnkp, *, iostat=io) dummy, dummy1
771 if (io == iostat_end)
exit
773 if (dummy ==
'begin' .and. dummy1 ==
'auto_projections')
then
775 read(w90_nnkp, *) w90_nproj
776 w90_num_wann = w90_nproj
778 if (.not. w90_scdm)
then
779 message(1) =
'oct-wannier90: Found auto_projections block. Currently the only implemented automatic way'
780 message(2) =
'oct-wannier90: to compute projections is the SCDM method.'
781 message(3) =
'oct-wannier90: Please set Wannier90UseSCDM = yes in the inp file.'
785 if (w90_nproj /= w90_num_bands)
then
786 message(1) =
'oct-wannier90: In auto_projections block first row needs to be equal to num_bands.'
789 read(w90_nnkp, *) dummyint
790 if (dummyint /= 0)
then
791 message(1) =
'oct-wannier90: The second row in auto_projections has to be 0, per Wannier90 documentation.'
800 message(1) =
"oct-wannier90: Finished parsing "//filename
805 filename = trim(adjustl(w90_prefix)) //
'.win'
806 message(1) =
"oct-wannier90: Parsing "//filename
810 read(w90_nnkp, fmt=
'(a)', iostat=io) line
811 if (io == iostat_end)
exit
812 if (index(line,
'=') > 0)
then
813 read(line, *, iostat=io) dummy, dummy2, dummy1
815 read(line, *, iostat=io) dummy, dummy1
819 if (dummy ==
'spin')
then
821 message(1) =
'oct-wannier90: The variable spin is set for a non spin-polarized calculation.'
825 if (dummy1 ==
'up')
then
827 else if (dummy1 ==
'down')
then
830 message(1) =
'oct-wannier90: Error parsing the variable spin.'
833 if (spin_channel_win /= w90_spin_channel)
then
834 message(1) =
'spin polarization input from .win and Wannier90SpinChannel do not agree.'
842 write(
message(1),
'(a,i1)')
'oct-wannier90: Using spin channel ', w90_spin_channel
846 message(1) =
"oct-wannier90: Finished parsing "//filename
855 class(
mesh_t),
intent(in) :: mesh
858 integer :: ist, jst, ik, ip, w90_mmn, iknn, ib
859 real(real64) :: Gcart(3)
861 character(len=80) :: filename
862 complex(real64),
allocatable :: overlap(:), ss(:)
863 complex(real64),
allocatable :: psin(:,:), phase(:)
865 integer :: inode, node_fr, node_to
866 type(mpi_request) :: send_req
872 if (st%parallel_in_states)
then
876 message(1) =
"Info: Computing the overlap matrix"
880 filename =
'./'// trim(adjustl(w90_prefix))//
'.mmn'
884 if (st%system_grp%is_root())
then
885 write(w90_mmn,*)
'Created by oct-wannier90'
886 write(w90_mmn,*) w90_num_bands, w90_num_kpts, w90_nntot
889 safe_allocate(psin(1:mesh%np, 1:st%d%dim))
890 safe_allocate(phase(1:mesh%np))
891 safe_allocate(overlap(1:w90_num_bands))
892 safe_allocate(ss(1:st%nst))
896 do ii = 1, w90_num_kpts * w90_nntot
897 ik = w90_nnk_list(1, ii)
898 iknn = w90_nnk_list(2, ii)
899 g(1:3) = w90_nnk_list(3:5, ii)
900 if (st%system_grp%is_root())
write(w90_mmn,
'(I10,2x,I10,2x,I3,2x,I3,2x,I3)') ik, iknn, g
903 g(sys%space%periodic_dim+1:sys%space%dim) = 0
907 ik = (ik-1)*2 + w90_spin_channel
908 iknn = (iknn-1)*2 + w90_spin_channel
913 if(ik >= st%d%kpt%start .and. ik <= st%d%kpt%end)
then
922 if (any(g /= 0))
then
925 phase(ip) =
exp(-
m_zi*dot_product(mesh%x(1:3, ip), gcart(1:3)))
934 if (exclude_list(jst)) cycle
937 if ( .not. st%d%kpt%parallel .and. .not. st%parallel_in_states)
then
942 do inode = 0, st%d%kpt%mpi_grp%size-1
943 if(iknn >= st%st_kpt_task(inode,3) .and. iknn <= st%st_kpt_task(inode,4))
then
946 if(ik >= st%st_kpt_task(inode,3) .and. ik <= st%st_kpt_task(inode,4))
then
953 send_req = mpi_request_null
958 if(node_to /= st%d%kpt%mpi_grp%rank)
then
959 call st%d%kpt%mpi_grp%isend(psin, mesh%np*st%d%dim, mpi_double_complex, node_to, send_req)
963 if(node_to == st%d%kpt%mpi_grp%rank .and. node_to /= node_fr)
then
964 call st%d%kpt%mpi_grp%recv(psin, mesh%np*st%d%dim, mpi_double_complex, node_fr)
966 if (send_req /= mpi_request_null)
then
967 call st%d%kpt%mpi_grp%wait(send_req)
973 if(ik >= st%d%kpt%start .and. ik <= st%d%kpt%end)
then
976 if (any(g /= 0))
then
979 do idim = 1, st%d%dim
982 psin(ip, idim) = psin(ip, idim) * phase(ip)
991 do ib = st%group%block_start, st%group%block_end
992 batch => st%group%psib(ib, ik)
993 if (all(exclude_list(batch%ist(1:batch%nst)))) cycle
995 do ist = 1, batch%nst
996 if (exclude_list(batch%ist(ist))) cycle
997 overlap(band_index(batch%ist(ist))) = ss(ist)
1003 call mesh%allreduce(overlap)
1006 if(st%d%kpt%parallel)
then
1011 if (st%system_grp%is_root())
then
1013 if (exclude_list(ist)) cycle
1014 write(w90_mmn,
'(e18.10,2x,e18.10)') overlap(band_index(ist))
1023 safe_deallocate_a(psin)
1024 safe_deallocate_a(phase)
1025 safe_deallocate_a(overlap)
1026 safe_deallocate_a(ss)
1036 integer :: ist, ik, w90_eig
1037 character(len=80) :: filename
1041 if (sys%st%parallel_in_states)
then
1045 if (sys%st%system_grp%is_root())
then
1046 filename =
'./'//trim(adjustl(w90_prefix))//
'.eig'
1048 do ik = 1, w90_num_kpts
1049 do ist = 1, sys%st%nst
1050 if (exclude_list(ist)) cycle
1052 write(w90_eig,
'(I5,2x,I8,2x,e18.10)') band_index(ist), ik, &
1055 write(w90_eig,
'(I5,2x,I8,2x,e18.10)') band_index(ist), ik, &
1068 subroutine write_unk(space, mesh, st, formatted)
1069 class(
space_t),
intent(in) :: space
1070 class(
mesh_t),
intent(in) :: mesh
1072 logical,
intent(in) :: formatted
1074 integer :: ist, ik, unk_file, ispin
1075 integer :: ix, iy, iz
1076 real(real64) :: w_real, w_imag
1077 character(len=80) :: filename
1078 complex(real64),
allocatable :: psi(:)
1084 if (st%d%kpt%parallel)
then
1088 if (sys%gr%parallel_in_domains)
then
1092 if (st%parallel_in_states)
then
1099 safe_allocate(psi(1:mesh%np))
1102 mesh%coord_system, need_partition=.not.mesh%parallel_in_domains)
1107 do ik = 1, w90_num_kpts
1108 do ispin = 1, st%d%dim
1109 if (st%system_grp%is_root())
then
1110 write(filename,
'(a,i5.5,a1,i1)')
'./UNK', ik,
'.', ispin
1114 write(unk_file, *) mesh%idx%ll(1:mesh%idx%dim), ik, w90_num_bands
1117 write(unk_file) mesh%idx%ll(1:mesh%idx%dim), ik, w90_num_bands
1123 if (exclude_list(ist)) cycle
1133 assert(.not. cube%parallel_in_domains)
1136 if (st%system_grp%is_root())
then
1138 do iz=1,cube%rs_n_global(3)
1139 do iy = 1,cube%rs_n_global(2)
1140 do ix = 1,cube%rs_n_global(1)
1141 w_real = real(cf%zrs(ix,iy,iz), real64)
1142 w_imag = aimag(cf%zrs(ix,iy,iz))
1143 write (unk_file, *) w_real, w_imag
1148 write(unk_file) (((cf%zrs(ix,iy,iz), ix=1,cube%rs_n_global(1)), iy=1,cube%rs_n_global(2)), iz=1,cube%rs_n_global(3))
1152 if (st%system_grp%is_root())
call io_close(unk_file)
1159 safe_deallocate_a(psi)
1167 class(
space_t),
intent(in) :: space
1168 class(
mesh_t),
intent(in) :: mesh
1173 integer :: ist, ik, w90_amn, idim, iw, ip, ik_real
1174 real(real64) :: center(3), kpoint(3), threshold
1175 character(len=80) :: filename
1176 complex(real64),
allocatable :: psi(:,:), phase(:), projection(:)
1177 real(real64),
allocatable :: ylm(:)
1183 if (st%parallel_in_states)
then
1187 filename =
'./'// trim(adjustl(w90_prefix))//
'.amn'
1191 if (st%system_grp%is_root())
then
1192 write(w90_amn,*)
'Created by oct-wannier90'
1193 write(w90_amn,*) w90_num_bands, w90_num_kpts, w90_num_wann
1198 message(1) =
"Info: Writing projections obtained from SCDM."
1202 do ik = 1, w90_num_kpts
1204 if (exclude_list(ist)) cycle
1205 if (st%system_grp%is_root())
then
1206 do iw = 1, w90_nproj
1207 write (w90_amn,
'(I5,2x,I5,2x,I5,2x,e18.10,2x,e18.10)') band_index(ist), iw, ik, uk(band_index(ist),iw,ik)
1215 message(1) =
"Info: Computing the projection matrix"
1221 safe_allocate(orbitals(1:w90_nproj))
1226 orbitals(iw)%norbs = 1
1227 orbitals(iw)%ndim = 1
1228 orbitals(iw)%radius = -
log(threshold)
1229 orbitals(iw)%use_submesh = .false.
1232 center(1:3) = latt%red_to_cart(w90_proj_centers(1:3, iw))
1233 call submesh_init(orbitals(iw)%sphere, space, mesh, latt, center, orbitals(iw)%radius)
1236 safe_allocate(ylm(1:orbitals(iw)%sphere%np))
1238 call ylm_wannier(ylm, w90_proj_lmr(iw,1), w90_proj_lmr(iw,2), &
1239 orbitals(iw)%sphere%r, orbitals(iw)%sphere%rel_x, orbitals(iw)%sphere%np)
1242 if (w90_proj_lmr(iw,3) == 1)
then
1243 do ip = 1,orbitals(iw)%sphere%np
1244 ylm(ip) = ylm(ip)*
m_two*
exp(-orbitals(iw)%sphere%r(ip))
1250 safe_allocate(orbitals(iw)%zorb(1:orbitals(iw)%sphere%np, 1, 1))
1251 orbitals(iw)%zorb(1:orbitals(iw)%sphere%np, 1, 1) = ylm(1:orbitals(iw)%sphere%np)
1252 safe_deallocate_a(ylm)
1254 safe_allocate(orbitals(iw)%phase(1:orbitals(iw)%sphere%np, st%d%kpt%start:st%d%kpt%end))
1255 orbitals(iw)%phase(:,:) =
m_z0
1256 safe_allocate(orbitals(iw)%eorb_mesh(1:mesh%np, 1, 1, st%d%kpt%start:st%d%kpt%end))
1257 orbitals(iw)%eorb_mesh(:,:,:,:) =
m_z0
1260 kpt_max = w90_num_kpts)
1264 safe_allocate(psi(1:mesh%np, 1:st%d%dim))
1265 safe_allocate(phase(1:mesh%np))
1266 safe_allocate(projection(1:w90_nproj))
1268 do ik = 1, w90_num_kpts
1269 kpoint(1:space%dim) = kpoints%get_point(ik)
1272 phase(ip) =
exp(-
m_zi* sum(mesh%x(1:space%dim, ip) * kpoint(1:space%dim)))
1277 ik_real = (ik-1)*2 + w90_spin_channel
1284 if (exclude_list(ist)) cycle
1288 if(ik_real >= st%d%kpt%start .and. ik_real <= st%d%kpt%end)
then
1292 do idim = 1, st%d%dim
1296 psi(ip, idim) = psi(ip, idim)*phase(ip)
1301 do iw = 1, w90_nproj
1303 if (w90_spinors) idim = w90_spin_proj_component(iw)
1307 projection(iw) =
zmf_dotp(mesh, psi(1:mesh%np,idim), &
1308 orbitals(iw)%eorb_mesh(1:mesh%np,1,1,ik_real), reduce = .false.)
1312 call mesh%allreduce(projection)
1316 if(st%d%kpt%parallel)
then
1320 if (st%system_grp%is_root())
then
1321 do iw = 1, w90_nproj
1322 write (w90_amn,
'(I5,2x,I5,2x,I5,2x,e18.10,2x,e18.10)') band_index(ist), iw, ik, projection(iw)
1328 safe_deallocate_a(psi)
1329 safe_deallocate_a(phase)
1330 safe_deallocate_a(projection)
1332 do iw = 1, w90_nproj
1335 safe_deallocate_a(orbitals)
1351 class(mesh_t),
intent(in) :: mesh
1352 type(states_elec_t),
target,
intent(in) :: st
1354 integer :: ist, jst, ik, w90_spn, counter
1355 character(len=80) :: filename
1356 complex(real64),
allocatable :: spin(:,:,:)
1357 complex(real64),
allocatable :: psim(:,:), psin(:,:)
1358 complex(real64) :: dot_upup, dot_updown, dot_downup, dot_downdown
1361 call profiling_in(
"W90_SPN")
1363 assert(st%d%ispin == spinors)
1365 if (st%parallel_in_states)
then
1366 call messages_not_implemented(
"w90_spn output with states parallelization")
1369 message(1) =
"Info: Computing the spin file"
1370 call messages_info(1)
1372 filename =
'./'// trim(adjustl(w90_prefix))//
'.spn'
1373 w90_spn = io_open(trim(filename), global_namespace, action=
'write')
1376 if (st%system_grp%is_root())
then
1377 write(w90_spn,*)
'Created by oct-wannier90'
1378 write(w90_spn,*) w90_num_bands, w90_num_kpts
1381 safe_allocate(psim(1:mesh%np, 1:st%d%dim))
1382 safe_allocate(psin(1:mesh%np, 1:st%d%dim))
1383 safe_allocate(spin(1:3, 1:(w90_num_bands*(w90_num_bands+1))/2, 1:w90_num_kpts))
1387 do ik = st%d%kpt%start, st%d%kpt%end
1390 if (exclude_list(jst)) cycle
1392 call states_elec_get_state(st, mesh, jst, ik, psim)
1394 if (exclude_list(ist)) cycle
1396 counter = counter + 1
1398 call states_elec_get_state(st, mesh, ist, ik, psin)
1400 dot_upup = zmf_dotp(mesh, psin(:, 1), psim(:, 1), reduce = .false.)
1401 dot_downdown = zmf_dotp(mesh, psin(:, 2), psim(:, 2), reduce = .false.)
1402 dot_updown = zmf_dotp(mesh, psin(:, 1), psim(:, 2), reduce = .false.)
1403 dot_downup = zmf_dotp(mesh, psin(:, 2), psim(:, 1), reduce = .false.)
1405 spin(1, counter, ik) = dot_updown + dot_downup
1406 spin(2, counter, ik) = -m_zi * dot_updown + m_zi * dot_downup
1407 spin(3, counter, ik) = dot_upup - dot_downdown
1412 call profiling_in(
"W90_SPN_REDUCE")
1413 call mesh%allreduce(spin)
1415 if(st%d%kpt%parallel)
then
1416 call comm_allreduce(st%d%kpt%mpi_grp, spin)
1418 call profiling_out(
"W90_SPN_REDUCE")
1421 if (st%system_grp%is_root())
then
1422 do ik = 1, w90_num_kpts
1425 if (exclude_list(jst)) cycle
1428 if (exclude_list(ist)) cycle
1430 counter = counter + 1
1431 write(w90_spn,
'(e18.10,2x,e18.10)') spin(1, counter, ik)
1432 write(w90_spn,
'(e18.10,2x,e18.10)') spin(2, counter, ik)
1433 write(w90_spn,
'(e18.10,2x,e18.10)') spin(3, counter, ik)
1439 call io_close(w90_spn)
1441 safe_deallocate_a(psim)
1442 safe_deallocate_a(psin)
1443 safe_deallocate_a(spin)
1445 call profiling_out(
"W90_SPN")
1453 class(space_t),
intent(in) :: space
1454 class(mesh_t),
intent(in) :: mesh
1455 type(ions_t),
intent(in) :: ions
1456 type(states_elec_t),
intent(in) :: st
1457 type(kpoints_t),
intent(in) :: kpoints
1459 integer :: w90_u_mat, w90_xyz, nwann, nik
1460 integer :: ik, iw, iw2, ip, ipmax, rankmax, idmmax
1461 real(real64),
allocatable :: centers(:,:), supercell_centers(:,:), new_centers(:,:)
1462 complex(real64),
allocatable :: Umnk(:,:,:)
1463 complex(real64),
allocatable :: zwn(:,:,:), psi(:,:), phase(:,:), phase_bloch(:), zwn_bloch(:,:,:)
1464 character(len=MAX_PATH_LEN) :: fname
1465 real(real64) :: kpoint(3), wmod, wmodmax, xx(space%dim)
1466 character(len=2) :: dum
1468 type(unit_t) :: fn_unit
1469 complex(real64) :: scal
1470 type(block_t) :: blk
1471 integer :: supercell(space%dim), ii, jj, kk, ncols, Nreplica, irep, irepmax
1472 real(real64) :: min_image_displ(3), offset(space%dim)
1474 integer,
allocatable :: parent(:)
1475 real(real64),
parameter :: tol_cluster = 0.25_real64
1480 message(1) =
"oct-wannier90: Constructing the Wannier states from the U matrix."
1481 call messages_info(1)
1483 inquire(file=trim(trim(adjustl(w90_prefix))//
'_centres.xyz'),exist=exist)
1484 if (.not. exist)
then
1485 message(1) =
'oct-wannier90: Cannot find the Wannier90 file seedname_centres.xyz.'
1486 write(message(2),
'(a)')
'Please run wannier90.x with "write_xyz=.true." in '// trim(adjustl(w90_prefix)) //
'.'
1487 call messages_fatal(2)
1490 w90_xyz = io_open(trim(trim(adjustl(w90_prefix))//
'_centres.xyz'), global_namespace, action=
'read')
1492 safe_allocate(centers(1:3, 1:w90_num_wann))
1496 do iw = 1, w90_num_wann
1497 read(w90_xyz, *) dum, centers(1:3, iw)
1499 centers(1:3, iw) = units_to_atomic(unit_angstrom, centers(1:3, iw))
1501 call io_close(w90_xyz)
1505 safe_allocate(parent(1:w90_num_wann))
1506 do iw = 1, w90_num_wann
1509 min_image_displ(:) = ions%latt%cart_to_red(centers(:, iw) - centers(:, jw))
1510 min_image_displ(1:space%periodic_dim) = min_image_displ(1:space%periodic_dim) - nint(min_image_displ(1:space%periodic_dim))
1511 min_image_displ = ions%latt%red_to_cart(min_image_displ)
1512 if (norm2(min_image_displ) < tol_cluster)
then
1513 parent(iw) = parent(jw)
1519 message(1) =
"Info : Clustering of the Wannier centers"
1520 call messages_info(1)
1522 safe_allocate(new_centers(1:3, 1:w90_num_wann))
1523 do iw = 1, w90_num_wann
1524 write(message(1),
'(a,i0,a,3(f7.3,a))')
'Info : Original Wannier center ', &
1525 iw,
' (', centers(1, iw),
', ', centers(2, iw),
', ', centers(3, iw),
')'
1527 if (parent(iw) == iw)
then
1529 new_centers(1:3, iw) = ions%latt%fold_into_cell(centers(1:3, iw))
1533 min_image_displ(:) = ions%latt%cart_to_red(centers(:, iw) - new_centers(:, parent(iw)))
1534 min_image_displ(1:space%periodic_dim) = real(nint(min_image_displ(1:space%periodic_dim)), real64)
1535 min_image_displ = ions%latt%red_to_cart(min_image_displ)
1536 new_centers(1:3, iw) = centers(1:3, iw) - min_image_displ
1539 write(message(2),
'(a,i0,a,3(f7.3,a))')
'Info : New Wannier center ', &
1540 iw,
' (', new_centers(1, iw),
', ', new_centers(2, iw),
', ', new_centers(3, iw),
')'
1541 write(message(3),
'(a)')
''
1542 call messages_info(3)
1546 centers = new_centers - centers
1547 safe_deallocate_a(parent)
1548 safe_deallocate_a(new_centers)
1550 inquire(file=trim(trim(adjustl(w90_prefix))//
'_u_dis.mat'),exist=exist)
1552 message(1) =
'oct-wannier90: Calculation of Wannier states with disentanglement is not yet supported.'
1553 call messages_fatal(1)
1556 inquire(file=trim(trim(adjustl(w90_prefix))//
'_u.mat'),exist=exist)
1557 if (.not. exist)
then
1558 message(1) =
'oct-wannier90: Cannot find the Wannier90 seedname_u.mat file.'
1559 write(message(2),
'(a)')
'Please run wannier90.x with "write_u_matrices=.true." in '// trim(adjustl(w90_prefix)) //
'.'
1560 call messages_fatal(2)
1562 w90_u_mat = io_open(trim(trim(adjustl(w90_prefix))//
'_u.mat'), global_namespace, action=
'read')
1568 read(w90_u_mat, *) nik, nwann, nwann
1569 if (nik /= w90_num_kpts .or. nwann /= w90_num_wann)
then
1570 message(1) =
"The file contains U matrices is inconsistent with the .win file."
1571 call messages_fatal(1)
1574 safe_allocate(umnk(1:w90_num_wann, 1:w90_num_wann, 1:w90_num_kpts))
1576 do ik = 1, w90_num_kpts
1581 read(w90_u_mat,
'(f15.10,sp,f15.10)') ((umnk(iw, iw2, ik), iw=1, w90_num_wann), iw2=1, w90_num_wann)
1584 call io_close(w90_u_mat)
1587 call parse_variable(global_namespace,
'OutputFormat', 0, how)
1589 message(1) =
"OutputFormat must be specified for outputing Wannier functions."
1590 call messages_fatal(1)
1600 if (parse_is_defined(sys%namespace,
'Wannier90Supercell'))
then
1601 if (parse_block(sys%namespace,
'Wannier90Supercell', blk) == 0)
then
1602 ncols = parse_block_cols(blk, 0)
1603 if (ncols /= space%dim)
then
1604 write(message(1),
'(a,i3,a,i3)')
'Wannier90Supercell has ', ncols,
' columns but must have ', sys%space%dim
1605 call messages_fatal(1, namespace=sys%namespace)
1607 do ii = 1, space%dim
1608 call parse_block_integer(blk, 0, ii - 1, supercell(ii))
1611 call parse_block_end(blk)
1617 nreplica = product(supercell)
1620 safe_allocate(supercell_centers(1:space%dim, 1:nreplica))
1621 offset(1:space%dim) = -
floor((real(supercell(1:space%dim), real64) - m_one) / m_two)
1623 do ii = 0, supercell(1)-1
1624 do jj = 0, supercell(2)-1
1625 do kk = 0, supercell(3)-1
1626 supercell_centers(:, irep) = ions%latt%red_to_cart(offset &
1627 + [real(ii, real64), real(jj, real64), real(kk, real64)])
1635 call io_mkdir(
'wannier', global_namespace)
1638 safe_allocate(zwn(1:mesh%np, 1:nreplica, 1:st%d%dim))
1639 safe_allocate(psi(1:mesh%np, 1:st%d%dim))
1640 safe_allocate(phase(1:mesh%np, 1:nreplica))
1641 safe_allocate(phase_bloch(1:mesh%np))
1642 if (w90_bloch_sums)
then
1643 safe_allocate(zwn_bloch(1:mesh%np, 1:st%d%dim, st%d%kpt%start:st%d%kpt%end))
1646 do iw = 1, w90_num_wann
1650 do ik = 1, w90_num_kpts
1652 if (.not. (ik >= st%d%kpt%start .and. ik <= st%d%kpt%end)) cycle
1654 if (w90_bloch_sums) zwn_bloch(:,:,ik) = m_z0
1656 kpoint(1:space%dim) = kpoints%get_point(ik, absolute_coordinates=.
true.)
1660 do irep = 1, nreplica
1663 xx = mesh%x(1:space%dim, ip)-centers(1:space%dim, iw) + supercell_centers(1:space%dim, irep)
1664 phase(ip, irep) =
exp(-m_zi* sum( xx * kpoint(1:space%dim)))
1667 if (w90_bloch_sums)
then
1669 xx = mesh%x(1:space%dim, ip)
1670 phase_bloch(ip) =
exp(-m_zi* sum( xx * kpoint(1:space%dim)))
1675 if (exclude_list(iw2)) cycle
1677 if (st%d%ispin /= spin_polarized)
then
1678 call states_elec_get_state(st, mesh, iw2, ik, psi)
1680 call states_elec_get_state(st, mesh, iw2, (ik-1)*2+w90_spin_channel, psi)
1684 do idim = 1, st%d%dim
1685 do irep = 1, nreplica
1688 zwn(ip, irep, idim) = zwn(ip, irep, idim) + umnk(band_index(iw2), iw, ik) * psi(ip, idim) * phase(ip, irep)
1695 if (w90_bloch_sums)
then
1697 do idim = 1, st%d%dim
1700 zwn_bloch(ip, idim, ik) = zwn_bloch(ip, idim, ik) &
1701 + umnk(band_index(iw2), iw, ik) * psi(ip, idim) * phase_bloch(ip)
1709 if(st%d%kpt%parallel)
then
1710 call comm_allreduce(st%d%kpt%mpi_grp, zwn)
1715 if (sys%st%d%ispin /= spinors)
then
1719 do irep = 1, nreplica
1721 wmod = real(zwn(ip, irep, 1)*conjg(zwn(ip, irep, 1)), real64)
1722 if (wmod > wmodmax)
then
1729 scal =
sqrt(wmodmax)/zwn(ipmax, irepmax, 1)/w90_num_kpts
1730 call mesh_minmaxloc(mesh, wmodmax, rankmax, mpi_maxloc)
1731 call mesh%mpi_grp%bcast(scal, 1, mpi_double_complex, rankmax)
1732 call lalg_scal(mesh%np, nreplica, scal, zwn(:,:,1))
1734 if (w90_bloch_sums)
then
1735 do ik = st%d%kpt%start, st%d%kpt%end
1739 do idim = 1, st%d%dim
1741 wmod = real(zwn_bloch(ip, idim, ik)*conjg(zwn_bloch(ip, idim, ik)), real64)
1742 if (wmod > wmodmax)
then
1749 scal =
sqrt(wmodmax)/zwn_bloch(ipmax, idmmax, ik)/w90_num_kpts
1750 call mesh_minmaxloc(mesh, wmodmax, rankmax, mpi_maxloc)
1751 call mesh%mpi_grp%bcast(scal, 1, mpi_double_complex, rankmax)
1752 call lalg_scal(mesh%np, st%d%dim, scal, zwn_bloch(:,:,ik))
1758 fn_unit =
sqrt(units_out%length**(-space%dim))
1759 do idim = 1, st%d%dim
1760 if (st%d%ispin == spinors)
then
1761 write(fname,
'(a,i3.3,a4,i1)')
'wannier-', iw,
'-isp', idim
1763 write(fname,
'(a,i3.3,a4,i1)')
'wannier-', iw
1765 if (any(supercell_centers > 1))
then
1766 call io_function_output_supercell(how,
"wannier", trim(fname), mesh, &
1767 space, ions%latt, zwn(:, :, idim), supercell_centers, supercell, fn_unit, ierr, global_namespace, &
1768 pos=ions%pos, atoms=ions%atom, grp = st%dom_st_kpt_mpi_grp)
1771 call zio_function_output(how,
"wannier", trim(fname), global_namespace, space, mesh, &
1772 zwn(:, 1, idim), fn_unit, ierr, pos=ions%pos, atoms=ions%atom, grp = st%dom_st_kpt_mpi_grp)
1777 if (w90_bloch_sums)
then
1778 do ik = st%d%kpt%start, st%d%kpt%end
1779 do idim = 1, st%d%dim
1780 if (st%d%ispin == spinors)
then
1781 write(fname,
'(a,i3.3,a4,i1,a3,i5.5)')
'wannier_bloch-', iw,
'-isp', idim,
'-ik', ik
1783 write(fname,
'(a,i3.3,a4,i1,a3,i5.5)')
'wannier_bloch-', iw,
'-ik', ik
1785 call zio_function_output(how,
"wannier", trim(fname), global_namespace, space, mesh, &
1786 zwn_bloch(:, idim, ik), fn_unit, ierr, pos=ions%pos, atoms=ions%atom)
1792 if (sys%st%d%ispin /= spinors)
then
1794 do irep = 1, nreplica
1796 if(abs(real(zwn(ip, irep, 1), real64)) >= 1e-2_real64)
then
1797 wmodmax = max(wmodmax, abs(aimag(zwn(ip, irep, 1)))/abs(real(zwn(ip, irep, 1), real64)))
1801 call mesh_minmaxloc(mesh, wmodmax, rankmax, mpi_maxloc)
1803 write(message(1),
'(a,i4,a,f11.6)')
'oct-wannier90: Wannier function ', iw,
' Max. Im/Re Ratio = ', wmodmax
1804 call messages_info(1)
1806 write(message(1),
'(a,i4)')
'oct-wannier90: Wannier function done ', iw
1807 call messages_info(1)
1811 safe_deallocate_a(umnk)
1812 safe_deallocate_a(zwn)
1813 safe_deallocate_a(psi)
1814 safe_deallocate_a(phase)
1815 safe_deallocate_a(phase_bloch)
1816 safe_deallocate_a(centers)
1817 safe_deallocate_a(supercell_centers)
double log(double __x) __attribute__((__nothrow__
double exp(double __x) __attribute__((__nothrow__
double sqrt(double __x) __attribute__((__nothrow__
double floor(double __x) __attribute__((__nothrow__
This module implements batches of mesh functions.
This module handles the calculation mode.
type(calc_mode_par_t), public calc_mode_par
Singleton instance of parallel calculation mode.
integer, parameter, public p_strategy_states
parallelization in states
subroutine, public zmesh_to_cube(mesh, mf, cube, cf)
Convert a function from the mesh to the cube.
subroutine, public zcube_function_free_rs(cube, cf)
Deallocates the real space grid.
subroutine, public zcube_function_alloc_rs(cube, cf, in_device, force_alloc)
Allocates locally the real space grid, if PFFT library is not used. Otherwise, it assigns the PFFT re...
subroutine, public cube_init(cube, nn, namespace, space, spacing, coord_system, fft_type, fft_library, dont_optimize, nn_out, mpi_grp, need_partition, tp_enlarge, blocksize)
subroutine, public cube_end(cube)
subroutine, public cube_init_cube_map(cube, mesh)
integer, parameter, public unpolarized
Parameters...
integer, parameter, public spinors
integer, parameter, public spin_polarized
Fast Fourier Transform module. This module provides a single interface that works with different FFT ...
subroutine, public fft_all_init(namespace)
initialize the table
subroutine, public fft_all_end()
delete all plans
real(real64), parameter, public m_two
subroutine, public global_end()
Finalise parser varinfo file, and MPI.
real(real64), parameter, public m_huge
real(real64), parameter, public m_zero
complex(real64), parameter, public m_z0
complex(real64), parameter, public m_zi
subroutine, public global_init(communicator)
Initialise Octopus.
real(real64), parameter, public m_half
real(real64), parameter, public m_one
This module implements the underlying real-space grid.
subroutine, public io_init(defaults)
If the argument defaults is present and set to true, then the routine will not try to read anything f...
subroutine, public io_close(iunit, grp)
subroutine, public io_end()
integer function, public io_open(file, namespace, action, status, form, position, die, recl, grp)
subroutine, public kpoints_to_absolute(latt, kin, kout)
System information (time, memory, sysname)
This module defines functions over batches of mesh functions.
subroutine, public zmesh_batch_mf_dotp(mesh, aa, psi, dot, reduce, nst)
calculate the dot products between a batch and a vector of mesh functions
This module defines various routines, operating on mesh functions.
This module defines the meshes, which are used in Octopus.
subroutine, public messages_end()
subroutine, public messages_not_implemented(feature, namespace)
subroutine, public messages_init(output_dir)
subroutine, public messages_warning(no_lines, all_nodes, namespace)
character(len=256), dimension(max_lines), public message
to be output by fatal, warning
subroutine, public messages_fatal(no_lines, only_root_writes, namespace)
subroutine, public messages_experimental(name, namespace)
subroutine, public messages_info(no_lines, iunit, debug_only, stress, all_nodes, namespace)
type(mpi_grp_t), public mpi_world
This module handles the communicators for the various parallelization strategies.
type(namespace_t), public global_namespace
subroutine, public orbitalset_init(this)
subroutine, public orbitalset_end(this)
subroutine, public orbitalset_update_phase(os, dim, kpt, kpoints, spin_polarized, vec_pot, vec_pot_var, kpt_max)
Build the phase correction to the global phase in case the orbital crosses the border of the simulato...
logical function, public parse_is_defined(namespace, name)
subroutine, public parser_init()
Initialise the Octopus parser.
subroutine, public parser_end()
End the Octopus parser.
subroutine, public profiling_end(namespace)
subroutine, public profiling_out(label)
Increment out counter and sum up difference between entry and exit time.
subroutine, public profiling_in(label, exclude)
Increment in counter and save entry time.
subroutine, public profiling_init(namespace)
Create profiling subdirectory.
integer, parameter, public restart_gs
integer, parameter, public restart_td
integer, parameter, public restart_type_load
subroutine, public zstates_elec_rrqr_decomposition(st, namespace, mesh, nst, root, ik, jpvt)
Perform RRQR on the transpose states stored in the states object and return the pivot vector.
This module defines routines to write information about states.
logical function, public state_kpt_is_local(st, ist, ik)
check whether a given state (ist, ik) is on the local node
subroutine, public states_elec_allocate_wfns(st, mesh, wfs_type, skip, packed)
Allocates the KS wavefunctions defined within a states_elec_t structure.
subroutine, public states_elec_look(restart, nik, dim, nst, ierr)
Reads the 'states' file in the restart directory, and finds out the nik, dim, and nst contained in it...
This module handles reading and writing restart information for the states_elec_t.
subroutine, public states_elec_load(restart, namespace, space, st, mesh, kpoints, ierr, iter, lr, lowest_missing, label, verbose, skip)
returns in ierr: <0 => Fatal error, or nothing read =0 => read all wavefunctions >0 => could only rea...
subroutine, public submesh_init(this, space, mesh, latt, center, rc)
type(type_t), public type_cmplx
brief This module defines the class unit_t which is used by the unit_systems_oct_m module.
This module defines the unit system, used for input and output.
type(unit_t), public unit_angstrom
For XYZ files.
subroutine, public unit_system_init(namespace)
type(unit_t), public unit_ev
For output energies in eV.
This module is intended to contain simple general-purpose utility functions and procedures.
subroutine, public ylm_wannier(ylm, l, mr, rr, xx, nr)
Class describing the electron system.
Describes mesh distribution to nodes.
The states_elec_t class contains all electronic wave functions.
batches of electronic states
subroutine create_wannier90_spn(mesh, st)
Write the spn file containing .
subroutine create_wannier90_eig()
subroutine read_wannier90_files()
subroutine write_unk(space, mesh, st, formatted)
subroutine create_wannier90_mmn(mesh, st)
subroutine wannier90_setup(ions, kpoints, space)
subroutine generate_wannier_states(space, mesh, ions, st, kpoints)
program wannier90_interface
subroutine create_wannier90_amn(space, mesh, latt, st, kpoints)
subroutine wannier90_output()