LCOV - code coverage report
Current view: top level - src/pw - realspace_grid_cube_unittest.F (source / functions) Coverage Total Hit
Test: CP2K Regtests (git:7641cd9) Lines: 79.2 % 24 19
Test Date: 2026-05-25 07:16:39 Functions: 100.0 % 2 2

            Line data    Source code
       1              : !--------------------------------------------------------------------------------------------------!
       2              : !   CP2K: A general program to perform molecular dynamics simulations                              !
       3              : !   Copyright 2000-2026 CP2K developers group <https://cp2k.org>                                   !
       4              : !                                                                                                  !
       5              : !   SPDX-License-Identifier: GPL-2.0-or-later                                                      !
       6              : !--------------------------------------------------------------------------------------------------!
       7            2 : PROGRAM realspace_grid_cube_unittest
       8            2 :    USE kinds,                           ONLY: dp
       9              :    USE realspace_grid_cube,             ONLY: cube_read_values,&
      10              :                                               cube_value_format,&
      11              :                                               cube_values_format
      12              : 
      13              :    IMPLICIT NONE
      14              : 
      15              :    CHARACTER(LEN=13)                                  :: value
      16              :    CHARACTER(LEN=92)                                  :: slice_values
      17              :    CHARACTER(LEN=79)                                  :: values
      18              :    REAL(KIND=dp), DIMENSION(6)                        :: buffer, reference
      19              :    REAL(KIND=dp), DIMENSION(7)                        :: slice_buffer, slice_reference
      20              : 
      21            2 :    WRITE (value, cube_value_format) 0.33004E-101_dp
      22            2 :    IF (INDEX(value, "E-101") <= 0) &
      23            0 :       ERROR STOP "Cube value format must preserve three-digit negative exponents."
      24              : 
      25              :    reference = [0.0_dp, -0.91458E-35_dp, 0.33004E-101_dp, &
      26            2 :                 -0.32487E-103_dp, 1.0_dp, -1.0_dp]
      27            2 :    WRITE (values(1:78), cube_values_format) reference
      28            2 :    values(79:79) = NEW_LINE("C")
      29            2 :    IF (INDEX(values, "E-101") <= 0) &
      30            0 :       ERROR STOP "Cube line format must preserve E-101."
      31            2 :    IF (INDEX(values, "E-103") <= 0) &
      32            0 :       ERROR STOP "Cube line format must preserve E-103."
      33            2 :    CALL cube_read_values(values, buffer)
      34           14 :    IF (MAXVAL(ABS(buffer - reference)) > 1.0E-12_dp) &
      35            0 :       ERROR STOP "Cube reader must parse adjacent explicit-exponent values."
      36              : 
      37           14 :    slice_reference(1:6) = reference
      38            2 :    slice_reference(7) = 0.27183E-123_dp
      39            2 :    WRITE (slice_values(1:78), cube_values_format) slice_reference(1:6)
      40            2 :    slice_values(79:79) = NEW_LINE("C")
      41            2 :    WRITE (slice_values(80:92), cube_value_format) slice_reference(7)
      42            2 :    CALL cube_read_values(slice_values, slice_buffer)
      43           16 :    IF (MAXVAL(ABS(slice_buffer - slice_reference)) > 1.0E-12_dp) &
      44            0 :       ERROR STOP "Cube reader must parse multi-line z-slices."
      45              : 
      46            2 : END PROGRAM realspace_grid_cube_unittest
        

Generated by: LCOV version 2.0-1