Skip to content

Commit

Permalink
detect duplicate presence of the same function nwchemgit#799
Browse files Browse the repository at this point in the history
  • Loading branch information
edoapra committed Jun 24, 2023
1 parent be3b2b0 commit df119cd
Showing 1 changed file with 47 additions and 1 deletion.
48 changes: 47 additions & 1 deletion src/ddscf/int_1e_ga.F
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ subroutine int_1e_ga(ibas, jbas, g, integ_type, oskel)
#include "cscfps.fh"
#include "sym.fh"
#include "geom.fh"
#include "util.fh"
c
c Compute the desired type of integrals (kinetic, potential, overlap)
c and ADD them into the given global array.
Expand All @@ -68,13 +69,16 @@ subroutine int_1e_ga(ibas, jbas, g, integ_type, oskel)
c local variables
c
integer type
logical dobq
integer bad_ovl,adrs,lds,i0,i1,j0,j1
logical dobq,oprint_s,oprint_check_s
character*255 integ_type1
c
call ga_sync()
c
dobq = geom_extbq_on()
integ_type1 = integ_type
oprint_check_s = util_print('check_s',print_high)
oprint_s = util_print('ao overlap',print_debug)
c
if (inp_compare(.false., integ_type1, 'potential0')) then
integ_type1='potential'
Expand Down Expand Up @@ -157,6 +161,23 @@ subroutine int_1e_ga(ibas, jbas, g, integ_type, oskel)
call int_1e_oldga(ibas, jbas, g, integ_type1, oskel)
end if
c
c overlap: check if offdiagonal elements are 1 -> same basis
if(type.eq.3.and.oprint_s) call ga_print(g)
if(type.eq.3.and.oprint_check_s) then
bad_ovl=0
call ga_distribution(g,
. ga_nodeid(), i0, i1, j0, j1)
if (i0.gt.0 .and. i0.le.i1) then
call ga_access(g, i0, i1, j0, j1, adrs, lds)
call int_checks(i0, i1, j0, j1,dbl_mb(adrs),
A bad_ovl)
endif
call ga_igop(2023,bad_ovl,1, '+')
if(bad_ovl.gt.0) then
call errquit('int_1e_ga: same basis from S matrix',
A bad_ovl, BASIS_ERR)
endif
endif
end
c
subroutine int_1e_ooldga(ibas, jbas, g, integ_type, oskel)
Expand Down Expand Up @@ -715,3 +736,28 @@ subroutine int_1e_oldga0(ibas, g, type, oskel,
if (oscfps) call pstat_off(ps_int_1e)
c
end
subroutine int_checks(i0, i1, j0, j1, s, sing_vals)
implicit none
#include "stdio.fh"
integer i0, i1, j0, j1
double precision s(i0:i1,j0:j1)
integer sing_vals
c
integer i,j
double precision eps
parameter(eps=1d-8)
c
if(i0.lt.j0) return
do j=j0,j1
do i=i0,min(i1,j1)
if(i.gt.j) then
if (abs(s(i,j)-1d0).lt.eps) then
write(luout,1) i,j
sing_vals=sing_vals+1
endif
endif
enddo
enddo
1 format(' basis ',i5,' and ',i5,' are the same')
return
end

0 comments on commit df119cd

Please sign in to comment.