src: remove unnecessary one, zero uses

This commit is contained in:
Michele Guerini Rocco 2024-09-23 22:16:33 +02:00 committed by rnhmjoj
parent 80782a58fc
commit 24e0e6e472
Signed by: rnhmjoj
GPG Key ID: BFBAF4C975F76450
7 changed files with 221 additions and 250 deletions

View File

@ -145,7 +145,7 @@ pure subroutine harmnumber(Y, mu, Npl2, weakly, nhmin, nhmax)
! Yc = 1 -½ N² (weakly relativistic)
!
if (weakly) then
Yc = max(one - npl2/2, zero)
Yc = max(1 - npl2/2, zero)
else
Yc = sqrt(max(1 - npl2, zero))
end if
@ -196,7 +196,7 @@ pure subroutine harmnumber(Y, mu, Npl2, weakly, nhmin, nhmax)
else
rdu2 = Yn**2 - Yc**2
gamma = (Yn - sqrt(Npl2*rdu2))/(1 - Npl2)
argexp = mu*(gamma - one)
argexp = mu*(gamma - 1)
end if
if (argexp <= expcr) then
@ -406,7 +406,7 @@ subroutine warmdisp(X, Y, mu, Npl, Npr_cold, sox, &
Npr2 = Npr2_prev + 0.05_wp_ * (Npr2 - Npr2_prev) / abs(Npr2 - Npr2_prev)
! Again, make sure that we have a damped EM wave and not a
! Bernstein-like wave (see above)
if (real(sqrt(Npr2)) * aimag(sqrt(Npr2)) < zero) &
if (real(sqrt(Npr2)) * aimag(sqrt(Npr2)) < 0) &
Npr2 = conjg(sqrt(Npr2))**2
end if
end block modify_fixed_point
@ -464,7 +464,7 @@ subroutine warmdisp(X, Y, mu, Npl, Npr_cold, sox, &
if (sox < 0) then
e(3) = 1
else
e(1) = sqrt(one/(1 + abs(-eps(1,1)/eps(1,2))**2))
e(1) = sqrt(1/(1 + abs(-eps(1,1)/eps(1,2))**2))
e(2) = -e(1)*eps(1,1)/eps(1,2)
end if
end if
@ -673,7 +673,7 @@ subroutine hermitian(rr,yg,mu,npl,cr,fast,lrm)
do n=-lrm,lrm
do k=0,2
do m=0,lrm
rr(n,k,m)=zero
rr(n,k,m) = 0
end do
end do
end do
@ -893,7 +893,7 @@ subroutine hermitian_2(rr,yg,mu,npl,cr,fast,lrm,error)
do n=-lrm,lrm
do k=0,2
do m=0,lrm
rr(n,k,m)=zero
rr(n,k,m) = 0
end do
end do
end do
@ -1059,7 +1059,7 @@ function fhermit(t,apar,npar)
zm2=zm*zm
zm3=zm2*zm
call calcei3(zm,fe0m)
ffe=zero
ffe = 0
uplh=upl**ih
if(n.eq.0.and.m.eq.0) ffe=exdxdt*fe0m*upl2
if(m.eq.1) ffe=(one+s*(one-zm*fe0m))*uplh/mu2
@ -1089,7 +1089,7 @@ subroutine antihermitian(ri,yg,mu,npl,ci,lrm)
do n=1,lrm
do k=0,2
do m=1,lrm
ri(n,k,m)=zero
ri(n,k,m) = 0
end do
end do
end do
@ -1101,7 +1101,7 @@ subroutine antihermitian(ri,yg,mu,npl,ci,lrm)
do n=1,lrm
ygn=n*yg
rdu2=ygn**2-dnl
if(rdu2.gt.zero) then
if(rdu2.gt.0) then
rdu=sqrt(rdu2)
du=rdu/dnl
ub=npl*ygn/dnl
@ -1231,17 +1231,17 @@ pure subroutine fsup(lrm, yg, npl, mu, cefp, cefm, error)
phim=sqrt(abs(phi2))
if (alpha.ge.0) then
xp=psi-phim
yp=zero
yp=0
xm=-psi-phim
ym=zero
ym=0
x0=-phim
y0=zero
y0=0
else
xp=psi
yp=phim
xm=-psi
ym=phim
x0=zero
x0=0
y0=phim
end if
call zetac (xp,yp,zrp,zip,iflag)
@ -1295,19 +1295,19 @@ pure subroutine fsup(lrm, yg, npl, mu, cefp, cefm, error)
alpha=npl*npl/2.0_wp_-is*yg-one
phi2=mu*alpha
phim=sqrt(abs(phi2))
if (alpha.ge.zero) then
if (alpha.ge.0) then
xp=psi-phim
yp=zero
yp=0
xm=-psi-phim
ym=zero
ym=0
x0=-phim
y0=zero
y0=0
else
xp=psi
yp=phim
xm=-psi
ym=phim
x0=zero
x0=0
y0=phim
end if
call zetac (xp,yp,zrp,zip,iflag)
@ -1320,7 +1320,7 @@ pure subroutine fsup(lrm, yg, npl, mu, cefp, cefm, error)
!
cf12=czero
if (alpha.ge.0) then
if (alpha.ne.zero) cf12=-(czp+czm)/(2.0_wp_*phim)
if (alpha.ne.0) cf12=-(czp+czm)/(2.0_wp_*phim)
else
cf12=-im*(czp+czm)/(2.0_wp_*phim)
end if

View File

@ -131,10 +131,10 @@ contains
allocate(results%jcd(params%output%nrho))
! ...and initialise them
results%pabs = zero
results%icd = zero
results%dpdv = zero
results%jcd = zero
results%pabs = 0
results%icd = 0
results%dpdv = 0
results%jcd = 0
! ========= set environment END =========
! Pre-determinted tables
@ -180,15 +180,15 @@ contains
write (msg, '("pass: ",g0)') ip
call log_info(msg, mod='gray_core', proc='gray_main')
pabs_pass = zero
icd_pass = zero
pabs_pass = 0
icd_pass = 0
istop_pass = 0 ! stop flag for current pass
nbeam_pass = 2*nbeam_pass ! max n of beams in current pass
if(ip > 1) then
du1 = zero
gri = zero
ggri = zero
du1 = 0
gri = 0
ggri = 0
if(ip == params%raytracing%ipass) cpl = [zero, zero] ! no successive passes
end if
@ -215,15 +215,22 @@ contains
cycle
end if
call vectinit(psjki,ppabs,ccci,tau0,alphaabs0,dids0,ccci0,iiv)
psjki = 0
ppabs = 0
ccci = 0
tau0 = 0
alphaabs0 = 0
dids0 = 0
ccci0 = 0
iiv = 1
if(ip == 1) then ! 1st pass
igrad_b = params%raytracing%igrad ! * input value, igrad_b=0 from 2nd pass
tau1 = zero ! * tau from previous passes
etau1 = one
cpl1 = one ! * coupling from previous passes
lgcpl1 = zero
tau1 = 0 ! * tau from previous passes
etau1 = 1
cpl1 = 1 ! * coupling from previous passes
lgcpl1 = 0
p0ray = p0jk ! * initial beam power
call compute_initial_conds(params%raytracing, params%antenna, & ! * initial conditions
@ -469,10 +476,10 @@ contains
end if
end block
else
tekev=zero
alpha=zero
didp=zero
anprim=zero
tekev=0
alpha=0
didp=0
anprim=0
anprre=anpr
nharm=0
nhf=0
@ -568,15 +575,15 @@ contains
cpl_beam1 = sum(&
p0ray * exp(-tau0) * cpls(:,child_index_rt)/cpl1, MASK=iop > 2) / &
sum(p0ray * exp(-tau0), MASK=iop > 2) ! * average O-mode coupling for next beam (on active rays)
cpl_beam2 = one - cpl_beam1 ! * average X-mode coupling for next beam
cpl_beam2 = 1 - cpl_beam1 ! * average X-mode coupling for next beam
if(iop(1) > 2) then ! * central ray O/X-mode coupling for next beam
cpl_cbeam1 = cpls(1,child_index_rt)/cpl1(1)
cpl_cbeam2 = one - cpl_cbeam1
cpl_cbeam2 = 1 - cpl_cbeam1
end if
else ! last pass OR no ray re-entered plasma
cpl_beam1 = zero
cpl_beam2 = zero
cpl_beam1 = 0
cpl_beam2 = 0
end if
! print final results for pass on screen
@ -661,36 +668,6 @@ contains
end subroutine gray_main
subroutine vectinit(psjki,ppabs,ccci,tau0,alphaabs0,dids0,ccci0,iiv)
use const_and_precisions, only : zero
! arguments
real(wp_), dimension(:,:), intent(out) :: psjki,ppabs,ccci
real(wp_), dimension(:), intent(out) :: tau0,alphaabs0,dids0,ccci0
integer, dimension(:), intent(out) :: iiv
!! common/external functions/variables
! integer :: jclosest
! real(wp_), dimension(3) :: anwcl,xwcl
!
! common/refln/anwcl,xwcl,jclosest
!
! jclosest=nrayr+1
! anwcl(1:3)=0.0_wp_
! xwcl(1:3)=0.0_wp_
psjki = zero
ppabs = zero
ccci = zero
tau0 = zero
alphaabs0 = zero
dids0 = zero
ccci0 = zero
iiv = 1
end subroutine vectinit
subroutine compute_initial_conds(rtx, beam, N_c, k0, y, yp, dist, &
pos, grad_u, grad, hess)
! Computes the initial conditions for tracing a beam
@ -1007,7 +984,6 @@ contains
subroutine gradi_upd(params, ywrk, ak0, xc, du1, gri, ggri, error)
use const_and_precisions, only : zero, half
use gray_params, only : raytracing_parameters
use gray_errors, only : gray_error, unstable_beam, raise_error
@ -1060,7 +1036,7 @@ contains
call solg0(dxv1,dxv2,dxv3,dgu)
du1(:,k,j) = dgu
end do
gri(:,1) = zero
gri(:,1) = 0
! compute grad u1 and grad(S_I) for all the other rays
if (params%nrayr > 1) then
@ -1125,7 +1101,7 @@ contains
end do
! compute derivatives of grad u and grad(S_I) for rays jk>1
ggri(:,:,1) = zero
ggri(:,:,1) = 0
jm=1
j=2
k=0
@ -1160,9 +1136,9 @@ contains
uxx = dgg(1,1)
uyy = dgg(2,2)
uzz = dgg(3,3)
uxy = (dgg(1,2) + dgg(2,1))*half
uxz = (dgg(1,3) + dgg(3,1))*half
uyz = (dgg(2,3) + dgg(3,2))*half
uxy = (dgg(1,2) + dgg(2,1))/2
uxz = (dgg(1,3) + dgg(3,1))/2
uyz = (dgg(2,3) + dgg(3,2))/2
! derivatives of S_I and Grad(S_I)
gx = ux*dffiu
@ -1243,7 +1219,7 @@ contains
subroutine plas_deriv(equil, plasma, xv, bres, xgcn, dens, btot, &
bv, derbv, xg, yg, derxg, deryg, psinv_opt)
use const_and_precisions, only : zero, cm
use const_and_precisions, only : cm
use gray_equil, only : abstract_equil, vacuum
use gray_plasma, only : abstract_plasma
@ -1267,15 +1243,15 @@ contains
real(wp_) :: brr,bphi,bzz,dxgdpsi
real(wp_) :: dpsidr,dpsidz,ddpsidrr,ddpsidzz,ddpsidrz,fpolv,dfpv,ddensdpsi
xg = zero
xg = 0
yg = 99._wp_
psinv = -1._wp_
dens = zero
btot = zero
derxg = zero
deryg = zero
bv = zero
derbv = zero
dens = 0
btot = 0
derxg = 0
deryg = 0
bv = 0
derbv = 0
select type (equil)
type is (vacuum)
@ -1284,11 +1260,11 @@ contains
return
end select
dbtot = zero
dbv = zero
dbvcdc = zero
dbvcdc = zero
dbvdc = zero
dbtot = 0
dbv = 0
dbvcdc = 0
dbvcdc = 0
dbvdc = 0
xx = xv(1)
yy = xv(2)
@ -1315,7 +1291,7 @@ contains
if (present(psinv_opt)) psinv_opt = psinv
! compute yg and derivative
if(psinv < zero) then
if(psinv < 0) then
bphi = fpolv/rrm
btot = abs(bphi)
yg = btot/bres
@ -1405,7 +1381,7 @@ contains
! (`ywppla_upd` suborutine); while the optional ones are used for
! computing the absoprtion and current drive.
use const_and_precisions, only : zero, one, half, two
use const_and_precisions, only : zero, half
use gray_params, only : gray_parameters, STEP_ARCLEN, &
STEP_TIME, STEP_PHASE
@ -1461,24 +1437,24 @@ contains
! Shorthands used in the expressions below
yg2 = yg**2 ! Y²
anpl2 = anpl**2 ! N²
dnl = one - anpl2 ! 1 - N²
duh = one - xg - yg2 ! UH denom (duh=0 on the upper-hybrid resonance)
dnl = 1 - anpl2 ! 1 - N²
duh = 1 - xg - yg2 ! UH denom (duh=0 on the upper-hybrid resonance)
! Compute/copy optional outputs
if (present(anpr)) anpr = sqrt(max(an2 - anpl2, zero)) ! N
if (present(anpl_)) anpl_ = anpl ! N
an2s = one
dan2sdxg = zero
dan2sdyg = zero
dan2sdnpl = zero
del = zero
fdia = zero
dfdiadnpl = zero
dfdiadxg = zero
dfdiadyg = zero
an2s = 1
dan2sdxg = 0
dan2sdyg = 0
dan2sdnpl = 0
del = 0
fdia = 0
dfdiadnpl = 0
dfdiadxg = 0
dfdiadyg = 0
if(xg > zero) then
if(xg > 0) then
! Derivatives of the cold plasma refractive index
!
! N²s = 1 - X - XY²(1 + N² ± Δ)/[2(1 - X - Y²)]
@ -1487,19 +1463,19 @@ contains
! + for the X mode, - for the O mode
! Δ
del = sqrt(dnl**2 + 4.0_wp_*anpl2*(one - xg)/yg2)
del = sqrt(dnl**2 + 4.0_wp_*anpl2*(1 - xg)/yg2)
! (N²s)/X
! Note: this term is nonzero for X=0, but it multiplies terms
! proportional to X or X/ψ which are zero outside the plasma.
dan2sdxg = - half*yg2*(one - yg2)*(one + anpl2 + sox*del)/duh**2 &
+ sox*xg*anpl2/(del*duh) - one
dan2sdxg = - half*yg2*(1 - yg2)*(1 + anpl2 + sox*del)/duh**2 &
+ sox*xg*anpl2/(del*duh) - 1
! (N²s)/Y
dan2sdyg = - xg*yg*(one - xg)*(one + anpl2 + sox*del)/duh**2 &
+ two*sox*xg*(one - xg)*anpl2/(yg*del*duh)
dan2sdyg = - xg*yg*(1 - xg)*(1 + anpl2 + sox*del)/duh**2 &
+ 2*sox*xg*(1 - xg)*anpl2/(yg*del*duh)
! (N²s)/N
dan2sdnpl = - xg*yg2*anpl/duh &
- sox*xg*anpl*(two*(one - xg) - yg2*dnl)/(del*duh)
- sox*xg*anpl*(2*(1 - xg) - yg2*dnl)/(del*duh)
if(igrad > 0) then
! Derivatives used in the complex eikonal terms (beamtracing only)
@ -1507,28 +1483,27 @@ contains
real(wp_) :: ddelnpl2, ddelnpl2x, ddelnpl2y, derdel
! ²Δ/N²
ddelnpl2 = two*(two*(one - xg)*(one + 3.0_wp_*anpl2**2) &
ddelnpl2 = 2*(2*(1 - xg)*(1 + 3.0_wp_*anpl2**2) &
- yg2*dnl**3)/yg2/del**3
! ²(N²s)/N²
fdia = - xg*yg2*(one + half*sox*ddelnpl2)/duh
fdia = - xg*yg2*(1 + half*sox*ddelnpl2)/duh
! Intermediates results used right below
derdel = two*(one - xg)*anpl2*(one + 3.0_wp_*anpl2**2) &
- dnl**2*(one + 3.0_wp_*anpl2)*yg2
derdel = 4.0_wp_*derdel/(yg*del)**5
ddelnpl2y = two*(one - xg)*derdel
derdel = 2*(1 - xg)*anpl2*(1 + 3*anpl2**2) &
- dnl**2*(1 + 3*anpl2)*yg2
derdel = 4*derdel/(yg*del)**5
ddelnpl2y = 2*(1 - xg)*derdel
ddelnpl2x = yg*derdel
! ³(N²s)/N³
dfdiadnpl = 24.0_wp_*sox*xg*(one - xg)*anpl*(one - anpl2**2) &
/(yg2*del**5)
dfdiadnpl = 24*sox*xg*(1 - xg)*anpl*(1 - anpl2**2)/(yg2*del**5)
! ³(N²s)/N²X
dfdiadxg = - yg2*(one - yg2)/duh**2 - sox*yg2*((one - yg2) &
*ddelnpl2 + xg*duh*ddelnpl2x)/(two*duh**2)
dfdiadxg = - yg2*(1 - yg2)/duh**2 - sox*yg2*((1 - yg2) &
*ddelnpl2 + xg*duh*ddelnpl2x)/(2*duh**2)
! ³(N²s)/N²Y
dfdiadyg = - two*yg*xg*(one - xg)/duh**2 &
- sox*xg*yg*(two*(one - xg)*ddelnpl2 &
+ yg*duh*ddelnpl2y)/(two*duh**2)
dfdiadyg = - 2*yg*xg*(1 - xg)/duh**2 &
- sox*xg*yg*(2*(1 - xg)*ddelnpl2 &
+ yg*duh*ddelnpl2y)/(2*duh**2)
end block
end if
end if
@ -1541,7 +1516,7 @@ contains
! Λ/ = 2 - (N²s)/ = 2 - (N²s)/N
! Note: we used the identity f() = f' ∇(v̅⋅b̅) = f'.
derdnv = two*anv - dan2sdnpl*bv
derdnv = 2*anv - dan2sdnpl*bv
! Λ/ω = N²/ω - N²s/XX/ω - N²s/YY/ω - N²s/NN/ω
! Notes: 1. N depends on ω: N²=c²k²/ω² N²/ω = -2N²/ω
@ -1549,7 +1524,7 @@ contains
! 2. derdom is actually ωΛ/ω, see below for the reason.
! 3. N gains a dependency on ω because Λ(S, ω) is computed
! on the constrains Λ=0.
derdom = -two*an2 + two*xg*dan2sdxg + yg*dan2sdyg + anpl*dan2sdnpl
derdom = -2*an2 + 2*xg*dan2sdxg + yg*dan2sdyg + anpl*dan2sdnpl
if (igrad > 0) then
! Complex eikonal terms added to the above expressions
@ -1576,7 +1551,7 @@ contains
! Λ/ω += |S_I|²/ω + ½(bS_I)²/ω + ½(S_I)² /ω (²N²s/N²)
! Note: as above S_I gains a dependency on ω
derdom = derdom + two*gr2 - bdotgr**2 &
derdom = derdom + 2*gr2 - bdotgr**2 &
* (fdia + xg*dfdiadxg + half*yg*dfdiadyg &
+ half*anpl*dfdiadnpl)
end block
@ -1651,7 +1626,7 @@ contains
if (present(ddr) .or. present(ddi)) then
! Dispersion relation (geometric optics)
! ddr Λ = N² - N²s(X,Y,N) = 0
an2s = one - xg - half*xg*yg2*(one + anpl2 + sox*del)/duh
an2s = 1 - xg - half*xg*yg2*(1 + anpl2 + sox*del)/duh
ddr = an2 - an2s
end if

View File

@ -185,7 +185,7 @@ contains
ddens = self%dens_spline%deriv(psin)
! Evaluate the spline 1st derivative
if (abs(dens) < 1.0e-10_wp_) dens = zero
if (abs(dens) < 1.0e-10_wp_) dens = 0
else
! Use a C² polynomial extension outside (ψ > ψ)

View File

@ -1,5 +1,5 @@
module reflections
use const_and_precisions, only : wp_, comp_tiny, comp_eps, comp_huge, zero, one
use const_and_precisions, only : wp_, comp_tiny, comp_eps, comp_huge
implicit none
@ -16,7 +16,7 @@ subroutine reflect(ki,nsurf,ko)
real(wp_), intent(out), dimension(3) :: ko
real(wp_) :: twokn,norm2
norm2 = dot_product(nsurf,nsurf)
if (norm2>zero) then
if (norm2>0) then
twokn = 2.0_wp_*dot_product(ki,nsurf)/norm2
ko=ki-twokn*nsurf
else
@ -42,20 +42,20 @@ subroutine inters_linewall(xv, kv, wall, sint, normw)
sint=comp_huge
iint=0
normw=zero
normw=0
do i=1, size(wall%R)-1
! search intersections with i-th wall segment
call linecone_coord(xv, kv, wall%R(i:i+1), wall%z(i:i+1), si, ti, ni)
! discard solutions with s<=0
first=ni+1
do j=1,ni
if (si(j)>zero) then
if (si(j)>0) then
first=j
exit
end if
end do
do j=first,ni
if ((si(j)<sint .or. iint==0) .and. ti(j)>=zero .and. ti(j)<=one) then
if ((si(j)<sint .or. iint==0) .and. ti(j)>=0 .and. ti(j)<=1) then
! check intersection is in r,z range and keep the closest
sint = si(j)
iint = i
@ -72,7 +72,7 @@ subroutine inters_linewall(xv, kv, wall, sint, normw)
l = hypot(drw, dzw)
kxy = norm2(kv(1:2))
normw(3) = -drw/l
if (rint>zero) then
if (rint>0) then
normw(1) = xint/rint*dzw/l
normw(2) = yint/rint*dzw/l
else
@ -80,7 +80,7 @@ subroutine inters_linewall(xv, kv, wall, sint, normw)
normw(2) = kv(2)/kxy*dzw/l
end if
! reverse normal if k.n>0
if (dot_product(normw,kv)>zero) normw=-normw
if (dot_product(normw,kv)>0) normw=-normw
end subroutine inters_linewall
@ -168,8 +168,8 @@ subroutine interssegm_coord(xa,ya,xb,yb,s,t,ierr)
dyb = yb(2)-yb(1)
crossprod = dxb*dya - dxa*dyb
if (abs(crossprod)<comp_tiny) then
s = zero
t = zero
s = 0
t = 0
ierr = 1
else
s = (dyb*(xa(1)-xb(1)) - dxb*(ya(1)-yb(1)))/crossprod
@ -187,8 +187,8 @@ function interssegm(xa,ya,xb,yb)
integer :: ierr
interssegm = .false.
call interssegm_coord(xa,ya,xb,yb,s,t,ierr)
if (ierr==0 .and. s>=zero .and. s<=one .and. &
t>=zero .and. t<=one) interssegm = .true.
if (ierr==0 .and. s>=0 .and. s<=1 .and. &
t>=0 .and. t<=1) interssegm = .true.
end function interssegm

26
src/vendor/eierf.f90 vendored
View File

@ -180,7 +180,7 @@ contains
1.99999999999048104167_wp_/)
!----------------------------------------------------------------------
x = arg
if (x == zero) then
if (x == 0) then
ei = -xinf
if (intt == 2) ei = -ei
else if ((x < zero) .or. (intt == 2)) then
@ -209,7 +209,7 @@ contains
if (intt /= 3) ei = ei * exp(-y)
else
if ((y > xbig) .and. (intt < 3)) then
ei = zero
ei = 0
else
w = one / y
sump = e(1)
@ -231,8 +231,8 @@ contains
!----------------------------------------------------------------------
t = x + x
t = t / three - two
px(1) = zero
qx(1) = zero
px(1) = 0
qx(1) = 0
px(2) = p(1)
qx(2) = q(1)
do i = 2, 9
@ -262,14 +262,14 @@ contains
if (intt == 3) ei = exp(-x) * ei
end if
else if (x < twelve) then
frac = zero
frac = 0
do i = 1, 9
frac = s(i) / (r(i) + x + frac)
end do
ei = (r(10) + frac) / x
if (intt /= 3) ei = ei * exp(x)
else if (x <= two4) then
frac = zero
frac = 0
do i = 1, 9
frac = q1(i) / (p1(i) + x + frac)
end do
@ -280,7 +280,7 @@ contains
ei = xinf
else
y = one / x
frac = zero
frac = 0
do i = 1, 9
frac = q2(i) / (p2(i) + x + frac)
end do
@ -532,7 +532,7 @@ contains
1.99999999999048104167_wp_/)
!----------------------------------------------------------------------
x = arg
if (x == zero) then
if (x == 0) then
ei = -xinf
else if ((x < zero)) then
!----------------------------------------------------------------------
@ -574,8 +574,8 @@ contains
!----------------------------------------------------------------------
t = x + x
t = t / three - two
px(1) = zero
qx(1) = zero
px(1) = 0
qx(1) = 0
px(2) = p(1)
qx(2) = q(1)
do i = 2, 9
@ -603,20 +603,20 @@ contains
ei = exp(-x) * (sump / (sumq*(x+x0)) + frac) * xmx0
end if
else if (x < twelve) then
frac = zero
frac = 0
do i = 1, 9
frac = s(i) / (r(i) + x + frac)
end do
ei = (r(10) + frac) / x
else if (x <= two4) then
frac = zero
frac = 0
do i = 1, 9
frac = q1(i) / (p1(i) + x + frac)
end do
ei = (p1(10) + frac) / x
else
y = one / x
frac = zero
frac = 0
do i = 1, 9
frac = q2(i) / (p2(i) + x + frac)
end do

156
src/vendor/minpack.f90 vendored
View File

@ -48,7 +48,6 @@ module minpack
contains
pure subroutine hybrj1(fcn,n,x,fvec,fjac,ldfjac,tol,info,wa,lwa)
use const_and_precisions, only : zero, one
! arguments
integer, intent(in) :: n, ldfjac, lwa
integer, intent(out) :: info
@ -166,7 +165,7 @@ contains
!
! check the input parameters for errors.
!
if (n <= 0 .or. ldfjac < n .or. tol < zero &
if (n <= 0 .or. ldfjac < n .or. tol < 0 &
.or. lwa < (n*(n + 13))/2) return
!
! call hybrj.
@ -175,7 +174,7 @@ contains
xtol = tol
mode = 2
do j = 1, n
wa(j) = one
wa(j) = 1
end do
nprint = 0
lr = (n*(n + 1))/2
@ -188,7 +187,7 @@ contains
pure subroutine hybrj(fcn,n,x,fvec,fjac,ldfjac,xtol,maxfev,diag,mode, &
factor,nprint,info,nfev,njev,r,lr,qtf,wa1,wa2, &
wa3,wa4)
use const_and_precisions, only : zero, one, epsmch=>comp_eps
use const_and_precisions, only : epsmch=>comp_eps
use, intrinsic :: ieee_exceptions, only : ieee_get_halting_mode, &
ieee_set_halting_mode, &
ieee_invalid
@ -373,12 +372,12 @@ contains
!
! check the input parameters for errors.
!
if (n <= 0 .or. ldfjac < n .or. xtol < zero &
.or. maxfev <= 0 .or. factor <= zero &
if (n <= 0 .or. ldfjac < n .or. xtol < 0 &
.or. maxfev <= 0 .or. factor <= 0 &
.or. lr < (n*(n + 1))/2) go to 300
if (mode == 2) then
do j = 1, n
if (diag(j) <= zero) go to 300
if (diag(j) <= 0) go to 300
end do
end if
!
@ -422,7 +421,7 @@ contains
if (mode /= 2) then
do j = 1, n
diag(j) = wa2(j)
if (wa2(j) == zero) diag(j) = one
if (wa2(j) == 0) diag(j) = 1
end do
end if
!
@ -434,7 +433,7 @@ contains
end do
xnorm = enorm(n,wa3)
delta = factor*xnorm
if (delta == zero) delta = factor
if (delta == 0) delta = factor
end if
!
! form (q transpose)*fvec and store in qtf.
@ -443,8 +442,8 @@ contains
qtf(i) = fvec(i)
end do
do j = 1, n
if (fjac(j,j) /= zero) then
summ = zero
if (fjac(j,j) /= 0) then
summ = 0
do i = j, n
summ = summ + fjac(i,j)*qtf(i)
end do
@ -466,7 +465,7 @@ contains
l = l + n - i
end do
r(l) = wa1(j)
if (wa1(j) == zero) sing = .true.
if (wa1(j) == 0) sing = .true.
end do
!
! accumulate the orthogonal factor in fjac.
@ -520,14 +519,14 @@ contains
!
! compute the scaled actual reduction.
!
actred = -one
if (fnorm1 < fnorm) actred = one - (fnorm1/fnorm)**2
actred = -1
if (fnorm1 < fnorm) actred = 1 - (fnorm1/fnorm)**2
!
! compute the scaled predicted reduction.
!
l = 1
do i = 1, n
summ = zero
summ = 0
do j = i, n
summ = summ + r(l)*wa1(j)
l = l + 1
@ -535,14 +534,14 @@ contains
wa3(i) = qtf(i) + summ
end do
temp = enorm(n,wa3)
prered = zero
if (temp < fnorm) prered = one - (temp/fnorm)**2
prered = 0
if (temp < fnorm) prered = 1 - (temp/fnorm)**2
!
! compute the ratio of the actual to the predicted
! reduction.
!
ratio = zero
if (prered > zero) ratio = actred/prered
ratio = 0
if (prered > 0) ratio = actred/prered
!
! update the step bound.
!
@ -554,7 +553,7 @@ contains
ncfail = 0
ncsuc = ncsuc + 1
if (ratio >= p5 .or. ncsuc > 1) delta = dmax1(delta,pnorm/p5)
if (abs(ratio-one) <= p1) delta = pnorm/p5
if (abs(ratio-1) <= p1) delta = pnorm/p5
end if
!
! test for successful iteration.
@ -582,7 +581,7 @@ contains
!
! test for convergence.
!
if (delta <= xtol*xnorm .or. fnorm == zero) info = 1
if (delta <= xtol*xnorm .or. fnorm == 0) info = 1
if (info /= 0) go to 300
!
! tests for termination and stringent tolerances.
@ -601,7 +600,7 @@ contains
! and update qtf if necessary.
!
do j = 1, n
summ = zero
summ = 0
do i = 1, n
summ = summ + fjac(i,j)*wa4(i)
end do
@ -638,7 +637,7 @@ contains
end subroutine hybrj
pure subroutine dogleg(n,r,lr,diag,qtb,delta,x,wa1,wa2)
use const_and_precisions, only : zero, one, epsmch=>comp_eps
use const_and_precisions, only : epsmch=>comp_eps
! arguments
integer, intent(in) :: n, lr
real(wp_), intent(in) :: delta, r(lr), diag(n), qtb(n)
@ -712,20 +711,20 @@ contains
jp1 = j + 1
jj = jj - k
l = jj + 1
summ = zero
summ = 0
do i = jp1, n
summ = summ + r(l)*x(i)
l = l + 1
end do
temp = r(jj)
if (temp == zero) then
if (temp == 0) then
l = j
do i = 1, j
temp = dmax1(temp,abs(r(l)))
l = l + n - i
end do
temp = epsmch*temp
if (temp == zero) temp = epsmch
if (temp == 0) temp = epsmch
end if
x(j) = (qtb(j) - summ)/temp
end do
@ -733,7 +732,7 @@ contains
! test whether the gauss-newton direction is acceptable.
!
do j = 1, n
wa1(j) = zero
wa1(j) = 0
wa2(j) = diag(j)*x(j)
end do
qnorm = enorm(n,wa2)
@ -756,9 +755,9 @@ contains
! the special case in which the scaled gradient is zero.
!
gnorm = enorm(n,wa1)
sgnorm = zero
sgnorm = 0
alpha = delta/qnorm
if (gnorm /= zero) then
if (gnorm /= 0) then
!
! calculate the point along the scaled gradient
! at which the quadratic is minimized.
@ -768,7 +767,7 @@ contains
end do
l = 1
do j = 1, n
summ = zero
summ = 0
do i = j, n
summ = summ + r(l)*wa1(i)
l = l + 1
@ -780,7 +779,7 @@ contains
!
! test whether the scaled gradient direction is acceptable.
!
alpha = zero
alpha = 0
if (sgnorm < delta) then
!
! the scaled gradient direction is not acceptable.
@ -791,22 +790,21 @@ contains
temp = (bnorm/gnorm)*(bnorm/qnorm)*(sgnorm/delta)
temp = temp - (delta/qnorm)*(sgnorm/delta)**2 &
+ sqrt((temp-(delta/qnorm))**2 &
+(one-(delta/qnorm)**2)*(one-(sgnorm/delta)**2))
alpha = ((delta/qnorm)*(one - (sgnorm/delta)**2))/temp
+(1-(delta/qnorm)**2)*(1-(sgnorm/delta)**2))
alpha = ((delta/qnorm)*(1 - (sgnorm/delta)**2))/temp
end if
end if
!
! form appropriate convex combination of the gauss-newton
! direction and the scaled gradient direction.
!
temp = (one - alpha)*dmin1(sgnorm,delta)
temp = (1 - alpha)*dmin1(sgnorm,delta)
do j = 1, n
x(j) = temp*wa1(j) + alpha*x(j)
end do
end subroutine dogleg
pure function enorm(n,x)
use const_and_precisions, only : zero, one
real(wp_) :: enorm
integer, intent(in) :: n
real(wp_), dimension(n), intent(in) :: x
@ -850,11 +848,11 @@ contains
integer :: i
real(wp_) :: agiant,floatn,s1,s2,s3,xabs,x1max,x3max
real(wp_), parameter :: rdwarf=3.834e-20_wp_,rgiant=1.304e19_wp_
s1 = zero
s2 = zero
s3 = zero
x1max = zero
x3max = zero
s1 = 0
s2 = 0
s3 = 0
x1max = 0
x3max = 0
floatn = n
agiant = rgiant/floatn
do i = 1, n
@ -865,7 +863,7 @@ contains
! sum for large components.
!
if (xabs > x1max) then
s1 = one + s1*(x1max/xabs)**2
s1 = 1 + s1*(x1max/xabs)**2
x1max = xabs
else
s1 = s1 + (xabs/x1max)**2
@ -875,10 +873,10 @@ contains
! sum for small components.
!
if (xabs > x3max) then
s3 = one + s3*(x3max/xabs)**2
s3 = 1 + s3*(x3max/xabs)**2
x3max = xabs
else
if (xabs /= zero) s3 = s3 + (xabs/x3max)**2
if (xabs /= 0) s3 = s3 + (xabs/x3max)**2
end if
end if
else
@ -891,11 +889,11 @@ contains
!
! calculation of norm.
!
if (s1 /= zero) then
if (s1 /= 0) then
enorm = x1max*sqrt(s1+(s2/x1max)/x1max)
else
if (s2 /= zero) then
if (s2 >= x3max) enorm = sqrt(s2*(one+(x3max/s2)*(x3max*s3)))
if (s2 /= 0) then
if (s2 >= x3max) enorm = sqrt(s2*(1+(x3max/s2)*(x3max*s3)))
if (s2 < x3max) enorm = sqrt(x3max*((s2/x3max)+(x3max*s3)))
else
enorm = x3max*sqrt(s3)
@ -904,7 +902,6 @@ contains
end function enorm
pure subroutine qform(m,n,q,ldq,wa)
use const_and_precisions, only : zero, one
! arguments
integer, intent(in) :: m,n,ldq
real(wp_), intent(out) :: wa(m)
@ -956,7 +953,7 @@ contains
do j = 2, minmn
jm1 = j - 1
do i = 1, jm1
q(i,j) = zero
q(i,j) = 0
end do
end do
!
@ -965,9 +962,9 @@ contains
np1 = n + 1
do j = np1, m
do i = 1, m
q(i,j) = zero
q(i,j) = 0
end do
q(j,j) = one
q(j,j) = 1
end do
!
! accumulate q from its factored form.
@ -976,12 +973,12 @@ contains
k = minmn - l + 1
do i = k, m
wa(i) = q(i,k)
q(i,k) = zero
q(i,k) = 0
end do
q(k,k) = one
if (wa(k) /= zero) then
q(k,k) = 1
if (wa(k) /= 0) then
do j = k, m
summ = zero
summ = 0
do i = k, m
summ = summ + q(i,j)*wa(i)
end do
@ -995,7 +992,7 @@ contains
end subroutine qform
pure subroutine qrfac(m,n,a,lda,pivot,ipvt,lipvt,rdiag,acnorm,wa)
use const_and_precisions, only : zero, one, epsmch=>comp_eps
use const_and_precisions, only : zero, epsmch=>comp_eps
! arguments
integer, intent(in) :: m, n, lda, lipvt
integer, intent(out) :: ipvt(lipvt)
@ -1122,19 +1119,19 @@ contains
! j-th column of a to a multiple of the j-th unit vector.
!
ajnorm = enorm(m-j+1,a(j,j))
if (ajnorm /= zero) then
if (a(j,j) < zero) ajnorm = -ajnorm
if (ajnorm /= 0) then
if (a(j,j) < 0) ajnorm = -ajnorm
do i = j, m
a(i,j) = a(i,j)/ajnorm
end do
a(j,j) = a(j,j) + one
a(j,j) = a(j,j) + 1
!
! apply the transformation to the remaining columns
! and update the norms.
!
jp1 = j + 1
do k = jp1, n
summ = zero
summ = 0
do i = j, m
summ = summ + a(i,j)*a(i,k)
end do
@ -1142,9 +1139,9 @@ contains
do i = j, m
a(i,k) = a(i,k) - temp*a(i,j)
end do
if (pivot .and. rdiag(k) /= zero) then
if (pivot .and. rdiag(k) /= 0) then
temp = a(j,k)/rdiag(k)
rdiag(k) = rdiag(k)*sqrt(dmax1(zero,one-temp**2))
rdiag(k) = rdiag(k)*sqrt(dmax1(zero, 1-temp**2))
if (p05*(rdiag(k)/wa(k))**2 <= epsmch) then
rdiag(k) = enorm(m-j,a(jp1,k))
wa(k) = rdiag(k)
@ -1157,7 +1154,6 @@ contains
end subroutine qrfac
pure subroutine r1mpyq(m,n,a,lda,v,w)
use const_and_precisions, only : one
! arguments
integer, intent(in) :: m, n, lda
real(wp_), intent(in) :: v(n),w(n)
@ -1221,10 +1217,10 @@ contains
if (nm1 < 1) return
do nmj = 1, nm1
j = n - nmj
if (abs(v(j)) > one) cs = one/v(j)
if (abs(v(j)) > one) sn = sqrt(one-cs**2)
if (abs(v(j)) <= one) sn = v(j)
if (abs(v(j)) <= one) cs = sqrt(one-sn**2)
if (abs(v(j)) > 1) cs = 1/v(j)
if (abs(v(j)) > 1) sn = sqrt(1-cs**2)
if (abs(v(j)) <= 1) sn = v(j)
if (abs(v(j)) <= 1) cs = sqrt(1-sn**2)
do i = 1, m
temp = cs*a(i,j) - sn*a(i,n)
a(i,n) = sn*a(i,j) + cs*a(i,n)
@ -1235,10 +1231,10 @@ contains
! apply the second set of givens rotations to a.
!
do j = 1, nm1
if (abs(w(j)) > one) cs = one/w(j)
if (abs(w(j)) > one) sn = sqrt(one-cs**2)
if (abs(w(j)) <= one) sn = w(j)
if (abs(w(j)) <= one) cs = sqrt(one-sn**2)
if (abs(w(j)) > 1) cs = 1/w(j)
if (abs(w(j)) > 1) sn = sqrt(1-cs**2)
if (abs(w(j)) <= 1) sn = w(j)
if (abs(w(j)) <= 1) cs = sqrt(1-sn**2)
do i = 1, m
temp = cs*a(i,j) + sn*a(i,n)
a(i,n) = -sn*a(i,j) + cs*a(i,n)
@ -1248,7 +1244,7 @@ contains
end subroutine r1mpyq
pure subroutine r1updt(m,n,s,ls,u,v,w,sing)
use const_and_precisions, only : zero, one, giant=>comp_huge
use const_and_precisions, only : giant=>comp_huge
! arguments
integer, intent(in) :: m, n, ls
logical, intent(out) :: sing
@ -1346,8 +1342,8 @@ contains
do nmj = 1, nm1
j = n - nmj
jj = jj - (m - j + 1)
w(j) = zero
if (v(j) /= zero) then
w(j) = 0
if (v(j) /= 0) then
!
! determine a givens rotation which eliminates the
! j-th element of v.
@ -1356,8 +1352,8 @@ contains
cotan = v(n)/v(j)
sn = p5/sqrt(p25+p25*cotan**2)
cs = sn*cotan
tau = one
if (abs(cs)*giant > one) tau = one/cs
tau = 1
if (abs(cs)*giant > 1) tau = 1/cs
else
tn = v(j)/v(n)
cs = p5/sqrt(p25+p25*tn**2)
@ -1393,7 +1389,7 @@ contains
!
sing = .false.
do j = 1, nm1
if (w(j) /= zero) then
if (w(j) /= 0) then
!
! determine a givens rotation which eliminates the
! j-th element of the spike.
@ -1402,8 +1398,8 @@ contains
cotan = s(jj)/w(j)
sn = p5/sqrt(p25+p25*cotan**2)
cs = sn*cotan
tau = one
if (abs(cs)*giant > one) tau = one/cs
tau = 1
if (abs(cs)*giant > 1) tau = 1/cs
else
tn = w(j)/s(jj)
cs = p5/sqrt(p25+p25*tn**2)
@ -1429,7 +1425,7 @@ contains
!
! test for zero diagonal elements in the output s.
!
if (s(jj) == zero) sing = .true.
if (s(jj) == 0) sing = .true.
jj = jj + (m - j + 1)
end do
!
@ -1440,7 +1436,7 @@ contains
s(l) = w(i)
l = l + 1
end do
if (s(jj) == zero) sing = .true.
if (s(jj) == 0) sing = .true.
!
end subroutine r1updt

28
src/vendor/numint.f90 vendored
View File

@ -1,6 +1,6 @@
module numint
use const_and_precisions, only : wp_, zero, one
use const_and_precisions, only : wp_
implicit none
@ -16,10 +16,10 @@ contains
integer :: i
real(wp_) :: s0,s1,s2
s = zero
s0 = zero
s1 = zero
s2 = zero
s = 0
s0 = 0
s1 = 0
s2 = 0
do i = 2, n-1, 2
s1 = s1+fi(i-1)
s0 = s0+fi(i)
@ -39,7 +39,7 @@ contains
real(wp_), intent(out) :: s
integer :: i
s = zero
s = 0
do i = 1, n-1
s = s+(xi(i+1)-xi(i))*(fi(i+1)-fi(i))
end do
@ -110,11 +110,11 @@ contains
!
! initialize running sums to zero.
!
flag = zero
result = zero
cor11 = zero
errest = zero
area = zero
flag = 0
result = 0
cor11 = 0
errest = 0
area = 0
nofun = 0
if (a .eq. b) return
!
@ -124,7 +124,7 @@ contains
nim = 1
x0 = a
x(16) = b
qprev = zero
qprev = 0
f0 = fun(x0)
stone = (b - a) / 16.0_wp_
x(8) = (x0 + x(16)) / 2.0_wp_
@ -174,7 +174,7 @@ contains
!
! current level is levmax.
!
flag = flag + one
flag = flag + 1
exit
end if
if (nofun .gt. nofin) then
@ -243,7 +243,7 @@ contains
!
! make sure errest not less than roundoff level.
!
if (errest .eq. zero) return
if (errest .eq. 0) return
do
temp = abs(result) + errest
if (temp .ne. abs(result)) return