LCOV - code coverage report
Current view: top level - src - qs_diis_types.F (source / functions) Hit Total Coverage
Test: CP2K Regtests (git:9843133) Lines: 42 43 97.7 %
Date: 2024-05-10 06:53:45 Functions: 3 9 33.3 %

          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 buffer for the diis of the scf
      10             : !> \par History
      11             : !>      02.2003 rewamped [fawzi]
      12             : !> \author Matthias Krack
      13             : ! **************************************************************************************************
      14             : MODULE qs_diis_types
      15             :    USE cp_cfm_types,                    ONLY: cp_cfm_release,&
      16             :                                               cp_cfm_type
      17             :    USE cp_fm_types,                     ONLY: cp_fm_release,&
      18             :                                               cp_fm_type
      19             :    USE dbcsr_api,                       ONLY: dbcsr_p_type,&
      20             :                                               dbcsr_release
      21             :    USE kinds,                           ONLY: dp
      22             : #include "./base/base_uses.f90"
      23             : 
      24             :    IMPLICIT NONE
      25             :    PRIVATE
      26             : 
      27             :    LOGICAL, PRIVATE, PARAMETER :: debug_this_module = .TRUE.
      28             :    CHARACTER(len=*), PARAMETER, PRIVATE :: moduleN = 'qs_diis_types'
      29             : 
      30             :    PUBLIC :: qs_diis_buffer_type
      31             :    PUBLIC :: qs_diis_b_release
      32             :    PUBLIC :: qs_diis_buffer_type_sparse, &
      33             :              qs_diis_b_release_sparse, &
      34             :              qs_diis_buffer_type_kp, &
      35             :              qs_diis_b_release_kp
      36             : 
      37             : ! **************************************************************************************************
      38             : !> \brief keeps a buffer with the previous values of s,p,k
      39             : !> \par History
      40             : !>      02.2003 rewamped [fawzi]
      41             : !> \author Matthias Krack
      42             : ! **************************************************************************************************
      43             :    TYPE qs_diis_buffer_type
      44             :       INTEGER                                          :: nbuffer = -1
      45             :       INTEGER                                          :: ncall = -1
      46             :       TYPE(cp_fm_type), DIMENSION(:, :), POINTER       :: error => NULL()
      47             :       TYPE(cp_fm_type), DIMENSION(:, :), POINTER       :: param => NULL()
      48             :       REAL(KIND=dp), DIMENSION(:, :), POINTER          :: b_matrix => NULL()
      49             :    END TYPE qs_diis_buffer_type
      50             : 
      51             : ! **************************************************************************************************
      52             : !> \brief build array of pointers to diis buffers
      53             : !> \param diis_buffer the diis buffer pointer
      54             : !> \par History
      55             : !>      02.2003 created [fawzi]
      56             : !> \author fawzi
      57             : ! **************************************************************************************************
      58             :    TYPE qs_diis_buffer_p_type
      59             :       TYPE(qs_diis_buffer_type), POINTER :: diis_buffer => NULL()
      60             :    END TYPE qs_diis_buffer_p_type
      61             : 
      62             : ! **************************************************************************************************
      63             : !> \brief build array of pointers to diis buffers for sparse matrix case
      64             : !> \param diis_buffer the diis buffer pointer
      65             : !> \par History
      66             : !>      10.2014 Modified from non-sparse case by Fredy W. Aquino
      67             : !> \author fwaq
      68             : ! **************************************************************************************************
      69             :    TYPE qs_diis_buffer_type_sparse
      70             :       INTEGER                                          :: nbuffer = -1
      71             :       INTEGER                                          :: ncall = -1
      72             :       TYPE(dbcsr_p_type), DIMENSION(:, :), POINTER     :: error => NULL()
      73             :       TYPE(dbcsr_p_type), DIMENSION(:, :), POINTER     :: param => NULL()
      74             :       REAL(KIND=dp), DIMENSION(:, :), POINTER          :: b_matrix => NULL()
      75             :    END TYPE qs_diis_buffer_type_sparse
      76             : 
      77             :    TYPE qs_diis_buffer_p_type_sparse
      78             :       TYPE(qs_diis_buffer_type_sparse), POINTER        :: diis_buffer => NULL()
      79             :    END TYPE qs_diis_buffer_p_type_sparse
      80             : 
      81             : ! **************************************************************************************************
      82             : !> \brief build arrau of pointers to diis buffers in the k-point (complex full matrices) case
      83             : !> \note we keep the overlap matrix and 1 parameter matrix per k-point, in the corresponding kp subgroup
      84             : !> \par History
      85             : !>      04.2023 created
      86             : !> \author Augustin Bussy
      87             : ! **************************************************************************************************
      88             :    TYPE qs_diis_buffer_type_kp
      89             :       INTEGER                                          :: nbuffer = -1
      90             :       INTEGER                                          :: ncall = -1
      91             :       TYPE(cp_cfm_type), DIMENSION(:), POINTER         :: smat => NULL()
      92             :       TYPE(cp_cfm_type), DIMENSION(:, :, :), POINTER   :: param => NULL()
      93             :       TYPE(cp_cfm_type), DIMENSION(:, :, :), POINTER   :: error => NULL()
      94             :       COMPLEX(KIND=dp), DIMENSION(:, :), POINTER       :: b_matrix => NULL()
      95             :    END TYPE qs_diis_buffer_type_kp
      96             : 
      97             :    TYPE qs_diis_buffer_p_type_kp
      98             :       TYPE(qs_diis_buffer_type_kp), POINTER            :: diis_buffer => NULL()
      99             :    END TYPE qs_diis_buffer_p_type_kp
     100             : 
     101             : CONTAINS
     102             : 
     103             : ! **************************************************************************************************
     104             : !> \brief releases the given diis buffer (see doc/ReferenceCounting.html)
     105             : !> \param diis_buffer the buffer to release
     106             : !> \par History
     107             : !>      02.2003 created [fawzi]
     108             : !> \author fawzi
     109             : ! **************************************************************************************************
     110        3160 :    SUBROUTINE qs_diis_b_release(diis_buffer)
     111             :       TYPE(qs_diis_buffer_type), INTENT(INOUT)           :: diis_buffer
     112             : 
     113        3160 :       IF (ASSOCIATED(diis_buffer%b_matrix)) THEN
     114        2922 :          DEALLOCATE (diis_buffer%b_matrix)
     115             :       END IF
     116        3160 :       CALL cp_fm_release(diis_buffer%error)
     117        3160 :       CALL cp_fm_release(diis_buffer%param)
     118             : 
     119        3160 :    END SUBROUTINE qs_diis_b_release
     120             : 
     121             : ! **************************************************************************************************
     122             : !> \brief releases the given diis buffer (see doc/ReferenceCounting.html)
     123             : !> \param diis_buffer the buffer to release
     124             : !> \par History
     125             : !>      10-11-14 created [FA] modified from qs_diis_b_release
     126             : !> \author Fredy W. Aquino
     127             : ! **************************************************************************************************
     128           4 :    SUBROUTINE qs_diis_b_release_sparse(diis_buffer)
     129             : 
     130             :       TYPE(qs_diis_buffer_type_sparse), INTENT(INOUT)    :: diis_buffer
     131             : 
     132             :       INTEGER                                            :: i, j
     133             : 
     134           4 :       IF (ASSOCIATED(diis_buffer%b_matrix)) THEN
     135           4 :          DEALLOCATE (diis_buffer%b_matrix)
     136             :       END IF
     137           4 :       IF (ASSOCIATED(diis_buffer%error)) THEN
     138          10 :          DO j = 1, SIZE(diis_buffer%error, 2)
     139          34 :             DO i = 1, SIZE(diis_buffer%error, 1)
     140          24 :                CALL dbcsr_release(diis_buffer%error(i, j)%matrix)
     141          30 :                DEALLOCATE (diis_buffer%error(i, j)%matrix)
     142             :             END DO
     143             :          END DO
     144           4 :          DEALLOCATE (diis_buffer%error)
     145             :       END IF
     146           4 :       IF (ASSOCIATED(diis_buffer%param)) THEN
     147          10 :          DO j = 1, SIZE(diis_buffer%param, 2)
     148          34 :             DO i = 1, SIZE(diis_buffer%param, 1)
     149          24 :                CALL dbcsr_release(diis_buffer%param(i, j)%matrix)
     150          30 :                DEALLOCATE (diis_buffer%param(i, j)%matrix)
     151             :             END DO
     152             :          END DO
     153           4 :          DEALLOCATE (diis_buffer%param)
     154             :       END IF
     155           4 :    END SUBROUTINE qs_diis_b_release_sparse
     156             : 
     157             : ! **************************************************************************************************
     158             : !> \brief releases the given diis KP buffer
     159             : !> \param diis_buffer the buffer to release
     160             : ! **************************************************************************************************
     161         120 :    SUBROUTINE qs_diis_b_release_kp(diis_buffer)
     162             :       TYPE(qs_diis_buffer_type_kp), INTENT(INOUT)        :: diis_buffer
     163             : 
     164             :       INTEGER                                            :: i, j, k
     165             : 
     166         120 :       IF (ASSOCIATED(diis_buffer%b_matrix)) THEN
     167         106 :          DEALLOCATE (diis_buffer%b_matrix)
     168             :       END IF
     169         120 :       IF (ASSOCIATED(diis_buffer%smat)) THEN
     170         704 :          DO i = 1, SIZE(diis_buffer%smat)
     171         704 :             CALL cp_cfm_release(diis_buffer%smat(i))
     172             :          END DO
     173         106 :          DEALLOCATE (diis_buffer%smat)
     174             :       END IF
     175         120 :       IF (ASSOCIATED(diis_buffer%error)) THEN
     176         704 :          DO k = 1, SIZE(diis_buffer%error, 3)
     177        1456 :             DO j = 1, SIZE(diis_buffer%error, 2)
     178        4358 :                DO i = 1, SIZE(diis_buffer%error, 1)
     179        3760 :                   CALL cp_cfm_release(diis_buffer%error(i, j, k))
     180             :                END DO
     181             :             END DO
     182             :          END DO
     183         106 :          DEALLOCATE (diis_buffer%error)
     184             :       END IF
     185         120 :       IF (ASSOCIATED(diis_buffer%param)) THEN
     186         704 :          DO k = 1, SIZE(diis_buffer%param, 3)
     187        1456 :             DO j = 1, SIZE(diis_buffer%param, 2)
     188        4358 :                DO i = 1, SIZE(diis_buffer%param, 1)
     189        3760 :                   CALL cp_cfm_release(diis_buffer%param(i, j, k))
     190             :                END DO
     191             :             END DO
     192             :          END DO
     193         106 :          DEALLOCATE (diis_buffer%param)
     194             :       END IF
     195         120 :    END SUBROUTINE qs_diis_b_release_kp
     196           0 : END MODULE qs_diis_types

Generated by: LCOV version 1.15