59#include "./base/base_uses.f90"
64 CHARACTER(len=*),
PARAMETER,
PRIVATE :: moduleN =
'qs_chargemol'
65 LOGICAL,
PARAMETER :: debug_this_module = .false.
67 INTEGER,
PARAMETER :: chargemol_lmax = 5
82 CHARACTER(LEN=*),
PARAMETER :: routinen =
'write_wfx'
84 CHARACTER(LEN=12),
DIMENSION(:),
POINTER :: bcgf_symbol
85 CHARACTER(len=2) :: asym
86 CHARACTER(len=20),
ALLOCATABLE,
DIMENSION(:) :: atom_symbols
87 CHARACTER(LEN=256) :: datx
88 CHARACTER(LEN=6),
DIMENSION(:),
POINTER :: bsgf_symbol
89 CHARACTER(len=default_string_length) :: filename
90 INTEGER :: handle, i, iatom, icgf, ico, ikind, iloop, imo, ipgf, irow, iset, isgf, ishell, &
91 ispin, iwfx, lshell, max_l, ncgf, ncol_global, nelec_alpha, nelec_beta, nkpoint, noccup, &
92 nrow_global, nset, nsgf, nspins, num_atoms, output_unit, roks_high, roks_low, tot_npgf
93 INTEGER,
ALLOCATABLE,
DIMENSION(:) :: atom_of_kind, atomic_numbers, kind_of
94 INTEGER,
DIMENSION(:),
POINTER :: lmax, npgf, nshell
95 INTEGER,
DIMENSION(:, :),
POINTER :: l
96 LOGICAL :: do_kpoints, newl, periodic, unrestricted
98 REAL(kind=
dp),
ALLOCATABLE,
DIMENSION(:, :) :: atoms_cart, cmatrix, smatrix
99 REAL(kind=
dp),
DIMENSION(:),
POINTER :: core_charges
100 REAL(kind=
dp),
DIMENSION(:, :),
POINTER :: zet
101 REAL(kind=
dp),
DIMENSION(:, :, :),
POINTER :: gcc
113 TYPE(
qs_kind_type),
DIMENSION(:),
POINTER :: qs_kind_set
121 CALL timeset(routinen, handle)
126 IF (output_unit > 0)
THEN
127 WRITE (output_unit,
'(/,T2,A)') &
128 '!-----------------------------------------------------------------------------!'
129 WRITE (output_unit,
'(T32,A)')
"Writing Chargemol wfx file..."
130 WRITE (output_unit,
'(T2,A)') &
131 '!-----------------------------------------------------------------------------!'
135 cpassert(
ASSOCIATED(qs_env))
136 CALL get_qs_env(qs_env, cell=cell, mos=mos, particle_set=particle_set, &
137 qs_kind_set=qs_kind_set, scf_env=scf_env, scf_control=scf_control, &
138 dft_control=dft_control, energy=energy, force=force, subsys=subsys, &
139 atomic_kind_set=atomic_kind_set, do_kpoints=do_kpoints, &
140 kpoints=kpoint_env, matrix_s=matrix_s)
142 nkpoint = kpoint_env%nkp
144 IF (scf_control%use_ot)
THEN
145 cpabort(
"OT is incompatible with .wfx output. Switch off OT.")
148 IF (dft_control%roks)
THEN
149 CALL cp_abort(__location__,
"The output of chargemol .wfx files is currently "// &
150 "implemented only for (un)restricted HF and Kohn-Sham-like methods.")
153 IF (dft_control%lsd)
THEN
154 unrestricted = .true.
156 unrestricted = .false.
168 extension=
".wfx", my_local=.false.)
170 CALL open_file(filename, file_status=
"UNKNOWN", &
171 file_action=
"WRITE", &
179 IF (nspins == 1)
THEN
180 nelec_alpha = mos(1)%nelectron/2
181 nelec_beta = nelec_alpha
183 nelec_alpha = mos(1)%nelectron
184 nelec_beta = mos(2)%nelectron
187 IF (dft_control%roks)
THEN
188 IF (mos(1)%homo > mos(2)%homo)
THEN
200 num_atoms =
SIZE(particle_set)
201 ALLOCATE (atoms_cart(3, num_atoms))
202 ALLOCATE (atom_symbols(num_atoms))
203 ALLOCATE (atomic_numbers(num_atoms))
204 ALLOCATE (core_charges(num_atoms))
207 DO iatom = 1, num_atoms
208 NULLIFY (orb_basis_set)
209 atoms_cart(1:3, iatom) = particle_set(iatom)%r(1:3)
211 element_symbol=asym, kind_number=ikind)
212 atom_symbols(iatom) = asym
214 CALL get_qs_kind(qs_kind_set(ikind), basis_set=orb_basis_set, &
215 core_charge=core_charges(iatom))
216 IF (
ASSOCIATED(orb_basis_set))
THEN
218 nset=nset, lmax=lmax)
221 max_l = max(max_l, lmax(iset))
224 cpabort(
"Unknown basis set type. ")
226 IF (max_l > chargemol_lmax)
THEN
227 CALL cp_abort(__location__,
"Chargemol supports basis sets with l"// &
228 " up to 5 only (h angular functions).")
235 WRITE (iwfx,
"(A)")
"# Chargemol input file generated by CP2K "
237 WRITE (iwfx,
"(A,/)")
"# Creation date "//trim(datx)
239 WRITE (iwfx,
"(A)")
"<Title>"
240 WRITE (iwfx, *) trim(logger%iter_info%project_name)
241 WRITE (iwfx,
"(A,/)")
"</Title>"
247 WRITE (iwfx,
"(A)")
"<Keywords>"
248 WRITE (iwfx,
"(A)")
"GTO"
249 WRITE (iwfx,
"(A,/)")
"</Keywords>"
254 WRITE (iwfx,
"(A)")
"#<Model>"
255 IF (unrestricted)
THEN
256 WRITE (iwfx,
"(A)")
"#Unrestricted Kohn-Sham"
258 WRITE (iwfx,
"(A)")
"#Restricted Kohn-Sham"
260 WRITE (iwfx,
"(A,/)")
"#</Model>"
265 WRITE (iwfx,
"(A)")
"<Number of Nuclei>"
266 WRITE (iwfx,
"(I6)") num_atoms
267 WRITE (iwfx,
"(A,/)")
"</Number of Nuclei>"
272 WRITE (iwfx,
"(A)")
"<Number of Occupied Molecular Orbitals>"
274 IF (dft_control%roks .AND. nspins == 2)
THEN
275 noccup = max(mos(1)%homo, mos(2)%homo)
277 DO ispin = 1, dft_control%nspins
278 noccup = noccup + mos(ispin)%homo
281 WRITE (iwfx,
"(2I6)") noccup
282 WRITE (iwfx,
"(A,/)")
"</Number of Occupied Molecular Orbitals>"
287 WRITE (iwfx,
"(A)")
"<Number of Perturbations>"
288 WRITE (iwfx,
"(I6)") 0
289 WRITE (iwfx,
"(A,/)")
"</Number of Perturbations>"
294 WRITE (iwfx,
"(A)")
"<Net Charge>"
295 WRITE (iwfx,
"(F8.4)") real(dft_control%charge, kind=
dp)
296 WRITE (iwfx,
"(A,/)")
"</Net Charge>"
301 WRITE (iwfx,
"(A)")
"<Number of Electrons>"
302 WRITE (iwfx,
"(I6)") scf_env%nelectron
303 WRITE (iwfx,
"(A,/)")
"</Number of Electrons>"
308 WRITE (iwfx,
"(A)")
"<Number of Alpha Electrons>"
309 WRITE (iwfx,
"(I6)") nelec_alpha
310 WRITE (iwfx,
"(A,/)")
"</Number of Alpha Electrons>"
315 WRITE (iwfx,
"(A)")
"<Number of Beta Electrons>"
316 WRITE (iwfx,
"(I6)") nelec_beta
317 WRITE (iwfx,
"(A,/)")
"</Number of Beta Electrons>"
322 WRITE (iwfx,
"(A)")
"<Electron Spin Multiplicity>"
323 WRITE (iwfx,
"(I4)") dft_control%multiplicity
324 WRITE (iwfx,
"(A,/)")
"</Electron Spin Multiplicity>"
329 WRITE (iwfx,
"(A)")
"<Number of Core Electrons>"
330 WRITE (iwfx,
"(F16.10)") sum(atomic_numbers) - sum(core_charges)
331 WRITE (iwfx,
"(A,/)")
"</Number of Core Electrons>"
336 WRITE (iwfx,
"(A)")
"<Nuclear Names>"
337 DO iatom = 1, num_atoms
338 WRITE (iwfx,
"(A4)") atom_symbols(iatom)
340 WRITE (iwfx,
"(A,/)")
"</Nuclear Names>"
345 WRITE (iwfx,
"(A)")
"<Atomic Numbers>"
346 DO iatom = 1, num_atoms
347 WRITE (iwfx,
"(I4)") atomic_numbers(iatom)
349 WRITE (iwfx,
"(A,/)")
"</Atomic Numbers>"
354 WRITE (iwfx,
"(A)")
"<Nuclear Charges>"
355 DO iatom = 1, num_atoms
356 WRITE (iwfx,
"(F12.8)") core_charges(iatom)
358 WRITE (iwfx,
"(A,/)")
"</Nuclear Charges>"
363 WRITE (iwfx,
"(A)")
"<Nuclear Cartesian Coordinates>"
364 DO iatom = 1, num_atoms
365 WRITE (iwfx,
"(3ES26.16E3)") atoms_cart(1:3, iatom)
367 WRITE (iwfx,
"(A,/)")
"</Nuclear Cartesian Coordinates>"
374 IF (sum(cell%perd) == 0)
THEN
375 CALL cp_warn(__location__,
"Writing of periodic cell information"// &
376 " requested in input, but system is not periodic, ignoring request.")
378 WRITE (iwfx,
"(A)")
"<Number of Translation Vectors>"
379 WRITE (iwfx,
"(I3)") sum(cell%perd)
380 WRITE (iwfx,
"(A,/)")
"</Number of Translation Vectors>"
382 WRITE (iwfx,
"(A)")
"<Translation Vectors>"
384 IF (cell%perd(iatom) == 1)
THEN
385 WRITE (iwfx,
"(3F12.6)") cell%hmat(1:3, iatom)
388 WRITE (iwfx,
"(A,/)")
"</Translation Vectors>"
390 WRITE (iwfx,
"(A)")
"<Number of Kpoints>"
391 WRITE (iwfx,
"(I3)") 1
392 WRITE (iwfx,
"(A,/)")
"</Number of Kpoints>"
393 WRITE (iwfx,
"(A)")
"<Kpoint Weights>"
394 WRITE (iwfx,
"(I3)") 1
395 WRITE (iwfx,
"(A,/)")
"</Kpoint Weights>"
396 WRITE (iwfx,
"(A)")
"<Kpoint Fractional Coordinates>"
397 WRITE (iwfx,
"(F8.6)") 0.0
398 WRITE (iwfx,
"(A,/)")
"</Kpoint Fractional Coordinates>"
404 WRITE (iwfx,
"(A)")
"<Primitive Centers>"
406 DO iatom = 1, num_atoms
408 NULLIFY (orb_basis_set)
409 CALL get_atomic_kind(particle_set(iatom)%atomic_kind, kind_number=ikind)
410 CALL get_qs_kind(qs_kind_set(ikind), basis_set=orb_basis_set)
411 IF (
ASSOCIATED(orb_basis_set))
THEN
420 DO ishell = 1, nshell(iset)
421 lshell = l(ishell, iset)
422 DO ico = 1,
nco(lshell)
423 DO ipgf = 1, npgf(iset)
424 tot_npgf = tot_npgf + 1
425 IF (mod(iloop + 10, 10) /= 0)
THEN
426 WRITE (iwfx,
"(I4)", advance=
"no") iatom
429 WRITE (iwfx,
"(I4)") iatom
442 cpabort(
"Unknown basis set type. ")
445 WRITE (iwfx,
"(A,/)")
"</Primitive Centers>"
450 WRITE (iwfx,
"(A)")
"<Number of Primitives>"
451 WRITE (iwfx,
"(I8)") tot_npgf
452 WRITE (iwfx,
"(A,/)")
"</Number of Primitives>"
457 WRITE (iwfx,
"(A)")
"<Primitive Types>"
458 DO iatom = 1, num_atoms
460 NULLIFY (orb_basis_set)
461 NULLIFY (bcgf_symbol)
464 CALL get_atomic_kind(particle_set(iatom)%atomic_kind, kind_number=ikind)
465 CALL get_qs_kind(qs_kind_set(ikind), basis_set=orb_basis_set)
466 IF (
ASSOCIATED(orb_basis_set))
THEN
480 DO ishell = 1, nshell(iset)
481 lshell = l(ishell, iset)
482 DO ico = 1,
nco(lshell)
483 DO ipgf = 1, orb_basis_set%npgf(iset)
484 IF (mod(iloop + 10, 10) /= 0)
THEN
485 WRITE (iwfx,
'(I6)', advance=
"no") &
486 pgf_type_chargemol(bcgf_symbol(icgf) (3:))
489 WRITE (iwfx,
'(I6)') &
490 pgf_type_chargemol(bcgf_symbol(icgf) (3:))
502 cpabort(
"Unknown basis set type.")
508 WRITE (iwfx,
"(A,/)")
"</Primitive Types>"
517 WRITE (iwfx,
"(A)")
"<Primitive Exponents>"
518 DO iatom = 1, num_atoms
519 NULLIFY (orb_basis_set)
524 CALL get_atomic_kind(particle_set(iatom)%atomic_kind, kind_number=ikind)
525 CALL get_qs_kind(qs_kind_set(ikind), basis_set=orb_basis_set)
526 IF (
ASSOCIATED(orb_basis_set))
THEN
536 DO ishell = 1, nshell(iset)
537 lshell = l(ishell, iset)
538 DO ico = 1,
nco(lshell)
539 DO ipgf = 1, npgf(iset)
540 IF (mod(iloop + 5, 5) /= 0)
THEN
541 WRITE (iwfx,
"(ES20.10)", advance=
"no") zet(ipgf, iset)
544 WRITE (iwfx,
"(ES20.10)") zet(ipgf, iset)
557 cpabort(
"Unknown basis set type. ")
560 WRITE (iwfx,
"(A,/)")
"</Primitive Exponents>"
566 WRITE (iwfx,
"(A)")
"<Molecular Orbital Occupation Numbers>"
567 IF (.NOT. dft_control%roks)
THEN
569 DO imo = 1, mos(ispin)%homo
570 WRITE (iwfx,
"(f8.6)") &
571 mos(ispin)%occupation_numbers(imo)
575 DO imo = 1, mos(roks_low)%homo
576 WRITE (iwfx,
"(*(f8.6,1x))") &
577 mos(roks_low)%occupation_numbers(imo) &
578 + mos(roks_low)%occupation_numbers(imo)
580 DO imo = mos(roks_low)%homo + 1, mos(roks_high)%homo
581 WRITE (iwfx,
"(f8.6)") &
582 mos(roks_high)%occupation_numbers(imo)
585 WRITE (iwfx,
"(A,/)")
"</Molecular Orbital Occupation Numbers>"
590 WRITE (iwfx,
"(A)")
"<Molecular Orbital Energies>"
592 DO imo = 1, mos(ispin)%homo
593 WRITE (iwfx,
"(ES20.10)") mos(ispin)%eigenvalues(imo)
596 WRITE (iwfx,
"(A,/)")
"</Molecular Orbital Energies>"
602 WRITE (iwfx,
"(A)")
"<Molecular Orbital Spin Types>"
603 DO imo = 1, mos(1)%homo
604 IF (nspins == 1)
THEN
605 WRITE (iwfx,
'(A15)')
"Alpha and Beta"
606 ELSEIF (dft_control%uks)
THEN
607 WRITE (iwfx,
'(A6)')
"Alpha"
609 CALL cp_abort(__location__,
"This wavefunction type is currently"// &
610 " not supported by the chargemol interface.")
613 IF (nspins == 2)
THEN
614 DO imo = 1, mos(2)%homo
615 WRITE (iwfx,
'(A5)')
"Beta"
618 WRITE (iwfx,
"(A,/)")
"</Molecular Orbital Spin Types>"
624 WRITE (iwfx,
"(A)")
"<Kpoint Index for Orbitals>"
626 DO imo = 1, mos(ispin)%homo
627 WRITE (iwfx,
"(I6)") 1
630 WRITE (iwfx,
"(A,/)")
"</Kpoint Index for Orbitals>"
636 WRITE (iwfx,
"(A)")
"<Molecular Orbital Primitive Coefficients>"
637 NULLIFY (orb_basis_set)
640 IF (mos(1)%use_mo_coeff_b)
THEN
641 DO ispin = 1,
SIZE(mos)
642 IF (.NOT.
ASSOCIATED(mos(ispin)%mo_coeff_b))
THEN
652 nrow_global=nrow_global, &
653 ncol_global=ncol_global)
655 ALLOCATE (smatrix(nrow_global, ncol_global))
662 ALLOCATE (cmatrix(ncgf, ncol_global))
669 DO iatom = 1, num_atoms
670 NULLIFY (orb_basis_set)
671 CALL get_atomic_kind(particle_set(iatom)%atomic_kind, kind_number=ikind)
673 basis_set=orb_basis_set)
674 IF (
ASSOCIATED(orb_basis_set))
THEN
680 DO ishell = 1, nshell(iset)
681 lshell = l(ishell, iset)
682 CALL dgemm(
"T",
"N",
nco(lshell), mos(ispin)%nmo, &
683 nso(lshell), 1.0_dp, &
685 smatrix(isgf, 1), nsgf, 0.0_dp, &
686 cmatrix(icgf, 1), ncgf)
698 icgf = icgf +
nco(lshell)
699 isgf = isgf +
nso(lshell)
703 cpabort(
"Unknown basis set type. ")
708 DO imo = 1, mos(ispin)%homo
710 WRITE (iwfx,
"(A)")
"<MO Number>"
711 IF (nspins == 1 .OR. ispin == 1)
THEN
712 WRITE (iwfx,
"(I6)") imo
714 WRITE (iwfx,
"(I6)") imo + mos(1)%homo
716 WRITE (iwfx,
"(A)")
"</MO Number>"
720 DO iatom = 1, num_atoms
722 NULLIFY (orb_basis_set)
726 basis_set=orb_basis_set)
727 IF (
ASSOCIATED(orb_basis_set))
THEN
736 DO ishell = 1, nshell(iset)
737 lshell = orb_basis_set%l(ishell, iset)
739 DO ico = orb_basis_set%first_cgf(ishell, iset), &
740 orb_basis_set%last_cgf(ishell, iset)
743 DO ipgf = 1, orb_basis_set%npgf(iset)
745 zeta = orb_basis_set%zet(ipgf, iset)
747 IF (mod(iloop + 5, 5) /= 0)
THEN
748 WRITE (iwfx,
'(ES20.10)', advance=
"no") &
749 cmatrix(irow, imo)* &
750 orb_basis_set%norm_cgf(ico)* &
751 orb_basis_set%gcc(ipgf, ishell, iset)
754 WRITE (iwfx,
'(ES20.10)') &
755 cmatrix(irow, imo)* &
756 orb_basis_set%norm_cgf(ico)* &
757 orb_basis_set%gcc(ipgf, ishell, iset)
768 cpabort(
"Unknown basis set type.")
777 IF (
ALLOCATED(cmatrix))
DEALLOCATE (cmatrix)
778 IF (
ALLOCATED(smatrix))
DEALLOCATE (smatrix)
781 WRITE (iwfx,
"(A,/)")
"</Molecular Orbital Primitive Coefficients>"
786 WRITE (iwfx,
"(A)")
"<Energy>"
787 WRITE (iwfx,
"(ES26.16E3)") energy%total
788 WRITE (iwfx,
"(A,/)")
"</Energy>"
793 WRITE (iwfx,
"(A)")
"<Virial Ratio (-V/T)>"
794 WRITE (iwfx,
"(ES20.12)") - 1*(energy%total - energy%kinetic)/energy%kinetic
795 WRITE (iwfx,
"(A,/)")
"</Virial Ratio (-V/T)>"
801 IF (
ASSOCIATED(force) .AND. debug_this_module)
THEN
802 WRITE (iwfx,
"(A)")
"<Nuclear Cartesian Energy Gradients>"
804 CALL get_qs_env(qs_env, force=force, atomic_kind_set=atomic_kind_set)
805 ALLOCATE (atom_of_kind(num_atoms))
806 ALLOCATE (kind_of(num_atoms))
808 atom_of_kind=atom_of_kind, &
811 DO iatom = 1, num_atoms
812 ikind = kind_of(iatom)
813 i = atom_of_kind(iatom)
814 WRITE (iwfx,
"(3ES20.12E3)") force(ikind)%total(1:3, i)
817 WRITE (iwfx,
"(A,/)")
"<Nuclear Cartesian Energy Gradients>"
820 WRITE (iwfx,
"(A)")
"<Nuclear Virial of Energy-Gradient-Based Forces on Nuclei, W>"
821 WRITE (iwfx,
"(A)")
""
822 WRITE (iwfx,
"(A,/)")
"<Nuclear Virial of Energy-Gradient-Based Forces on Nuclei, W>"
825 WRITE (iwfx,
"(A)")
"<Full Virial Ratio, -(V - W)/T)>"
826 WRITE (iwfx,
"(A)")
""
827 WRITE (iwfx,
"(A,/)")
"</Full Virial Ratio, -(V - W)/T)>"
829 DEALLOCATE (atom_of_kind)
844 DEALLOCATE (atoms_cart)
845 DEALLOCATE (atom_symbols)
846 DEALLOCATE (atomic_numbers)
847 DEALLOCATE (core_charges)
853 IF (output_unit > 0)
THEN
854 WRITE (output_unit,
'(/,T2,A)') &
855 '!--------------------------- Chargemol wfx written ---------------------------!'
858 CALL timestop(handle)
867 INTEGER FUNCTION pgf_type_chargemol(l_symb)
RESULT(label)
869 CHARACTER(len=*),
INTENT(IN) :: l_symb
985 cpabort(
"The chargemol interface supports basis functions up to l=5 only")
989 END FUNCTION pgf_type_chargemol
static void dgemm(const char transa, const char transb, const int m, const int n, const int k, const double alpha, const double *a, const int lda, const double *b, const int ldb, const double beta, double *c, const int ldc)
Convenient wrapper to hide Fortran nature of dgemm_, swapping a and b.
Define the atomic kind types and their sub types.
subroutine, public get_atomic_kind_set(atomic_kind_set, atom_of_kind, kind_of, natom_of_kind, maxatom, natom, nshell, fist_potential_present, shell_present, shell_adiabatic, shell_check_distance, damping_present)
Get attributes of an atomic kind set.
subroutine, public get_atomic_kind(atomic_kind, fist_potential, element_symbol, name, mass, kind_number, natom, atom_list, rcov, rvdw, z, qeff, apol, cpol, mm_radius, shell, shell_active, damping)
Get attributes of an atomic kind.
subroutine, public get_gto_basis_set(gto_basis_set, name, aliases, norm_type, kind_radius, ncgf, nset, nsgf, cgf_symbol, sgf_symbol, norm_cgf, set_radius, lmax, lmin, lx, ly, lz, m, ncgf_set, npgf, nsgf_set, nshell, cphi, pgf_radius, sphi, scon, zet, first_cgf, first_sgf, l, last_cgf, last_sgf, n, gcc, maxco, maxl, maxpgf, maxsgf_set, maxshell, maxso, nco_sum, npgf_sum, nshell_sum, maxder, short_kind_radius, npgf_seg_sum)
...
Handles all functions related to the CELL.
subroutine, public get_cell(cell, alpha, beta, gamma, deth, orthorhombic, abc, periodic, h, h_inv, symmetry_id, tag)
Get informations about a simulation cell.
Defines control structures, which contain the parameters and the settings for the DFT-based calculati...
DBCSR operations in CP2K.
subroutine, public copy_dbcsr_to_fm(matrix, fm)
Copy a DBCSR matrix to a BLACS matrix.
Utility routines to open and close files. Tracking of preconnections.
subroutine, public open_file(file_name, file_status, file_form, file_action, file_position, file_pad, unit_number, debug, skip_get_unit_number, file_access)
Opens the requested file using a free unit number.
represent a full matrix distributed on many processors
subroutine, public cp_fm_get_info(matrix, name, nrow_global, ncol_global, nrow_block, ncol_block, nrow_local, ncol_local, row_indices, col_indices, local_data, context, nrow_locals, ncol_locals, matrix_struct, para_env)
returns all kind of information about the full matrix
subroutine, public cp_fm_get_submatrix(fm, target_m, start_row, start_col, n_rows, n_cols, transpose)
gets a submatrix of a full matrix op(target_m)(1:n_rows,1:n_cols) =fm(start_row:start_row+n_rows,...
various routines to log and control the output. The idea is that decisions about where to log should ...
integer function, public cp_logger_get_default_io_unit(logger)
returns the unit nr for the ionode (-1 on all other processors) skips as well checks if the procs cal...
type(cp_logger_type) function, pointer, public cp_get_default_logger()
returns the default logger
routines to handle the output, The idea is to remove the decision of wheter to output and what to out...
character(len=default_path_length) function, public cp_print_key_generate_filename(logger, print_key, middle_name, extension, my_local)
Utility function that returns a unit number to write the print key. Might open a file with a unique f...
Defines the basic variable types.
integer, parameter, public dp
integer, parameter, public default_string_length
Types and basic routines needed for a kpoint calculation.
Machine interface based on Fortran 2003 and POSIX.
subroutine, public m_datum(cal_date)
returns a datum in human readable format using a standard Fortran routine
Provides Cartesian and spherical orbital pointers and indices.
integer, dimension(:), allocatable, public nco
integer, dimension(:), allocatable, public nso
character(len=12) function, public cgf_symbol(n, lxyz)
Build a Cartesian orbital symbol (orbital labels for printing).
character(len=6) function, public sgf_symbol(n, l, m)
Build a spherical orbital symbol (orbital labels for printing).
Define the data structure for the particle information.
Periodic Table related data definitions.
subroutine, public get_ptable_info(symbol, number, amass, ielement, covalent_radius, metallic_radius, vdw_radius, found)
Pass information about the kind given the element symbol.
Write wfx file, works as interface to chargemol and multiwfn.
subroutine, public write_wfx(qs_env, dft_section)
...
subroutine, public get_qs_env(qs_env, atomic_kind_set, qs_kind_set, cell, super_cell, cell_ref, use_ref_cell, kpoints, dft_control, mos, sab_orb, sab_all, qmmm, qmmm_periodic, sac_ae, sac_ppl, sac_lri, sap_ppnl, sab_vdw, sab_scp, sap_oce, sab_lrc, sab_se, sab_xtbe, sab_tbe, sab_core, sab_xb, sab_xtb_pp, sab_xtb_nonbond, sab_almo, sab_kp, sab_kp_nosym, particle_set, energy, force, matrix_h, matrix_h_im, matrix_ks, matrix_ks_im, matrix_vxc, run_rtp, rtp, matrix_h_kp, matrix_h_im_kp, matrix_ks_kp, matrix_ks_im_kp, matrix_vxc_kp, kinetic_kp, matrix_s_kp, matrix_w_kp, matrix_s_ri_aux_kp, matrix_s, matrix_s_ri_aux, matrix_w, matrix_p_mp2, matrix_p_mp2_admm, rho, rho_xc, pw_env, ewald_env, ewald_pw, active_space, mpools, input, para_env, blacs_env, scf_control, rel_control, kinetic, qs_charges, vppl, rho_core, rho_nlcc, rho_nlcc_g, ks_env, ks_qmmm_env, wf_history, scf_env, local_particles, local_molecules, distribution_2d, dbcsr_dist, molecule_kind_set, molecule_set, subsys, cp_subsys, oce, local_rho_set, rho_atom_set, task_list, task_list_soft, rho0_atom_set, rho0_mpole, rhoz_set, ecoul_1c, rho0_s_rs, rho0_s_gs, do_kpoints, has_unit_metric, requires_mo_derivs, mo_derivs, mo_loc_history, nkind, natom, nelectron_total, nelectron_spin, efield, neighbor_list_id, linres_control, xas_env, virial, cp_ddapc_env, cp_ddapc_ewald, outer_scf_history, outer_scf_ihistory, x_data, et_coupling, dftb_potential, results, se_taper, se_store_int_env, se_nddo_mpole, se_nonbond_env, admm_env, lri_env, lri_density, exstate_env, ec_env, harris_env, dispersion_env, gcp_env, vee, rho_external, external_vxc, mask, mp2_env, bs_env, kg_env, wanniercentres, atprop, ls_scf_env, do_transport, transport_env, v_hartree_rspace, s_mstruct_changed, rho_changed, potential_changed, forces_up_to_date, mscfg_env, almo_scf_env, gradient_history, variable_history, embed_pot, spin_embed_pot, polar_env, mos_last_converged, eeq, rhs)
Get the QUICKSTEP environment.
Define the quickstep kind type and their sub types.
subroutine, public get_qs_kind(qs_kind, basis_set, basis_type, ncgf, nsgf, all_potential, tnadd_potential, gth_potential, sgp_potential, upf_potential, se_parameter, dftb_parameter, xtb_parameter, dftb3_param, zatom, zeff, elec_conf, mao, lmax_dftb, alpha_core_charge, ccore_charge, core_charge, core_charge_radius, paw_proj_set, paw_atom, hard_radius, hard0_radius, max_rad_local, covalent_radius, vdw_radius, gpw_type_forced, harmonics, max_iso_not0, max_s_harm, grid_atom, ngrid_ang, ngrid_rad, lmax_rho0, dft_plus_u_atom, l_of_dft_plus_u, n_of_dft_plus_u, u_minus_j, u_of_dft_plus_u, j_of_dft_plus_u, alpha_of_dft_plus_u, beta_of_dft_plus_u, j0_of_dft_plus_u, occupation_of_dft_plus_u, dispersion, bs_occupation, magnetization, no_optimize, addel, laddel, naddel, orbitals, max_scf, eps_scf, smear, u_ramping, u_minus_j_target, eps_u_ramping, init_u_ramping_each_scf, reltmat, ghost, floating, name, element_symbol, pao_basis_size, pao_model_file, pao_potentials, pao_descriptors, nelec)
Get attributes of an atomic kind.
subroutine, public get_qs_kind_set(qs_kind_set, all_potential_present, tnadd_potential_present, gth_potential_present, sgp_potential_present, paw_atom_present, dft_plus_u_atom_present, maxcgf, maxsgf, maxco, maxco_proj, maxgtops, maxlgto, maxlprj, maxnset, maxsgf_set, ncgf, npgf, nset, nsgf, nshell, maxpol, maxlppl, maxlppnl, maxppnl, nelectron, maxder, max_ngrid_rad, max_sph_harm, maxg_iso_not0, lmax_rho0, basis_rcut, basis_type, total_zeff_corr, npgf_seg)
Get attributes of an atomic kind set.
Definition and initialisation of the mo data type.
module that contains the definitions of the scf types
types that represent a quickstep subsys
parameters that control an scf iteration
Provides all information about an atomic kind.
Type defining parameters related to the simulation cell.
type of a logger, at the moment it contains just a print level starting at which level it should be l...
Contains information about kpoints.
Provides all information about a quickstep kind.