moved all the definitions of arithmetical, physical and type kind constants in const_and_precisions. Changed argument from tekev to mu in spitzer function subroutines.
This commit is contained in:
parent
045c581865
commit
e31f05e9a8
11
Makefile
11
Makefile
@ -4,7 +4,7 @@ EXE=gray
|
||||
# Objects list
|
||||
MAINOBJ=gray.o
|
||||
OTHOBJ=dqagmv.o grayl.o reflections.o green_func_p.o \
|
||||
const_and_precisions.o itm_constants.o itm_types.o
|
||||
const_and_precisions.o
|
||||
|
||||
# Alternative search paths
|
||||
vpath %.f90 src
|
||||
@ -23,17 +23,16 @@ $(EXE): $(MAINOBJ) $(OTHOBJ)
|
||||
$(FC) $(FFLAGS) -o $@ $^
|
||||
|
||||
# Dependencies on modules
|
||||
gray.o: dqagmv.o green_func_p.o reflections.o
|
||||
gray.o: dqagmv.o green_func_p.o reflections.o const_and_precisions.o
|
||||
green_func_p.o: const_and_precisions.o
|
||||
const_and_precisions.o: itm_types.o itm_constants.o
|
||||
itm_constants.o: itm_types.o
|
||||
reflections.o: const_and_precisions.o
|
||||
|
||||
# General object compilation command
|
||||
%.o: %.f90
|
||||
$(FC) $(FFLAGS) -c $^
|
||||
$(FC) $(FFLAGS) -c $<
|
||||
|
||||
%.o: %.f
|
||||
$(FC) $(FFLAGS) -c $^
|
||||
$(FC) $(FFLAGS) -c $<
|
||||
|
||||
gray.o:gray.f
|
||||
$(FC) -cpp $(DIRECTIVES) $(FFLAGS) -c $<
|
||||
|
@ -1,17 +1,21 @@
|
||||
!########################################################################!
|
||||
|
||||
MODULE const_and_precisions
|
||||
use itm_types, only : wp_ => r8
|
||||
use itm_constants, only : pi => itm_pi, e_ => itm_qe, me_ => itm_me, c_ => itm_c
|
||||
!########################################################################!
|
||||
IMPLICIT NONE
|
||||
PUBLIC
|
||||
!------------------------------------------------------------------------
|
||||
! common precisions
|
||||
!------------------------------------------------------------------------
|
||||
! INTEGER, PARAMETER :: sp_ = 4 ! single precision
|
||||
! INTEGER, PARAMETER :: dp_ = 8 ! double precision
|
||||
! INTEGER, PARAMETER :: wp_ = dp_ ! work-precision
|
||||
! INTEGER, PARAMETER :: i1 = SELECTED_INT_KIND (2) ! Integer*1
|
||||
! INTEGER, PARAMETER :: i2 = SELECTED_INT_KIND (4) ! Integer*2
|
||||
INTEGER, PARAMETER :: i4 = SELECTED_INT_KIND (9) ! Integer*4
|
||||
INTEGER, PARAMETER :: i8 = SELECTED_INT_KIND (18) ! Integer*8
|
||||
INTEGER, PARAMETER :: r4 = SELECTED_REAL_KIND (6, 37) ! Real*4
|
||||
INTEGER, PARAMETER :: r8 = SELECTED_REAL_KIND (15, 300) ! Real*8
|
||||
! INTEGER, PARAMETER :: sp_ = r4 ! single precision
|
||||
! INTEGER, PARAMETER :: dp_ = r8 ! double precision
|
||||
INTEGER, PARAMETER :: wp_ = r8 ! work-precision
|
||||
! INTEGER, PARAMETER :: odep_ = dp_ ! ODE-solver precision
|
||||
! INTEGER, PARAMETER :: xp_ = wp_ ! for ext. modules if necessary
|
||||
!------------------------------------------------------------------------
|
||||
@ -26,31 +30,33 @@
|
||||
!!========================================================================
|
||||
! Arithmetic constants
|
||||
!========================================================================
|
||||
integer, parameter :: izero = 0
|
||||
REAL(wp_), PARAMETER :: zero = 0.0_wp_
|
||||
REAL(wp_), PARAMETER :: unit = 1.0_wp_
|
||||
! REAL(wp_), PARAMETER :: pi = 3.141592653589793_wp_
|
||||
! REAL(wp_), PARAMETER :: sqrt_pi = 1.772453850905516_wp_
|
||||
REAL(wp_), PARAMETER :: one = 1.0_wp_
|
||||
real(wp_), parameter :: pi = 3.141592653589793_wp_ ! 3.141592653589793238462643383280
|
||||
REAL(wp_), PARAMETER :: sqrt_pi = 1.772453850905516_wp_
|
||||
! REAL(wp_), PARAMETER :: sqrt_2 = 1.414213562373095_wp_
|
||||
! REAL(wp_), PARAMETER :: rad = pi/180.0_wp_
|
||||
REAL(wp_), PARAMETER :: degree = pi/180.0_wp_
|
||||
REAL(wp_), PARAMETER :: emn1 = 0.367879441171442_wp_ ! exp(-1)
|
||||
!---
|
||||
! REAL(wp_), PARAMETER :: ex(1:3) = (/unit,zero,zero/)
|
||||
! REAL(wp_), PARAMETER :: ey(1:3) = (/zero,unit,zero/)
|
||||
! REAL(wp_), PARAMETER :: ez(1:3) = (/zero,zero,unit/)
|
||||
! REAL(wp_), PARAMETER :: ex(1:3) = (/one ,zero,zero/)
|
||||
! REAL(wp_), PARAMETER :: ey(1:3) = (/zero,one ,zero/)
|
||||
! REAL(wp_), PARAMETER :: ez(1:3) = (/zero,zero,one /)
|
||||
!---
|
||||
! REAL(wp_), PARAMETER :: kron(3,3) = reshape((/unit,zero,zero, &
|
||||
! zero,unit,zero, &
|
||||
! zero,zero,unit/),(/3,3/))
|
||||
! COMPLEX(wp_), PARAMETER :: im = (0.0_wp_,1.0_wp_)
|
||||
! COMPLEX(wp_), PARAMETER :: czero = (0.0_wp_,0.0_wp_)
|
||||
! COMPLEX(wp_), PARAMETER :: cunit = (1.0_wp_,0.0_wp_)
|
||||
! REAL(wp_), PARAMETER :: kron(3,3) = reshape((/one ,zero,zero, &
|
||||
! zero,one ,zero, &
|
||||
! zero,zero,one /),(/3,3/))
|
||||
COMPLEX(wp_), PARAMETER :: im = (0.0_wp_,1.0_wp_)
|
||||
COMPLEX(wp_), PARAMETER :: czero = (0.0_wp_,0.0_wp_)
|
||||
COMPLEX(wp_), PARAMETER :: cunit = (1.0_wp_,0.0_wp_)
|
||||
! COMPLEX(wp_), PARAMETER :: ctwo = (2.0_wp_,0.0_wp_)
|
||||
!========================================================================
|
||||
! Computer constants
|
||||
!========================================================================
|
||||
REAL(wp_), PARAMETER :: comp_eps = EPSILON(unit)
|
||||
REAL(wp_), PARAMETER :: comp_eps = EPSILON(one)
|
||||
! REAL(wp_), PARAMETER :: comp_eps2 = comp_eps**2
|
||||
! REAL(wp_), PARAMETER :: comp_tiny = TINY(unit)
|
||||
! REAL(wp_), PARAMETER :: comp_huge = HUGE(unit)
|
||||
REAL(wp_), PARAMETER :: comp_tiny = TINY(one)
|
||||
REAL(wp_), PARAMETER :: comp_huge = HUGE(one)
|
||||
! REAL(wp_), PARAMETER :: comp_tinylog =-200 ! LOG10(comp_tiny)
|
||||
! REAL(wp_), PARAMETER :: comp_hugelog =+200 ! LOG10(comp_huge)
|
||||
! REAL(wp_), PARAMETER :: comp_tiny1 = 1d+50*comp_tiny
|
||||
@ -60,23 +66,39 @@
|
||||
!------------------------------------------------------------------------
|
||||
! Conventional constants
|
||||
!------------------------------------------------------------------------
|
||||
INTEGER, PARAMETER :: int_invalid = -999999999
|
||||
REAL(R8), PARAMETER :: r8_invalid = -9.0e40_r8
|
||||
! REAL(wp_), PARAMETER :: output_tiny = 1.0d-66
|
||||
! REAL(wp_), PARAMETER :: output_huge = 1.0d+66
|
||||
!========================================================================
|
||||
! Physical constants (SI)
|
||||
!========================================================================
|
||||
! REAL(wp_), PARAMETER :: e_ = 1.602176487d-19 ! [C]
|
||||
! REAL(wp_), PARAMETER :: me_ = 9.10938215d-31 ! [kg]
|
||||
! REAL(wp_), PARAMETER :: mp_ = 1.672621637d-27 ! [kg]
|
||||
! REAL(wp_), PARAMETER :: rmpe_ = mp_/me_
|
||||
! REAL(wp_), PARAMETER :: c_ = 2.99792458d+08 ! [m/s]
|
||||
! REAL(wp_), PARAMETER :: eps0_ = 8.854187817d-12 ! [F/m]
|
||||
real (wp_), parameter :: e_ = 1.602176487e-19_wp_ ! elementary charge, C
|
||||
real (wp_), parameter :: me_ = 9.10938215e-31_wp_ ! electron mass, kg
|
||||
! real (wp_), parameter :: mp_ = 1.672621637e-27_wp_ ! proton mass, kg
|
||||
! real (wp_), parameter :: md_ = 3.34358320e-27_wp_ ! deuteron mass, kg
|
||||
! real (wp_), parameter :: mt_ = 5.00735588e-27_wp_ ! triton mass, kg
|
||||
! real (wp_), parameter :: ma_ = 6.64465620e-27_wp_ ! alpha mass, kg
|
||||
! real (wp_), parameter :: amu_ = 1.660538782e-27_wp_ ! amu, kg
|
||||
! REAL (wp_), PARAMETER :: rmpe_ = mp_/me_ ! proton-electron mass ratio
|
||||
real (wp_), parameter :: c_ = 2.99792458e8_wp_ ! speed of light, m/s
|
||||
real (wp_), parameter :: mu0_ = 4.0e-7_wp_ * pi ! magnetic permeability of vacuum
|
||||
real (wp_), parameter :: eps0_ = 1.0_wp_ / (mu0_ * c_**2) ! dielectric constant of vacuum, F/m
|
||||
! real (wp_), parameter :: avogr = 6.02214179e23_wp_
|
||||
! real (wp_), parameter :: KBolt = 1.3806504e-23_wp_
|
||||
!========================================================================
|
||||
! Physical constants (cgs)
|
||||
!========================================================================
|
||||
real (wp_), parameter :: ccgs_ = c_*1.e2_wp_ ! speed of light, cm/s
|
||||
real (wp_), parameter :: mecgs_ = me_*1.e3_wp_ ! electron mass, g
|
||||
real (wp_), parameter :: ecgs_ = e_*c_*10._wp_ ! elementary charge, statcoul
|
||||
!------------------------------------------------------------------------
|
||||
! Useful definitions
|
||||
!------------------------------------------------------------------------
|
||||
REAL(wp_), PARAMETER :: keV_ = 1000*e_ ! [J]
|
||||
REAL(wp_), PARAMETER :: keV_ = 1.e3_wp_*e_ ! [J]
|
||||
REAL(wp_), PARAMETER :: mc2_SI = me_*c_**2 ! [J]
|
||||
REAL(wp_), PARAMETER :: mc2_ = mc2_SI/keV_ ! [keV]
|
||||
REAL(wp_), PARAMETER :: mu0inv = 1._wp_/mu0_ !
|
||||
! REAL(wp_), PARAMETER :: mc_ = me_*c_ ! [kg*m/s]
|
||||
! ! f_ce = fce1_*B (B in Tesla): !
|
||||
! REAL(wp_), PARAMETER :: wce1_ = e_/me_ ! [rad/s]
|
||||
@ -100,6 +122,33 @@
|
||||
! REAL(wp_), PARAMETER :: Npar_min = 1.0d-3
|
||||
!########################################################################!
|
||||
|
||||
interface is_valid
|
||||
module procedure is_valid_int4, is_valid_int8, is_valid_real8
|
||||
end interface
|
||||
|
||||
contains
|
||||
|
||||
logical function is_valid_int4(in_int)
|
||||
implicit none
|
||||
integer(i4), intent(in) :: in_int
|
||||
is_valid_int4 = in_int /= int_invalid
|
||||
return
|
||||
end function is_valid_int4
|
||||
|
||||
logical function is_valid_int8(in_int)
|
||||
implicit none
|
||||
integer(i8), intent(in) :: in_int
|
||||
is_valid_int8 = in_int /= int_invalid
|
||||
return
|
||||
end function is_valid_int8
|
||||
|
||||
logical function is_valid_real8(in_real)
|
||||
implicit none
|
||||
real(r8), intent(in) :: in_real
|
||||
is_valid_real8 = abs(in_real - r8_invalid) > abs(r8_invalid) * 1.0e-15_r8
|
||||
return
|
||||
end function is_valid_real8
|
||||
|
||||
END MODULE const_and_precisions
|
||||
|
||||
!########################################################################!
|
||||
|
164
src/gray.f
164
src/gray.f
@ -109,8 +109,8 @@ c ray integration: end
|
||||
|
||||
|
||||
subroutine after_gray_integration
|
||||
use const_and_precisions, only : zero
|
||||
implicit real*8 (a-h,o-z)
|
||||
parameter(zero=0.0d0)
|
||||
character*255 filenmeqq,filenmprf,filenmbm
|
||||
c
|
||||
common/ss/st
|
||||
@ -176,11 +176,12 @@ c
|
||||
c
|
||||
c
|
||||
subroutine after_onestep(i,istop)
|
||||
use const_and_precisions, only : pi, cvdr=>degree
|
||||
use reflections, only : inside
|
||||
implicit real*8 (a-h,o-z)
|
||||
complex*16 ext,eyt,extr,eytr,exin2,eyin2
|
||||
parameter(jmx=31,kmx=36,nmx=8000,nbb=5000)
|
||||
parameter(taucr=12.0d0,pi=3.14159265358979d0,cvdr=pi/180.0d0)
|
||||
parameter(taucr=12.0d0)
|
||||
dimension psjki(jmx,kmx,nmx),ppabs(jmx,kmx,nmx),ccci(jmx,kmx,nmx)
|
||||
dimension iiv(jmx,kmx),tauv(jmx,kmx,nmx),alphav(jmx,kmx,nmx)
|
||||
dimension iop(jmx,kmx),iow(jmx,kmx),ihcd(jmx,kmx),istore(jmx,kmx)
|
||||
@ -471,10 +472,10 @@ c
|
||||
c
|
||||
c
|
||||
subroutine print_output(i,j,k)
|
||||
use const_and_precisions, only : pi
|
||||
implicit real*8 (a-h,o-z)
|
||||
parameter(ndim=6,jmx=31,kmx=36,nmx=8000)
|
||||
parameter(taucr=12.0d0)
|
||||
parameter(pi=3.14159265358979d0)
|
||||
dimension ywrk(ndim,jmx,kmx),ypwrk(ndim,jmx,kmx)
|
||||
dimension psjki(jmx,kmx,nmx)
|
||||
dimension tauv(jmx,kmx,nmx),alphav(jmx,kmx,nmx)
|
||||
@ -648,14 +649,13 @@ c
|
||||
c
|
||||
c
|
||||
subroutine read_data
|
||||
use const_and_precisions, only : qe=>ecgs_,me=>mecgs_,vc=>ccgs_,
|
||||
* cvdr=>degree,pi
|
||||
use green_func_p, only:Setup_SpitzFunc
|
||||
implicit real*8 (a-h,o-z)
|
||||
real*8 me
|
||||
character*8 wdat
|
||||
character*10 wtim
|
||||
character*255 filenmeqq,filenmprf,filenmbm
|
||||
parameter(qe=4.8032d-10,me=9.1095d-28,vc=2.9979d+10)
|
||||
parameter(pi=3.14159265358979d0,cvdr=pi/180.0d0)
|
||||
parameter(nmx=8000,nbb=5000)
|
||||
real*8 rlim(nbb),zlim(nbb)
|
||||
c
|
||||
@ -1031,8 +1031,8 @@ c
|
||||
c
|
||||
c
|
||||
subroutine surf_anal
|
||||
use const_and_precisions, only : pi
|
||||
implicit real*8(a-h,o-z)
|
||||
parameter(pi=3.14159265358979d0)
|
||||
common/parban/b0,rr0m,zr0m,rpam
|
||||
common/parbres/bres
|
||||
c
|
||||
@ -1183,9 +1183,9 @@ c
|
||||
c
|
||||
c
|
||||
subroutine equidata
|
||||
use const_and_precisions, only : pi
|
||||
implicit real*8 (a-h,o-z)
|
||||
parameter(nnw=501,nnh=501)
|
||||
parameter(pi=3.14159265358979d0)
|
||||
parameter(nbb=5000)
|
||||
c parameter(np=100)
|
||||
character*48 stringa
|
||||
@ -2270,8 +2270,8 @@ c
|
||||
c
|
||||
c
|
||||
subroutine contours_psi(h,np,rcn,zcn,ipr)
|
||||
use const_and_precisions, only : pi
|
||||
implicit real*8 (a-h,o-z)
|
||||
parameter(pi=3.14159265358979d0)
|
||||
parameter(mest=4,kspl=3)
|
||||
parameter(nnw=501,nnh=501)
|
||||
parameter(nrest=nnw+4,nzest=nnh+4)
|
||||
@ -2335,12 +2335,11 @@ c
|
||||
c
|
||||
c
|
||||
subroutine flux_average
|
||||
use const_and_precisions, only : zero,one,pi,ccj=>mu0inv
|
||||
implicit real*8 (a-h,o-z)
|
||||
real*8 lam
|
||||
|
||||
parameter(nnintp=101,ncnt=100,ncntt=2*ncnt+1,nlam=41)
|
||||
parameter(zero=0.0d0,one=1.0d0)
|
||||
parameter(pi=3.14159265358979d0,ccj=1.0d+7/(4.0d0*pi))
|
||||
parameter(ksp=3,njest=nnintp+ksp+1,nlest=nlam+ksp+1)
|
||||
parameter(lwrk=4*(nnintp+nlam)+11*(njest+nlest)+
|
||||
. njest*nnintp+nlest+54)
|
||||
@ -3404,8 +3403,8 @@ c
|
||||
c
|
||||
c
|
||||
subroutine plas_deriv(xx,yy,zz)
|
||||
use const_and_precisions, only : pi
|
||||
implicit real*8 (a-h,o-z)
|
||||
parameter(pi=3.14159265358979d0)
|
||||
dimension bv(3),derxg(3),deryg(3),derbv(3,3),dbtot(3)
|
||||
dimension bvc(3),dbvcdc(3,3),dbvdc(3,3),dbv(3,3)
|
||||
c
|
||||
@ -3786,8 +3785,8 @@ c
|
||||
|
||||
c
|
||||
subroutine tor_curr(rpsim,zpsim,ajphi)
|
||||
use const_and_precisions, only : pi,ccj=>mu0inv
|
||||
implicit real*8 (a-h,o-z)
|
||||
parameter(pi=3.14159265358979d0,ccj=1.0d+7/(4.0d0*pi))
|
||||
common/derip/dpsidr,dpsidz,ddpsidrr,ddpsidzz,ddpsidrz,fpolv,ffpv
|
||||
call equinum(rpsim,zpsim)
|
||||
bzz= dpsidr/rpsim
|
||||
@ -3960,10 +3959,10 @@ c
|
||||
c beam tracing initial conditions igrad=1
|
||||
c
|
||||
subroutine ic_gb
|
||||
use const_and_precisions, only : izero,zero,one,pi,cvdr=>degree
|
||||
implicit real*8 (a-h,o-z)
|
||||
parameter(ndim=6,ndimm=3)
|
||||
parameter(jmx=31,kmx=36,zero=0.0d0,izero=0,one=1.0d0)
|
||||
parameter(pi=3.14159265358979d0,cvdr=pi/180.0d0)
|
||||
parameter(jmx=31,kmx=36)
|
||||
dimension ywrk0(ndim,jmx,kmx),ypwrk0(ndim,jmx,kmx)
|
||||
dimension ytmp(ndim),yptmp(ndim)
|
||||
dimension xc0(ndimm,jmx,kmx),du10(ndimm,jmx,kmx)
|
||||
@ -4275,12 +4274,11 @@ c
|
||||
c ray tracing initial conditions igrad=0
|
||||
c
|
||||
subroutine ic_rt
|
||||
use const_and_precisions, only : izero,zero,one,pi,cvdr=>degree,
|
||||
* ui=>im
|
||||
implicit real*8 (a-h,o-z)
|
||||
complex*16 ui
|
||||
parameter(ndim=6,ndimm=3)
|
||||
parameter(jmx=31,kmx=36,zero=0.0d0,izero=0,one=1.0d0)
|
||||
parameter(pi=3.14159265358979d0,cvdr=pi/180.0d0)
|
||||
parameter(ui=(0.0d0,1.0d0))
|
||||
parameter(jmx=31,kmx=36)
|
||||
dimension ywrk0(ndim,jmx,kmx),ypwrk0(ndim,jmx,kmx)
|
||||
dimension ytmp(ndim),yptmp(ndim)
|
||||
dimension xc0(ndimm,jmx,kmx),du10(ndimm,jmx,kmx)
|
||||
@ -4472,10 +4470,10 @@ c
|
||||
|
||||
|
||||
subroutine ic_rt2
|
||||
use const_and_precisions, only : izero,zero,one,pi,cvdr=>degree
|
||||
implicit real*8 (a-h,o-z)
|
||||
parameter(ndim=6,ndimm=3)
|
||||
parameter(jmx=31,kmx=36,zero=0.0d0,izero=0,one=1.0d0)
|
||||
parameter(pi=3.14159265358979d0,cvdr=pi/180.0d0)
|
||||
parameter(jmx=31,kmx=36)
|
||||
dimension ywrk0(ndim,jmx,kmx),ypwrk0(ndim,jmx,kmx)
|
||||
dimension ytmp(ndim),yptmp(ndim)
|
||||
dimension yyrfl(jmx,kmx,ndim)
|
||||
@ -4685,9 +4683,9 @@ c
|
||||
c
|
||||
c
|
||||
subroutine pabs_curr(i,j,k)
|
||||
use const_and_precisions, only : pi
|
||||
implicit real*8 (a-h,o-z)
|
||||
parameter(jmx=31,kmx=36,nmx=8000)
|
||||
parameter(pi=3.14159265358979d0)
|
||||
dimension psjki(jmx,kmx,nmx)
|
||||
dimension tauv(jmx,kmx,nmx),alphav(jmx,kmx,nmx)
|
||||
dimension pdjki(jmx,kmx,nmx),ppabs(jmx,kmx,nmx)
|
||||
@ -4764,12 +4762,11 @@ c
|
||||
c
|
||||
c
|
||||
subroutine ecrh_cd
|
||||
use const_and_precisions, only : eqsi=>e_,mesi=>me_,vcsi=>c_,
|
||||
* mc2=>mc2_
|
||||
implicit real*8 (a-h,o-z)
|
||||
real*8 mc2,mesi
|
||||
parameter(taucr=12.0d0,xxcr=16.0d0,eps=1.d-8)
|
||||
parameter(qesi=1.602176487d-19,mesi=9.10938215d-31)
|
||||
parameter(vcsi=2.99792458d+8)
|
||||
parameter(mc2 = mesi*vcsi*vcsi/qesi*1d-3)
|
||||
complex*16 ex,ey,ez
|
||||
c
|
||||
common/nharm/nharm,nhf
|
||||
common/warm/iwarm,ilarm
|
||||
@ -4781,16 +4778,22 @@ c
|
||||
common/parwv/ak0,akinv,fhz
|
||||
c
|
||||
common/nprw/anprre,anprim
|
||||
common/epolar/ex,ey,ez
|
||||
c
|
||||
common/absor/alpha,effjcd,akim,tau
|
||||
c
|
||||
common/ierr/ierr
|
||||
common/iokh/iokhawa
|
||||
c
|
||||
|
||||
common/psival/psinv
|
||||
common/tete/tekev
|
||||
common/dens/dens,ddens
|
||||
common/amut/amu
|
||||
common/zz/Zeff
|
||||
common/btot/btot
|
||||
common/bmxmn/bmax,bmin
|
||||
common/fc/fc
|
||||
c
|
||||
c absorption computation
|
||||
c
|
||||
@ -4852,8 +4855,12 @@ c ratiovgr=2.0d0*anpr/derdnm*vgm
|
||||
c
|
||||
ithn=1
|
||||
if(lrm.gt.nharm) ithn=2
|
||||
if(ieccd.gt.0) call eccd(yg,anpl,anprre,amu,zeff,
|
||||
* ieccd,nharm,nhf,ithn,effjcd,iokhawa,ierr)
|
||||
if(ieccd.gt.0) then
|
||||
rbn=btot/bmin
|
||||
rbx=btot/bmax
|
||||
call eccd(yg,anpl,anprre,amu,zeff,rbn,rbx,fc,ex,ey,ez,
|
||||
* dens,psinv,ieccd,nharm,nhf,ithn,effjcd,iokhawa,ierr)
|
||||
end if
|
||||
|
||||
return
|
||||
999 format(12(1x,e12.5))
|
||||
@ -5011,13 +5018,11 @@ c computation of dielectric tensor elements
|
||||
c up to third order in Larmor radius for hermitian part
|
||||
c
|
||||
subroutine diel_tens_fr(e330,epsl,lrm)
|
||||
use const_and_precisions, only : pi,rpi=>sqrt_pi,ui=>im
|
||||
implicit real*8(a-h,o-z)
|
||||
complex*16 ui
|
||||
complex*16 e330,epsl(3,3,lrm)
|
||||
complex*16 ca11,ca12,ca22,ca13,ca23,ca33
|
||||
complex*16 cq0p,cq0m,cq1p,cq1m,cq2p
|
||||
parameter(pi=3.14159265358979d0,rpi=1.77245385090552d0)
|
||||
parameter(ui=(0.0d0,1.0d0))
|
||||
dimension rr(-lrm:lrm,0:2,0:lrm),ri(lrm,0:2,lrm)
|
||||
c
|
||||
common/xgxg/xg
|
||||
@ -5455,10 +5460,9 @@ c
|
||||
c
|
||||
c
|
||||
subroutine antihermitian(ri,lrm)
|
||||
use const_and_precisions, only : rpi=>sqrt_pi
|
||||
implicit none
|
||||
integer lmx,nmx,lrm,n,k,m,mm
|
||||
real*8 rpi
|
||||
parameter(rpi=1.77245385090552d0)
|
||||
parameter(lmx=20,nmx=lmx+2)
|
||||
real*8 fsbi(nmx)
|
||||
real*8 ri(lrm,0:2,lrm)
|
||||
@ -5581,10 +5585,10 @@ c computation of dielectric tensor elements
|
||||
c Krivenki and Orefice, JPP 30,125 (1983)
|
||||
c
|
||||
subroutine diel_tens_wr(ce330,cepsl,lrm)
|
||||
use const_and_precisions, only : cui=>im
|
||||
implicit real*8 (a-b,d-h,o-z)
|
||||
implicit complex*16 (c)
|
||||
dimension cefp(0:lrm,0:2),cefm(0:lrm,0:2),cepsl(3,3,lrm)
|
||||
parameter(cui=(0.0d0,1.0d0))
|
||||
c
|
||||
common/xgxg/xg
|
||||
common/ygyg/yg
|
||||
@ -5651,10 +5655,10 @@ c
|
||||
c
|
||||
c
|
||||
subroutine fsup(cefp,cefm,lrm)
|
||||
use const_and_precisions, only : cui=>im
|
||||
implicit real*8 (a-b,d-h,o-z)
|
||||
implicit complex*16 (c)
|
||||
parameter(apsicr=0.7d0)
|
||||
parameter(cui=(0.0d0,1.0d0))
|
||||
dimension cefp(0:lrm,0:2),cefm(0:lrm,0:2)
|
||||
c
|
||||
common/ygyg/yg
|
||||
@ -5796,42 +5800,32 @@ c
|
||||
|
||||
|
||||
|
||||
subroutine eccd(yg,anpl,anprre,amu,zeff,
|
||||
* ieccd,nhmn,nhmx,ithn,effjcd,iokhawa,ierr)
|
||||
use green_func_p, only: SpitzFuncCoeff,pi
|
||||
subroutine eccd(yg,anpl,anprre,amu,zeff,rbn,rbx,fc,ex,ey,ez,
|
||||
* dens,psinv,ieccd,nhmn,nhmx,ithn,effjcd,iokhawa,ierr)
|
||||
use green_func_p, only: SpitzFuncCoeff
|
||||
use const_and_precisions, only : pi,qesi=>e_,mesi=>me_,vcsi=>c_,
|
||||
* qe=>ecgs_,me=>mecgs_,vc=>ccgs_,mc2=>mc2_
|
||||
implicit none
|
||||
real*8 anum,denom,resp,resj,effjcd,coullog,dens,tekev
|
||||
real*8 anum,denom,resp,resj,effjcd,coullog,dens
|
||||
real*8 yg,anpl,anpr,amu,anprre,anprim
|
||||
real*8 mc2,anucc,canucc,ddens
|
||||
real*8 qesi,mesi,vcsi,qe,me,vc,ceff,Zeff,psinv
|
||||
real*8 rbn,rbx,btot,bmin,bmax,alams,fp0s,pa,fc
|
||||
real*8 mc2m2,anucc,canucc,ddens
|
||||
real*8 ceff,Zeff,psinv
|
||||
real*8 rbn,rbx,alams,fp0s,pa,fc
|
||||
real*8 fjch,fjncl,fjch0,fconic
|
||||
real*8 cst2,eccdpar(5)
|
||||
complex*16 ex,ey,ez
|
||||
integer ieccd,nhmn,nhmx,nhn,ithn,ierr,iokhawa
|
||||
external fjch,fjncl,fjch0
|
||||
|
||||
parameter(qesi=1.602176487d-19,mesi=9.10938215d-31)
|
||||
parameter(vcsi=2.99792458d+8)
|
||||
parameter(qe=4.8032068d-10,me=mesi*1.d3,vc=vcsi*1.d2)
|
||||
parameter(mc2=mesi*vcsi*vcsi/qesi*1d-3)
|
||||
parameter(mc2m2=1.0d0/mc2**2)
|
||||
parameter(canucc=2.0d13*pi*qe**4/(me**2*vc**3))
|
||||
parameter(ceff=qesi/(mesi*vcsi))
|
||||
|
||||
common/psival/psinv
|
||||
|
||||
common/dens/dens,ddens
|
||||
common/epolar/ex,ey,ez
|
||||
common/btot/btot
|
||||
common/bmxmn/bmax,bmin
|
||||
common/fc/fc
|
||||
|
||||
anum=0.0d0
|
||||
denom=0.0d0
|
||||
effjcd=0.0d0
|
||||
|
||||
tekev=mc2/amu
|
||||
coullog=48.0d0-log(1.0d7*dens/tekev**2)
|
||||
coullog=48.0d0-log(1.0d7*dens*mc2m2*amu**2)
|
||||
anucc=canucc*dens*coullog
|
||||
|
||||
c nhmx=nhmn
|
||||
@ -5848,11 +5842,9 @@ c cst2=1.0d0-B/B_max
|
||||
c alams=sqrt(1-B_min/B_max)
|
||||
c Zeff < 31 !!!
|
||||
c fp0s= P_a (alams)
|
||||
rbn=btot/bmin
|
||||
rbx=btot/bmax
|
||||
cst2=1.0d0-rbx
|
||||
if(cst2.lt.1d-6) cst2=0.0d0
|
||||
alams=sqrt(1.0d0-bmin/bmax)
|
||||
alams=sqrt(1.0d0-rbx/rbn)
|
||||
pa=sqrt(32.0d0/(Zeff+1.0d0)-1.0d0)/2.0d0
|
||||
fp0s=fconic(alams,pa,0)
|
||||
eccdpar(2)=rbn
|
||||
@ -5879,18 +5871,15 @@ c fp0s= P_a (alams)
|
||||
c neoclassical model:
|
||||
c ft=1-fc trapped particle fraction
|
||||
c rzfc=(1+Zeff)/fc
|
||||
rbn=btot/bmin
|
||||
rbx=btot/bmax
|
||||
cst2=1.0d0-rbx
|
||||
if(cst2.lt.1d-6) cst2=0.0d0
|
||||
call SpitzFuncCoeff(Tekev,Zeff,fc)
|
||||
eccdpar(2) = tekev
|
||||
eccdpar(3) = fc
|
||||
eccdpar(4) = rbx
|
||||
eccdpar(5) = psinv
|
||||
call SpitzFuncCoeff(amu,Zeff,fc)
|
||||
eccdpar(2) = fc
|
||||
eccdpar(3) = rbx
|
||||
eccdpar(4) = psinv
|
||||
do nhn=nhmn,nhmx
|
||||
call curr_int(yg,anpl,anprre,amu,ex,ey,ez,nhn,ithn,cst2,
|
||||
* fjncl,eccdpar,5,resj,resp,iokhawa,ierr)
|
||||
* fjncl,eccdpar,4,resj,resp,iokhawa,ierr)
|
||||
anum=anum+resj
|
||||
denom=denom+resp
|
||||
end do
|
||||
@ -6071,9 +6060,9 @@ c extrapar(13) = uplp
|
||||
c extrapar(14) = uplm
|
||||
c extrapar(15) = ygn
|
||||
c
|
||||
use const_and_precisions, only : ui=>im
|
||||
implicit real*8 (a-h,o-z)
|
||||
complex*16 ex,ey,ez,ui,emxy,epxy
|
||||
parameter(ui=(0.0d0,1.0d0))
|
||||
complex*16 ex,ey,ez,emxy,epxy
|
||||
dimension extrapar(npar)
|
||||
|
||||
yg=extrapar(1)
|
||||
@ -6293,10 +6282,9 @@ c extrapar(14) = uplm
|
||||
c extrapar(15) = ygn
|
||||
c
|
||||
c extrapar(16) = zeff
|
||||
c extrapar(17) = tekev
|
||||
c extrapar(18) = fc
|
||||
c extrapar(19) = hb
|
||||
c extrapar(20) = psin
|
||||
c extrapar(17) = fc
|
||||
c extrapar(18) = hb
|
||||
c extrapar(29) = psin
|
||||
c
|
||||
use green_func_p, only: GenSpitzFunc
|
||||
implicit real*8 (a-h,o-z)
|
||||
@ -6306,10 +6294,9 @@ c
|
||||
amu=extrapar(3)
|
||||
ygn=extrapar(15)
|
||||
zeff=extrapar(16)
|
||||
tekev=extrapar(17)
|
||||
fc=extrapar(18)
|
||||
hb=extrapar(19)
|
||||
psin=extrapar(20)
|
||||
fc=extrapar(17)
|
||||
hb=extrapar(18)
|
||||
psin=extrapar(19)
|
||||
|
||||
gam=anpl*upl+ygn
|
||||
u2=gam*gam-1.0d0
|
||||
@ -6317,7 +6304,7 @@ c
|
||||
upr2=u2-upl*upl
|
||||
bth=sqrt(2.0d0/amu)
|
||||
uth=u/bth
|
||||
call GenSpitzFunc(Tekev,Zeff,fc,uth,u,gam,fk,dfk)
|
||||
call GenSpitzFunc(amu,Zeff,fc,uth,u,gam,fk,dfk)
|
||||
fk=fk*(4.0d0/amu**2)
|
||||
dfk=dfk*(2.0d0/amu)*bth
|
||||
|
||||
@ -6450,10 +6437,10 @@ c
|
||||
c
|
||||
c
|
||||
subroutine pec(pabs,currt)
|
||||
use const_and_precisions, only : pi,one
|
||||
implicit real*8(a-h,o-z)
|
||||
parameter(nndmx=5001,jmx=31,kmx=36,nmx=8000)
|
||||
parameter(rtbc=1.0d0)
|
||||
parameter(pi=3.14159265358979d0)
|
||||
parameter(rtbc=one)
|
||||
dimension psjki(jmx,kmx,nmx),iiv(jmx,kmx)
|
||||
dimension ppabs(jmx,kmx,nmx),ccci(jmx,kmx,nmx)
|
||||
dimension pdjki(jmx,kmx,nmx),currj(jmx,kmx,nmx)
|
||||
@ -6810,8 +6797,8 @@ c
|
||||
c
|
||||
c
|
||||
subroutine profwidth(nd,xx,yy,rhotmx,rhopmx,ypk,drhot,drhop)
|
||||
use const_and_precisions, only : emn1
|
||||
implicit real*8(a-h,o-z)
|
||||
parameter(emn1=0.367879441171442d0)
|
||||
dimension xx(nd),yy(nd)
|
||||
common/jmxmn/rhotp,rhotm,ypkp,ypkm
|
||||
common/ipec/ipec,nnd
|
||||
@ -6973,15 +6960,15 @@ c
|
||||
end
|
||||
|
||||
subroutine pol_limit(ext,eyt)
|
||||
use const_and_precisions, only : ui=>im,pi
|
||||
implicit none
|
||||
real*8 bv(3),anv(3)
|
||||
real*8 anx,any,anz,anpl,anpr,yg,xe2om,ye2om,xe2xm,ye2xm
|
||||
real*8 an2,an,anxy,sngam,csgam,csg2,sng2,ffo,ffx,ffo2,ffx2
|
||||
real*8 deno,denx,anpl2,dnl,del0
|
||||
real*8 pi,beta0,alpha0,gam
|
||||
real*8 beta0,alpha0,gam
|
||||
real*8 sox
|
||||
complex*16 ui,exom,eyom,exxm,eyxm,ext,eyt
|
||||
parameter(ui=(0.0d0,1.0d0),pi=3.14159265358979d0)
|
||||
complex*16 exom,eyom,exxm,eyxm,ext,eyt
|
||||
c
|
||||
common/anv/anv
|
||||
common/nplr/anpl,anpr
|
||||
@ -7043,11 +7030,10 @@ c
|
||||
end subroutine stokes
|
||||
|
||||
subroutine polellipse(qq,uu,vv,psipol,chipol)
|
||||
use const_and_precisions, only : pi
|
||||
implicit none
|
||||
real*8 qq,uu,vv,psipol,chipol
|
||||
c real*8 llm,aa,bb,ell
|
||||
real*8 pi
|
||||
parameter(pi=3.14159265358979d0)
|
||||
c llm=sqrt(qq**2+uu**2)
|
||||
c aa=sqrt((1+llm)/2.0d0)
|
||||
c bb=sqrt((1-llm)/2.0d0)
|
||||
@ -7089,14 +7075,14 @@ c ell=bb/aa
|
||||
subroutine wall_refl(xv,anv,ext,eyt,xvrfl,anvrfl,extr,eytr,walln,
|
||||
. irfl)
|
||||
use reflections, only : inters_linewall,inside
|
||||
use const_and_precisions, only : ui=>im,pi
|
||||
implicit none
|
||||
integer*4 irfl
|
||||
real*8 anv(3),anv0(3),xv(3),xvrfl(3)
|
||||
real*8 walln(3),anvrfl(3),vv1(3),vv2(3),vv3(3)
|
||||
real*8 pi,smax,rrm,zzm
|
||||
complex*16 ui,extr,eytr,eztr,ext,eyt
|
||||
real*8 smax,rrm,zzm
|
||||
complex*16 extr,eytr,eztr,ext,eyt
|
||||
complex*16 evin(3),evrfl(3)
|
||||
parameter(ui=(0.0d0,1.0d0),pi=3.14159265358979d0)
|
||||
integer nbb,nlim
|
||||
parameter(nbb=5000)
|
||||
real*8 rlim(nbb),zlim(nbb)
|
||||
|
@ -107,8 +107,7 @@
|
||||
END SUBROUTINE Setup_SpitzFunc
|
||||
|
||||
|
||||
SUBROUTINE GenSpitzFunc(Te,Zeff,fc,u,q,gam, K,dKdu)
|
||||
|
||||
SUBROUTINE GenSpitzFunc(mu,Zeff,fc,u,q,gam, K,dKdu)
|
||||
!=======================================================================
|
||||
! Author: N.B.Marushchenko
|
||||
! June 2005: as start point the subroutine of Ugo Gasparino (198?)
|
||||
@ -172,15 +171,14 @@
|
||||
! dKdu = dK/du, i.e. its derivative over normalized momentum
|
||||
!=======================================================================
|
||||
IMPLICIT NONE
|
||||
REAL(wp_), INTENT(in) :: Te,Zeff,fc,u,q,gam
|
||||
REAL(wp_), INTENT(in) :: mu,Zeff,fc,u,q,gam
|
||||
REAL(wp_), INTENT(out) :: K,dKdu
|
||||
REAL(wp_) :: mu,gam1,gam2,gam3,w,dwdu
|
||||
REAL(wp_) :: gam1,gam2,gam3,w,dwdu
|
||||
!=======================================================================
|
||||
K = 0
|
||||
dKdu = 0
|
||||
IF (u < comp_eps) RETURN
|
||||
!---
|
||||
mu = mc2_/max(Te,1d-3)
|
||||
SELECT CASE(adj_appr(2))
|
||||
CASE('m') !--------------- momentum conservation ------------------!
|
||||
gam1 = gam !
|
||||
@ -210,7 +208,7 @@
|
||||
!#######################################################################
|
||||
!#######################################################################
|
||||
|
||||
SUBROUTINE SpitzFuncCoeff(Te,Zeff,fc)
|
||||
SUBROUTINE SpitzFuncCoeff(mu,Zeff,fc)
|
||||
!=======================================================================
|
||||
! Calculates the matrix coefficients required for the subroutine
|
||||
! "GenSpitzFunc", where the Spitzer function is defined through the
|
||||
@ -228,7 +226,7 @@
|
||||
! INPUT VARIABLES:
|
||||
! rho = sqrt(SS) with SS - flux-surface label (norm. magn. flux)
|
||||
! ne - density, 1/m^3
|
||||
! Te - temperature, keV
|
||||
! mu - mc2/Te
|
||||
! Zeff - effective charge
|
||||
! fc - fraction of circulating particles
|
||||
!
|
||||
@ -237,9 +235,9 @@
|
||||
! "Spitzer"-function (the same as in the Hirshman paper)
|
||||
!=======================================================================
|
||||
IMPLICIT NONE
|
||||
REAL(wp_), INTENT(in) :: Te,Zeff,fc
|
||||
REAL(wp_), INTENT(in) :: mu,Zeff,fc
|
||||
INTEGER :: n,i,j
|
||||
REAL(wp_) :: rtc,rtc1,mu,y,tn(1:nre)
|
||||
REAL(wp_) :: rtc,rtc1,y,tn(1:nre)
|
||||
REAL(wp_) :: m(0:4,0:4),g(0:4)
|
||||
REAL(wp_) :: om(0:4,0:4)
|
||||
REAL(wp_) :: gam11,gam21,gam31,gam41,gam01, &
|
||||
@ -250,17 +248,17 @@
|
||||
alp23,alp24,alp20, &
|
||||
alp34,alp30,alp40
|
||||
REAL(wp_) :: bet0,bet1,bet2,bet3,bet4,d0
|
||||
LOGICAL :: renew,rel,newTe,newne,newZ,newfc
|
||||
LOGICAL :: renew,rel,newmu,newne,newZ,newfc
|
||||
REAL(wp_), SAVE :: sfdx(1:4) = 0
|
||||
REAL(wp_), SAVE :: ne_old =-1, Te_old =-1, Zeff_old =-1, fc_old =-1
|
||||
REAL(wp_), SAVE :: ne_old =-1, mu_old =-1, Zeff_old =-1, fc_old =-1
|
||||
!=======================================================================
|
||||
rel = Te > 1
|
||||
newTe = abs(Te -Te_old ) > delta*Te
|
||||
rel = mu < mc2_
|
||||
newmu = abs(mu -mu_old ) > delta*mu
|
||||
newZ = abs(Zeff-Zeff_old) > delta*Zeff
|
||||
newfc = abs(fc -fc_old ) > delta*fc
|
||||
SELECT CASE(adj_appr(1))
|
||||
CASE ('l','c')
|
||||
renew = (newTe .and. rel) .OR. newZ .OR. newfc
|
||||
renew = (newmu .and. rel) .OR. newZ .OR. newfc
|
||||
END SELECT
|
||||
!---
|
||||
IF (.not.renew) THEN
|
||||
@ -271,7 +269,7 @@
|
||||
tn(:) = 0
|
||||
IF (adj_appr(4) == 'r') THEN
|
||||
IF (nre > 0) THEN
|
||||
mu = mc2_/max(Te,1d-3)
|
||||
!mu = min(mu,1.e3*mc2_)
|
||||
tn(1) = 1/mu
|
||||
DO n=2,min(2,nre)
|
||||
tn(n) = tn(n-1)/mu
|
||||
@ -359,7 +357,7 @@
|
||||
sfd(1) = bet1-alp10*d0-alp14*sfd(4)-alp13*sfd(3)-alp12*sfd(2)
|
||||
!=======================================================================
|
||||
fc_old = fc
|
||||
Te_old = Te
|
||||
mu_old = mu
|
||||
Zeff_old = Zeff
|
||||
!---
|
||||
sfdx(1:4) = sfd(1:4)
|
||||
@ -405,7 +403,7 @@
|
||||
q2 = q*q ! for the integrand, HSL_f
|
||||
gp1 = gam+1 ! ..
|
||||
!---
|
||||
CALL quanc8(HSL_f,zero,unit,atol,rtol,Integr,err,nfun,flag)
|
||||
CALL quanc8(HSL_f,zero,one,atol,rtol,Integr,err,nfun,flag)
|
||||
!=======================================================================
|
||||
gam2 = gam*gam
|
||||
!---
|
||||
|
@ -1,32 +0,0 @@
|
||||
!> Module implementing the ITM physics constants
|
||||
!>
|
||||
!> Source:
|
||||
!> based on SOLPS b2mod_constants.F
|
||||
!> '09/12/07 xpb : source CODATA 2006 (http://www.nist.gov/)'
|
||||
!> pulled from ets r100
|
||||
!>
|
||||
!> \author David Coster
|
||||
!>
|
||||
!> \version "$Id: itm_constants.f90 37 2009-08-17 17:15:00Z coster $"
|
||||
|
||||
module itm_constants
|
||||
|
||||
use itm_types
|
||||
|
||||
real (kind = R8), parameter :: itm_pi = 3.141592653589793238462643383280_R8
|
||||
real (kind = R8), parameter :: itm_c = 2.99792458e8_R8 ! speed of light, m/s
|
||||
real (kind = R8), parameter :: itm_me = 9.10938215e-31_R8 ! electron mass, kg
|
||||
real (kind = R8), parameter :: itm_mp = 1.672621637e-27_R8 ! proton mass, kg
|
||||
real (kind = R8), parameter :: itm_md = 3.34358320e-27_R8 ! deuteron mass, kg
|
||||
real (kind = R8), parameter :: itm_mt = 5.00735588e-27_R8 ! triton mass, kg
|
||||
real (kind = R8), parameter :: itm_ma = 6.64465620e-27_R8 ! alpha mass, kg
|
||||
real (kind = R8), parameter :: itm_amu = 1.660538782e-27_R8 ! amu, kg
|
||||
real (kind = R8), parameter :: itm_ev = 1.602176487e-19_R8
|
||||
real (kind = R8), parameter :: itm_qe = itm_ev
|
||||
real (kind = R8), parameter :: itm_mu0 = 4.0e-7_R8 * itm_pi
|
||||
real (kind = R8), parameter :: itm_eps0 = 1.0_R8 / (itm_mu0 * itm_c * itm_c)
|
||||
real (kind = R8), parameter :: itm_avogr = 6.02214179e23_R8
|
||||
real (kind = R8), parameter :: itm_KBolt = 1.3806504e-23_R8
|
||||
character (len=64), parameter :: itm_constants_version = '$Id: itm_constants.f90 37 2009-08-17 17:15:00Z coster $'
|
||||
|
||||
end module itm_constants
|
@ -1,50 +0,0 @@
|
||||
!> Module implementing the ITM basic types
|
||||
!>
|
||||
!> Source:
|
||||
!> based on SOLPS b2mod_types.F
|
||||
!> pulled from ets r100 and extended with input from C. Konz, T. Ribeiro & B. Scott
|
||||
!>
|
||||
!> \author David Coster
|
||||
!>
|
||||
!> \version "$Id: itm_types.f90 144 2010-10-07 09:26:24Z konz $"
|
||||
|
||||
module itm_types
|
||||
|
||||
INTEGER, PARAMETER :: ITM_I1 = SELECTED_INT_KIND (2) ! Integer*1
|
||||
INTEGER, PARAMETER :: ITM_I2 = SELECTED_INT_KIND (4) ! Integer*2
|
||||
INTEGER, PARAMETER :: ITM_I4 = SELECTED_INT_KIND (9) ! Integer*4
|
||||
INTEGER, PARAMETER :: ITM_I8 = SELECTED_INT_KIND (18) ! Integer*8
|
||||
INTEGER, PARAMETER :: R4 = SELECTED_REAL_KIND (6, 37) ! Real*4
|
||||
INTEGER, PARAMETER :: R8 = SELECTED_REAL_KIND (15, 300) ! Real*8
|
||||
|
||||
INTEGER, PARAMETER :: itm_int_invalid = -999999999
|
||||
REAL(R8), PARAMETER :: itm_r8_invalid = -9.0D40
|
||||
|
||||
interface itm_is_valid
|
||||
module procedure itm_is_valid_int4, itm_is_valid_int8, itm_is_valid_real8
|
||||
end interface
|
||||
|
||||
contains
|
||||
|
||||
logical function itm_is_valid_int4(in_int)
|
||||
implicit none
|
||||
integer(ITM_I4) in_int
|
||||
itm_is_valid_int4 = in_int .ne. itm_int_invalid
|
||||
return
|
||||
end function itm_is_valid_int4
|
||||
|
||||
logical function itm_is_valid_int8(in_int)
|
||||
implicit none
|
||||
integer(ITM_I8) in_int
|
||||
itm_is_valid_int8 = in_int .ne. itm_int_invalid
|
||||
return
|
||||
end function itm_is_valid_int8
|
||||
|
||||
logical function itm_is_valid_real8(in_real)
|
||||
implicit none
|
||||
real(R8) in_real
|
||||
itm_is_valid_real8 = abs(in_real - itm_r8_invalid) .gt. abs(itm_r8_invalid) * 1.0e-15_R8
|
||||
return
|
||||
end function itm_is_valid_real8
|
||||
|
||||
end module itm_types
|
@ -1,21 +1,20 @@
|
||||
module reflections
|
||||
use const_and_precisions, only : wp_, comp_tiny, comp_eps, comp_huge, zero, one
|
||||
implicit none
|
||||
private
|
||||
integer, parameter :: r8=selected_real_kind(15,300)
|
||||
real(r8), parameter :: tinyr8=tiny(1._r8)
|
||||
public :: reflect,inters_linewall,inside
|
||||
public :: linecone_coord,interssegm_coord,interssegm
|
||||
contains
|
||||
|
||||
subroutine reflect(ki,nsurf,ko)
|
||||
implicit none
|
||||
real(r8), intent(in), dimension(3) :: ki
|
||||
real(r8), intent(in), dimension(3) :: nsurf
|
||||
real(r8), intent(out), dimension(3) :: ko
|
||||
real(r8) :: twokn,norm2
|
||||
real(wp_), intent(in), dimension(3) :: ki
|
||||
real(wp_), intent(in), dimension(3) :: nsurf
|
||||
real(wp_), intent(out), dimension(3) :: ko
|
||||
real(wp_) :: twokn,norm2
|
||||
norm2 = dot_product(nsurf,nsurf)
|
||||
if (norm2>0.0_r8) then
|
||||
twokn = 2.0_r8*dot_product(ki,nsurf)/norm2
|
||||
if (norm2>zero) then
|
||||
twokn = 2.0_wp_*dot_product(ki,nsurf)/norm2
|
||||
ko=ki-twokn*nsurf
|
||||
else
|
||||
ko=ki
|
||||
@ -24,19 +23,19 @@ end subroutine reflect
|
||||
|
||||
subroutine inters_linewall(xv,kv,rw,zw,nw,sint,normw)
|
||||
implicit none
|
||||
real(r8), intent(in), dimension(3) :: xv,kv
|
||||
real(wp_), intent(in), dimension(3) :: xv,kv
|
||||
integer, intent(in) :: nw
|
||||
real(r8), dimension(nw), intent(in) :: rw,zw
|
||||
real(r8), intent(out) :: sint
|
||||
real(r8), dimension(3), intent(out) :: normw
|
||||
real(wp_), dimension(nw), intent(in) :: rw,zw
|
||||
real(wp_), intent(out) :: sint
|
||||
real(wp_), dimension(3), intent(out) :: normw
|
||||
integer :: i,j,ni,iint
|
||||
real(r8), dimension(2) :: si,ti
|
||||
real(r8) :: drw,dzw,xint,yint,rint,l,kxy
|
||||
real(r8) :: tol
|
||||
tol=sqrt(epsilon(1.0_r8))
|
||||
sint=huge(sint)
|
||||
real(wp_), dimension(2) :: si,ti
|
||||
real(wp_) :: drw,dzw,xint,yint,rint,l,kxy
|
||||
real(wp_) :: tol
|
||||
tol=sqrt(comp_eps)
|
||||
sint=comp_huge
|
||||
iint=0
|
||||
normw=0.0_r8
|
||||
normw=zero
|
||||
do i=1,nw-1
|
||||
!search intersections with i-th wall segment
|
||||
call linecone_coord(xv,kv,rw(i:i+1),zw(i:i+1),si,ti,ni)
|
||||
@ -47,7 +46,7 @@ subroutine inters_linewall(xv,kv,rw,zw,nw,sint,normw)
|
||||
ti(1) = ti(2)
|
||||
end do
|
||||
do j=1,ni
|
||||
if ((si(j)<sint .or. iint==0) .and. ti(j)>=0._r8 .and. ti(j)<=1._r8) then
|
||||
if ((si(j)<sint .or. iint==0) .and. ti(j)>=zero .and. ti(j)<=one) then
|
||||
!check intersection is in r,z range and keep the closest
|
||||
sint = si(j)
|
||||
iint = i
|
||||
@ -64,7 +63,7 @@ subroutine inters_linewall(xv,kv,rw,zw,nw,sint,normw)
|
||||
l = sqrt(drw**2+dzw**2)
|
||||
kxy = sqrt(kv(1)**2+kv(2)**2)
|
||||
normw(3) = -drw/l
|
||||
if (rint>0.0_r8) then
|
||||
if (rint>zero) then
|
||||
normw(1) = xint/rint*dzw/l
|
||||
normw(2) = yint/rint*dzw/l
|
||||
else
|
||||
@ -72,17 +71,17 @@ subroutine inters_linewall(xv,kv,rw,zw,nw,sint,normw)
|
||||
normw(2) = kv(2)/kxy*dzw/l
|
||||
end if
|
||||
!reverse normal if k.n>0
|
||||
if (dot_product(normw,kv)>0.0_r8) normw=-normw
|
||||
if (dot_product(normw,kv)>zero) normw=-normw
|
||||
end subroutine inters_linewall
|
||||
|
||||
subroutine linecone_coord(xv,kv,rs,zs,s,t,n)
|
||||
implicit none
|
||||
real(r8), intent(in), dimension(3) :: xv,kv
|
||||
real(r8), intent(in), dimension(2) :: rs,zs
|
||||
real(r8), dimension(2), intent(out) :: s,t
|
||||
real(wp_), intent(in), dimension(3) :: xv,kv
|
||||
real(wp_), intent(in), dimension(2) :: rs,zs
|
||||
real(wp_), dimension(2), intent(out) :: s,t
|
||||
integer, intent(out) :: n
|
||||
real(r8) :: x0,y0,z0,kx,ky,kz
|
||||
real(r8) :: dr,dz,r,a,bhalf,c,delta,tvertex,zvertex,srmin,rmin,zrmin
|
||||
real(wp_) :: x0,y0,z0,kx,ky,kz
|
||||
real(wp_) :: dr,dz,r,a,bhalf,c,delta,tvertex,zvertex,srmin,rmin,zrmin
|
||||
x0=xv(1)
|
||||
y0=xv(2)
|
||||
z0=xv(3)
|
||||
@ -93,9 +92,9 @@ subroutine linecone_coord(xv,kv,rs,zs,s,t,n)
|
||||
dz = zs(2)-zs(1)
|
||||
s = 0
|
||||
t = 0
|
||||
if (abs(dz)<tinyr8) then
|
||||
if (abs(dz)<comp_tiny) then
|
||||
!surface in horizontal plane
|
||||
if (abs(kz)<tinyr8 .or. abs(dr)<tinyr8) then
|
||||
if (abs(kz)<comp_tiny .or. abs(dr)<comp_tiny) then
|
||||
n = 0
|
||||
else
|
||||
s(1) = (zs(1)-z0)/kz
|
||||
@ -107,9 +106,9 @@ subroutine linecone_coord(xv,kv,rs,zs,s,t,n)
|
||||
a = (kx**2+ky**2) - (dr/dz*kz)**2
|
||||
bhalf = -dr/dz*kz*rs(1) + (kx*x0 + ky*y0) - (dr/dz)**2*kz*(z0-zs(1))
|
||||
c = (x0**2+y0**2) - (rs(1) + dr/dz*(z0-zs(1)))**2
|
||||
if (abs(a)<tinyr8) then
|
||||
if (abs(a)<comp_tiny) then
|
||||
!line parallel to cone generator
|
||||
if (abs(dr)<tinyr8) then
|
||||
if (abs(dr)<comp_tiny) then
|
||||
!cylinder and vertical line
|
||||
n = 0
|
||||
else
|
||||
@ -118,14 +117,14 @@ subroutine linecone_coord(xv,kv,rs,zs,s,t,n)
|
||||
srmin = -(kx*x0 + ky*y0)/(kx**2+ky**2)
|
||||
rmin = sqrt((x0+srmin*kx)**2+(y0+srmin*ky)**2)
|
||||
zrmin = z0 + srmin*kz
|
||||
if (rmin<tinyr8 .and. abs(zrmin-zvertex)<tinyr8) then
|
||||
if (rmin<comp_tiny .and. abs(zrmin-zvertex)<comp_tiny) then
|
||||
!line passing by cone vertex
|
||||
!s(1) = srmin
|
||||
!t(1) = tvertex
|
||||
!n = 1
|
||||
n = 0
|
||||
else
|
||||
s(1) = -0.5_r8*c/bhalf
|
||||
s(1) = -0.5_wp_*c/bhalf
|
||||
t(1) = (kz*s(1)+(z0-zs(1)))/dz
|
||||
n = 1
|
||||
end if
|
||||
@ -147,18 +146,18 @@ end subroutine linecone_coord
|
||||
|
||||
subroutine interssegm_coord(xa,ya,xb,yb,s,t,ierr)
|
||||
implicit none
|
||||
real(r8), dimension(2), intent(in) :: xa,ya,xb,yb
|
||||
real(r8), intent(out) :: s,t
|
||||
real(wp_), dimension(2), intent(in) :: xa,ya,xb,yb
|
||||
real(wp_), intent(out) :: s,t
|
||||
integer, intent(out) :: ierr
|
||||
real(r8) :: crossprod,dxa,dya,dxb,dyb
|
||||
real(wp_) :: crossprod,dxa,dya,dxb,dyb
|
||||
dxa = xa(2)-xa(1)
|
||||
dya = ya(2)-ya(1)
|
||||
dxb = xb(2)-xb(1)
|
||||
dyb = yb(2)-yb(1)
|
||||
crossprod = dxb*dya - dxa*dyb
|
||||
if (abs(crossprod)<tiny(crossprod)) then
|
||||
s = 0.0_r8
|
||||
t = 0.0_r8
|
||||
s = zero
|
||||
t = zero
|
||||
ierr = 1
|
||||
else
|
||||
s = (dyb*(xa(1)-xb(1)) - dxb*(ya(1)-yb(1)))/crossprod
|
||||
@ -169,25 +168,25 @@ end subroutine interssegm_coord
|
||||
|
||||
function interssegm(xa,ya,xb,yb)
|
||||
implicit none
|
||||
real(r8), dimension(2), intent(in) :: xa,ya,xb,yb
|
||||
real(wp_), dimension(2), intent(in) :: xa,ya,xb,yb
|
||||
logical :: interssegm
|
||||
real(r8) :: s,t
|
||||
real(wp_) :: s,t
|
||||
integer :: ierr
|
||||
interssegm = .false.
|
||||
call interssegm_coord(xa,ya,xb,yb,s,t,ierr)
|
||||
if (ierr==0 .and. s>=0._r8 .and. s<=1._r8 .and. &
|
||||
t>=0._r8 .and. t<=1._r8) interssegm = .true.
|
||||
if (ierr==0 .and. s>=zero .and. s<=one .and. &
|
||||
t>=zero .and. t<=one) interssegm = .true.
|
||||
end function interssegm
|
||||
|
||||
function inside(xc,yc,n,x,y)
|
||||
implicit none
|
||||
integer, intent(in) :: n
|
||||
real(r8), dimension(n), intent(in) :: xc,yc
|
||||
real(r8), intent(in) :: x,y
|
||||
real(wp_), dimension(n), intent(in) :: xc,yc
|
||||
real(wp_), intent(in) :: x,y
|
||||
logical :: inside
|
||||
integer, dimension(n) :: jint
|
||||
real(r8), dimension(n) :: xint
|
||||
real(r8), dimension(n+1) :: xclosed,yclosed
|
||||
real(wp_), dimension(n) :: xint
|
||||
real(wp_), dimension(n+1) :: xclosed,yclosed
|
||||
integer :: i,nj
|
||||
xclosed(1:n)=xc(1:n)
|
||||
yclosed(1:n)=yc(1:n)
|
||||
@ -208,19 +207,19 @@ function intlin(x1,y1,x2,y2,x) result(y)
|
||||
!linear interpolation
|
||||
!must be x1 != x2
|
||||
implicit none
|
||||
real(r8),intent(in) :: x1,y1,x2,y2,x
|
||||
real(r8) :: y
|
||||
real(r8) :: a
|
||||
real(wp_),intent(in) :: x1,y1,x2,y2,x
|
||||
real(wp_) :: y
|
||||
real(wp_) :: a
|
||||
a=(x2-x)/(x2-x1)
|
||||
y=a*y1+(1._r8-a)*y2
|
||||
y=a*y1+(one-a)*y2
|
||||
end function intlin
|
||||
|
||||
subroutine locate_unord(a,n,x,j,m,nj)
|
||||
implicit none
|
||||
integer, intent(in) :: n,m
|
||||
integer, intent(out) :: nj
|
||||
real(r8), dimension(n), intent(in) :: a
|
||||
real(r8), intent(in) :: x
|
||||
real(wp_), dimension(n), intent(in) :: a
|
||||
real(wp_), intent(in) :: x
|
||||
integer, dimension(m), intent(inout) :: j
|
||||
integer :: i
|
||||
nj=0
|
||||
@ -240,8 +239,8 @@ function locate(a,n,x) result(j)
|
||||
!j=0 or j=n indicate that x is out of range (Numerical Recipes)
|
||||
implicit none
|
||||
integer, intent(in) :: n
|
||||
real(r8), dimension(n), intent(in) :: a
|
||||
real(r8), intent(in) :: x
|
||||
real(wp_), dimension(n), intent(in) :: a
|
||||
real(wp_), intent(in) :: x
|
||||
integer :: j
|
||||
integer :: jl,ju,jm
|
||||
logical :: incr
|
||||
@ -262,8 +261,8 @@ end function locate
|
||||
subroutine order(p,q)
|
||||
!returns p,q in ascending order
|
||||
implicit none
|
||||
real(r8), intent(inout) :: p,q
|
||||
real(r8) :: temp
|
||||
real(wp_), intent(inout) :: p,q
|
||||
real(wp_) :: temp
|
||||
if (p>q) then
|
||||
temp=p
|
||||
p=q
|
||||
@ -275,7 +274,7 @@ subroutine bubble(a,n)
|
||||
!bubble sorting of array a
|
||||
implicit none
|
||||
integer, intent(in) :: n
|
||||
real(r8), dimension(n), intent(inout) :: a
|
||||
real(wp_), dimension(n), intent(inout) :: a
|
||||
integer :: i, j
|
||||
do i=1,n
|
||||
do j=n,i+1,-1
|
||||
|
Loading…
Reference in New Issue
Block a user