From 294a774e9e88b96ae1038730ac025c6479c6f3e6 Mon Sep 17 00:00:00 2001 From: "Igor S. Gerasimov" Date: Wed, 27 Nov 2024 05:21:07 +0100 Subject: [PATCH 1/5] Fix undefined behavior warning in constrain_pot.f90 Signed-off-by: Igor S. Gerasimov --- src/constrain_pot.f90 | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/src/constrain_pot.f90 b/src/constrain_pot.f90 index 6cfa4a087..335fb8264 100644 --- a/src/constrain_pot.f90 +++ b/src/constrain_pot.f90 @@ -104,9 +104,9 @@ subroutine qpothess2(fix,n,at,xyz,h) ! calculate hessian do i = 1, fix%n !loop over all atoms ii = (fix%atoms(i)-1)*3 - do k = 1, 3 !loop diagonal elements (xyz components) - do j = 1, fix%n !inner loop for sum over all atoms - if (i.ne.j) then + do j = 1, fix%n !inner loop for sum over all atoms + if (i.ne.j) then + do k = 1, 3 !loop diagonal elements (xyz components) rij = xyz(:,fix%atoms(j))-xyz(:,fix%atoms(i)) r = norm2(rij) r2 = r*r @@ -123,9 +123,11 @@ subroutine qpothess2(fix,n,at,xyz,h) iikl = lin(ii+k,ii+l) h(iikl) = h(iikl) + 2.0_wp*fix%fc*r0*dx*dy/r3 enddo !end loop same-atom block-diagonal elements - endif - enddo !end inner loop for sum over all atoms - do j = i+1, fix%n !loop over the rest (mixed atoms) + enddo !end loop diagonal elements (xyz components) + endif + enddo !end inner loop for sum over all atoms + do j = i+1, fix%n !loop over the rest (mixed atoms) + do k = 1, 3 !loop diagonal elements (xyz components) rij = xyz(:,fix%atoms(j))-xyz(:,fix%atoms(i)) r = norm2(rij) r2 = r*r @@ -147,8 +149,8 @@ subroutine qpothess2(fix,n,at,xyz,h) h(ikjm) = h(ikjm) - 2.0_wp*fix%fc*r0*dx*dy/r3 endif enddo - enddo - enddo !end loop diagonal elements (xyz components) + enddo !end loop diagonal elements (xyz components) + enddo enddo !end loop atoms contains From 955ff888b5f80032d70099eaf3e0d349f811f087 Mon Sep 17 00:00:00 2001 From: "Igor S. Gerasimov" Date: Wed, 27 Nov 2024 05:24:35 +0100 Subject: [PATCH 2/5] Compute once those that does not depend on k Signed-off-by: Igor S. Gerasimov --- src/constrain_pot.f90 | 33 ++++++++++++++++----------------- 1 file changed, 16 insertions(+), 17 deletions(-) diff --git a/src/constrain_pot.f90 b/src/constrain_pot.f90 index 335fb8264..71fad3460 100644 --- a/src/constrain_pot.f90 +++ b/src/constrain_pot.f90 @@ -106,14 +106,14 @@ subroutine qpothess2(fix,n,at,xyz,h) ii = (fix%atoms(i)-1)*3 do j = 1, fix%n !inner loop for sum over all atoms if (i.ne.j) then + rij = xyz(:,fix%atoms(j))-xyz(:,fix%atoms(i)) + r = norm2(rij) + r2 = r*r + r3 = r2*r + ij = lin(i-1,j-1)+1 + r0 = fix%val(ij) + dr = r-r0 do k = 1, 3 !loop diagonal elements (xyz components) - rij = xyz(:,fix%atoms(j))-xyz(:,fix%atoms(i)) - r = norm2(rij) - r2 = r*r - r3 = r2*r - ij = lin(i-1,j-1)+1 - r0 = fix%val(ij) - dr = r-r0 dx = xyz(k,fix%atoms(i))-xyz(k,fix%atoms(j)) dx2 = dx*dx iik = lin(ii+k,ii+k) @@ -127,23 +127,22 @@ subroutine qpothess2(fix,n,at,xyz,h) endif enddo !end inner loop for sum over all atoms do j = i+1, fix%n !loop over the rest (mixed atoms) + rij = xyz(:,fix%atoms(j))-xyz(:,fix%atoms(i)) + r = norm2(rij) + r2 = r*r + r3 = r2*r + ij = lin(i-1,j-1)+1 + r0 = fix%val(ij) + dr = r-r0 + jj = (fix%atoms(j)-1)*3 do k = 1, 3 !loop diagonal elements (xyz components) - rij = xyz(:,fix%atoms(j))-xyz(:,fix%atoms(i)) - r = norm2(rij) - r2 = r*r - r3 = r2*r - ij = lin(i-1,j-1)+1 - r0 = fix%val(ij) - dr = r-r0 - jj = (fix%atoms(j)-1)*3 + dx = xyz(k,fix%atoms(i))-xyz(k,fix%atoms(j)) do m = 1, 3 if (k.eq.m) then !same component case - dx = xyz(k,fix%atoms(i))-xyz(k,fix%atoms(j)) dx2 = dx*dx ijk = lin(ii+k,jj+k) h(ijk) = h(ijk) - 2.0_wp*fix%fc*(1.0_wp+dx2/r2-dx2*dr/r3-r0/r) else !different component case - dx = xyz(k,fix%atoms(i))-xyz(k,fix%atoms(j)) dy = xyz(m,fix%atoms(i))-xyz(m,fix%atoms(j)) ikjm = lin(ii+k,jj+m) h(ikjm) = h(ikjm) - 2.0_wp*fix%fc*r0*dx*dy/r3 From 8964cd871c632cb89ece62f369d6b71e8c969dd5 Mon Sep 17 00:00:00 2001 From: "Igor S. Gerasimov" Date: Wed, 27 Nov 2024 05:25:56 +0100 Subject: [PATCH 3/5] Remove legacy comma Signed-off-by: Igor S. Gerasimov --- src/gfnff/gfnff_eg.f90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gfnff/gfnff_eg.f90 b/src/gfnff/gfnff_eg.f90 index 58b84ca1f..bbf858715 100644 --- a/src/gfnff/gfnff_eg.f90 +++ b/src/gfnff/gfnff_eg.f90 @@ -1068,7 +1068,7 @@ subroutine egbond_hb(i,iat,jat,iTr,rab,rij,drij,drijdcn,hb_cn,hb_dcn,n,at,xyz,e, hbH=jat hbA=iat else - write(*,'(10x,"No H-atom found in this bond ",i0,1x,i0)'), iat,jat + write(*,'(10x,"No H-atom found in this bond ",i0,1x,i0)') iat,jat return end if From 9863ece98bb340e4762ee585dc558dddca535ca7 Mon Sep 17 00:00:00 2001 From: "Igor S. Gerasimov" Date: Wed, 27 Nov 2024 05:35:30 +0100 Subject: [PATCH 4/5] Proper interface for eigsort4 Signed-off-by: Igor S. Gerasimov --- src/gfnff/frag_hess.f90 | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/src/gfnff/frag_hess.f90 b/src/gfnff/frag_hess.f90 index b0d4039d9..3dbe28f28 100644 --- a/src/gfnff/frag_hess.f90 +++ b/src/gfnff/frag_hess.f90 @@ -40,14 +40,12 @@ function shortest_distance(nspin, start, goal, numnb, neighbours, input_distance real(wp) :: alt_dist real(wp) :: distance(nspin) end function shortest_distance - subroutine eigsort4(lab,ew,u) + subroutine eigsort4(lab,u,ew) use xtb_mctc_accuracy, only : sp implicit none - integer :: ii,k, j, i - real(sp) :: pp, hilf - integer :: lab - real(sp) :: ew(lab) - real(sp) :: u(lab,lab) + integer, intent(in) :: lab + real(sp), intent(inout) :: u(lab,lab) + real(sp), intent(inout) :: ew(lab) end subroutine eigsort4 end interface @@ -486,9 +484,9 @@ subroutine eigsort4(lab,u,ew) integer :: ii,k, j, i real(sp) :: pp, hilf - integer, intent(in) :: lab - real(sp), intent(inout) :: ew(lab) + integer, intent(in) :: lab real(sp), intent(inout) :: u(lab,lab) + real(sp), intent(inout) :: ew(lab) do ii = 2, lab i = ii - 1 From c3d0c175399a4f1fcb74f3f0e170f373b9c4bde0 Mon Sep 17 00:00:00 2001 From: "Igor S. Gerasimov" Date: Wed, 27 Nov 2024 05:43:09 +0100 Subject: [PATCH 5/5] Fix shortest_distance interface Signed-off-by: Igor S. Gerasimov --- src/gfnff/frag_hess.f90 | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/src/gfnff/frag_hess.f90 b/src/gfnff/frag_hess.f90 index 3dbe28f28..ce54c5a2a 100644 --- a/src/gfnff/frag_hess.f90 +++ b/src/gfnff/frag_hess.f90 @@ -29,16 +29,10 @@ function shortest_distance(nspin, start, goal, numnb, neighbours, input_distance integer, intent(in) :: start integer, intent(in) :: goal integer, intent(in) :: numnb - integer, intent(in) :: neighbours(20, nspin) + integer, intent(in) :: neighbours(numnb, nspin, 1) real(wp), intent(in) :: input_distances(nspin, nspin) logical, intent(out) :: visited(nspin) integer, intent(out) :: precessor(nspin) - integer :: current - integer :: neighbour - integer :: i_neighbours - integer :: bonds - real(wp) :: alt_dist - real(wp) :: distance(nspin) end function shortest_distance subroutine eigsort4(lab,u,ew) use xtb_mctc_accuracy, only : sp