LCOV - code coverage report
Current view: top level - src - dm_ls_scf_types.F (source / functions) Hit Total Coverage
Test: CP2K Regtests (git:ccc2433) Lines: 30 31 96.8 %
Date: 2024-04-25 07:09:54 Functions: 1 10 10.0 %

          Line data    Source code
       1             : !--------------------------------------------------------------------------------------------------!
       2             : !   CP2K: A general program to perform molecular dynamics simulations                              !
       3             : !   Copyright 2000-2024 CP2K developers group <https://cp2k.org>                                   !
       4             : !                                                                                                  !
       5             : !   SPDX-License-Identifier: GPL-2.0-or-later                                                      !
       6             : !--------------------------------------------------------------------------------------------------!
       7             : 
       8             : ! **************************************************************************************************
       9             : !> \brief Types needed for a linear scaling quickstep SCF run based on the density
      10             : !>        matrix
      11             : !> \par History
      12             : !>       2010.10 created [Joost VandeVondele]
      13             : !> \author Joost VandeVondele
      14             : ! **************************************************************************************************
      15             : MODULE dm_ls_scf_types
      16             :    USE dbcsr_api,                       ONLY: dbcsr_release,&
      17             :                                               dbcsr_type
      18             :    USE input_constants,                 ONLY: ls_cluster_atomic,&
      19             :                                               ls_cluster_molecular
      20             :    USE input_section_types,             ONLY: section_vals_release,&
      21             :                                               section_vals_type
      22             :    USE kinds,                           ONLY: dp
      23             :    USE message_passing,                 ONLY: mp_para_env_release,&
      24             :                                               mp_para_env_type
      25             :    USE pao_types,                       ONLY: pao_env_type,&
      26             :                                               pao_finalize
      27             :    USE pexsi_types,                     ONLY: lib_pexsi_env,&
      28             :                                               lib_pexsi_finalize
      29             :    USE qs_density_mixing_types,         ONLY: mixing_storage_release,&
      30             :                                               mixing_storage_type
      31             : #include "./base/base_uses.f90"
      32             : 
      33             :    IMPLICIT NONE
      34             : 
      35             :    PRIVATE
      36             : 
      37             :    CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'dm_ls_scf_types'
      38             : 
      39             :    PUBLIC :: ls_scf_env_type, ls_mstruct_type, ls_cluster_atomic, ls_cluster_molecular, &
      40             :              ls_scf_curvy_type
      41             : 
      42             :    TYPE ls_mstruct_type
      43             :       INTEGER :: cluster_type = -1
      44             :       LOGICAL :: do_pao = .FALSE.
      45             :       INTEGER, DIMENSION(:), ALLOCATABLE :: atom_to_molecule
      46             :       TYPE(dbcsr_type)                :: matrix_A
      47             :       TYPE(dbcsr_type)                :: matrix_B
      48             :    END TYPE
      49             : 
      50             :    TYPE ls_mat_history_type
      51             :       INTEGER :: istore = 0, nstore = 0
      52             :       TYPE(dbcsr_type), DIMENSION(:, :), ALLOCATABLE :: matrix
      53             :    END TYPE
      54             : 
      55             :    TYPE ls_scf_curvy_type
      56             :       TYPE(dbcsr_type), DIMENSION(:), ALLOCATABLE :: matrix_dp
      57             :       TYPE(dbcsr_type), DIMENSION(:), ALLOCATABLE :: matrix_p
      58             :       TYPE(dbcsr_type), DIMENSION(:, :), ALLOCATABLE :: matrix_psave
      59             :       TYPE(dbcsr_type), DIMENSION(:, :), ALLOCATABLE :: matrix_BCH
      60             :       REAL(KIND=dp), DIMENSION(2)                      :: step_size = 0.0_dp
      61             :       REAL(KIND=dp), DIMENSION(2)                      :: shift = 0.0_dp
      62             :       REAL(KIND=dp), DIMENSION(2)                      :: cg_denom = 0.0_dp
      63             :       REAL(KIND=dp), DIMENSION(2)                      :: cg_numer = 0.0_dp
      64             :       REAL(KIND=dp), DIMENSION(6)                      :: energies = 0.0_dp
      65             :       INTEGER                                          :: line_search_step = 0
      66             :       INTEGER, DIMENSION(2)                            :: BCH_saved = 0
      67             :       LOGICAL                                          :: double_step_size = .FALSE.
      68             :       LOGICAL, DIMENSION(2)                            :: fix_shift = .FALSE.
      69             : 
      70             :       INTEGER                                          :: line_search_type = 0
      71             :       INTEGER                                          :: n_bch_hist = 0
      72             :       REAL(KIND=dp)                                    :: scale_filter = 0.0_dp
      73             :       REAL(KIND=dp)                                    :: filter_factor = 0.0_dp
      74             :       REAL(KIND=dp)                                    :: min_shift = 0.0_dp
      75             :       REAL(KIND=dp)                                    :: min_filter = 0.0_dp
      76             :    END TYPE
      77             : 
      78             :    TYPE chebyshev_type
      79             :       LOGICAL :: compute_chebyshev = .FALSE.
      80             :       INTEGER :: n_chebyshev = 0
      81             :       INTEGER :: n_gridpoint_dos = 0
      82             :       REAL(KIND=dp), DIMENSION(:), POINTER :: min_energy => NULL()
      83             :       REAL(KIND=dp), DIMENSION(:), POINTER :: max_energy => NULL()
      84             :       TYPE(section_vals_type), POINTER :: print_key_dos => NULL()
      85             :       TYPE(section_vals_type), POINTER :: print_key_cube => NULL()
      86             :    END TYPE
      87             : 
      88             :    TYPE ls_scf_env_type
      89             :       INTEGER               :: nspins = 0, natoms = 0
      90             :       INTEGER               :: nelectron_total = 0
      91             :       INTEGER, DIMENSION(2) :: nelectron_spin = 0
      92             :       REAL(KIND=dp), DIMENSION(2) ::  mu_spin = 0.0_dp
      93             :       REAL(KIND=dp), DIMENSION(2) ::  homo_spin = 0.0_dp
      94             :       REAL(KIND=dp), DIMENSION(2) ::  lumo_spin = 0.0_dp
      95             : 
      96             :       ! This prevents a bug in GCC up to version 9.x (9.5 seems to work though)
      97             :       TYPE(ls_mat_history_type) :: scf_history = ls_mat_history_type(matrix=null())
      98             :       INTEGER :: extrapolation_order = -1
      99             : 
     100             :       LOGICAL :: has_unit_metric = .FALSE.
     101             : 
     102             :       LOGICAL :: curvy_steps = .FALSE.
     103             :       INTEGER :: s_preconditioner_type = 0
     104             :       INTEGER :: s_inversion_type = 0
     105             :       INTEGER :: purification_method = 0
     106             :       INTEGER :: sign_method = 0
     107             :       INTEGER :: sign_order = 0
     108             :       LOGICAL :: sign_symmetric = .FALSE.
     109             :       INTEGER :: submatrix_sign_method = -1
     110             :       INTEGER :: s_sqrt_method = 0
     111             :       INTEGER :: s_sqrt_order = 0
     112             : 
     113             :       LOGICAL               :: needs_s_inv = .FALSE., has_s_preconditioner = .FALSE., fixed_mu = .FALSE., &
     114             :                                dynamic_threshold = .FALSE., check_s_inv = .FALSE.
     115             :       LOGICAL               :: restart_read = .FALSE., restart_write = .FALSE., non_monotonic = .FALSE.
     116             :       REAL(KIND=dp)         :: eps_filter = 0.0_dp, eps_scf = 0.0_dp
     117             : 
     118             :       REAL(KIND=dp)         :: eps_lanczos = 0.0_dp
     119             :       INTEGER               :: max_iter_lanczos = 0
     120             : 
     121             :       REAL(KIND=dp)         :: mixing_fraction = 0.0_dp
     122             :       INTEGER               :: max_scf = 0
     123             :       LOGICAL               :: ls_diis = .FALSE.
     124             :       INTEGER               :: iter_ini_diis = 0
     125             :       INTEGER               :: nmixing = 0, max_diis = 0
     126             :       REAL(KIND=dp)         :: eps_diis = 0.0_dp
     127             :       REAL(KIND=dp)         :: energy_init = 0.0_dp
     128             : 
     129             :       TYPE(dbcsr_type)   :: matrix_s_inv
     130             :       TYPE(dbcsr_type)   :: matrix_s
     131             :       TYPE(dbcsr_type)   :: matrix_bs_sqrt, matrix_bs_sqrt_inv
     132             :       TYPE(dbcsr_type)   :: matrix_s_sqrt, matrix_s_sqrt_inv
     133             :       TYPE(dbcsr_type), DIMENSION(:), ALLOCATABLE :: matrix_ks
     134             :       TYPE(dbcsr_type), DIMENSION(:), ALLOCATABLE :: matrix_p
     135             : 
     136             :       LOGICAL  :: report_all_sparsities = .FALSE., perform_mu_scan = .FALSE., use_s_sqrt = .FALSE.
     137             : 
     138             :       TYPE(ls_mstruct_type) :: ls_mstruct
     139             :       TYPE(ls_scf_curvy_type) :: curvy_data = ls_scf_curvy_type(matrix_dp=null(), matrix_p=null(), &
     140             :                                                                 matrix_psave=null(), matrix_bch=null())
     141             : 
     142             :       TYPE(chebyshev_type) :: chebyshev = chebyshev_type()
     143             : 
     144             :       LOGICAL :: do_rho_mixing = .FALSE.
     145             :       INTEGER :: density_mixing_method = 0
     146             :       TYPE(mixing_storage_type), POINTER :: mixing_store => NULL()
     147             : 
     148             :       LOGICAL :: do_transport = .FALSE.
     149             :       LOGICAL :: do_pexsi = .FALSE.
     150             : 
     151             :       LOGICAL :: calculate_forces = .FALSE.
     152             : 
     153             :       TYPE(lib_pexsi_env) :: pexsi
     154             : 
     155             :       TYPE(mp_para_env_type), POINTER :: para_env => NULL()
     156             :       LOGICAL                 :: do_pao = .FALSE.
     157             :       TYPE(pao_env_type)      :: pao_env
     158             :    END TYPE ls_scf_env_type
     159             : 
     160             :    PUBLIC :: ls_scf_release
     161             : 
     162             : CONTAINS
     163             : 
     164             : ! **************************************************************************************************
     165             : !> \brief release the LS type.
     166             : !> \param ls_scf_env ...
     167             : !> \par History
     168             : !>       2012.11 created [Joost VandeVondele]
     169             : !> \author Joost VandeVondele
     170             : ! **************************************************************************************************
     171         358 :    SUBROUTINE ls_scf_release(ls_scf_env)
     172             :       TYPE(ls_scf_env_type), POINTER                     :: ls_scf_env
     173             : 
     174             :       CHARACTER(len=*), PARAMETER                        :: routineN = 'ls_scf_release'
     175             : 
     176             :       INTEGER                                            :: handle, ispin, istore
     177             : 
     178         358 :       CALL timeset(routineN, handle)
     179             : 
     180         358 :       CALL mp_para_env_release(ls_scf_env%para_env)
     181             : 
     182         358 :       DEALLOCATE (ls_scf_env%ls_mstruct%atom_to_molecule)
     183             : 
     184             :       ! set up the buffer for the history of matrices
     185         758 :       DO istore = 1, MIN(ls_scf_env%scf_history%istore, ls_scf_env%scf_history%nstore)
     186        1178 :          DO ispin = 1, SIZE(ls_scf_env%scf_history%matrix, 1)
     187         820 :             CALL dbcsr_release(ls_scf_env%scf_history%matrix(ispin, istore))
     188             :          END DO
     189             :       END DO
     190         358 :       DEALLOCATE (ls_scf_env%scf_history%matrix)
     191             : 
     192         358 :       IF (ALLOCATED(ls_scf_env%matrix_p)) THEN
     193         726 :          DO ispin = 1, SIZE(ls_scf_env%matrix_p)
     194         726 :             CALL dbcsr_release(ls_scf_env%matrix_p(ispin))
     195             :          END DO
     196         356 :          DEALLOCATE (ls_scf_env%matrix_p)
     197             :       END IF
     198             : 
     199         358 :       IF (ASSOCIATED(ls_scf_env%chebyshev%print_key_dos)) &
     200           6 :          CALL section_vals_release(ls_scf_env%chebyshev%print_key_dos)
     201         358 :       IF (ASSOCIATED(ls_scf_env%chebyshev%print_key_cube)) &
     202           6 :          CALL section_vals_release(ls_scf_env%chebyshev%print_key_cube)
     203         358 :       IF (ASSOCIATED(ls_scf_env%chebyshev%min_energy)) THEN
     204           2 :          DEALLOCATE (ls_scf_env%chebyshev%min_energy)
     205             :       END IF
     206         358 :       IF (ASSOCIATED(ls_scf_env%chebyshev%max_energy)) THEN
     207           2 :          DEALLOCATE (ls_scf_env%chebyshev%max_energy)
     208             :       END IF
     209             : 
     210         358 :       IF (ASSOCIATED(ls_scf_env%mixing_store)) THEN
     211         336 :          CALL mixing_storage_release(ls_scf_env%mixing_store)
     212         336 :          DEALLOCATE (ls_scf_env%mixing_store)
     213             :       END IF
     214             : 
     215         358 :       IF (ls_scf_env%do_pexsi) THEN
     216           8 :          CALL lib_pexsi_finalize(ls_scf_env%pexsi)
     217             :       END IF
     218             : 
     219         358 :       IF (ls_scf_env%do_pao) &
     220          94 :          CALL pao_finalize(ls_scf_env%pao_env)
     221             : 
     222         358 :       DEALLOCATE (ls_scf_env)
     223             : 
     224         358 :       CALL timestop(handle)
     225             : 
     226         358 :    END SUBROUTINE ls_scf_release
     227             : 
     228           0 : END MODULE dm_ls_scf_types

Generated by: LCOV version 1.15