src/gray_jetto1beamf90: update for graycore changes

This commit is contained in:
Michele Guerini Rocco 2021-12-15 02:31:11 +01:00
parent f56e1cbc05
commit 7818ac731c
Signed by: rnhmjoj
GPG Key ID: BFBAF4C975F76450

View File

@ -1,17 +1,13 @@
subroutine gray_jetto1beam(ijetto, mr, mz, r, z, psin, psia, rax, zax, & subroutine gray_jetto1beam(ijetto, mr, mz, r, z, psin, psia, rax, zax, &
nbnd, rbnd, zbnd, nrho, psrad, fpol, te, dne, zeff, qpsi, ibeam, & nbnd, rbnd, zbnd, nrho, psrad, fpol, te, dne, zeff, qpsi, ibeam, &
p0mw, alphain, betain, dpdv, jcd, pabs, icd, ierr) p0mw, alphain, betain, dpdv, jcd, pabs, icd, error)
use const_and_precisions, only : wp_ use const_and_precisions, only: wp_
use units, only : ucenr,usumm,uprj0,uwbm,udisp,ubres,ucnt,uoutr,ueq,uprfin, & use gray_params, only: gray_parameters, gray_data, gray_results
uflx,upec,uprm,ubeam use graycore, only: gray_main
use gray_params, only : read_params,raytracing,ecrh_cd,antenna,&
equilibrium,profiles,output
use beams, only : read_beam2
use graycore, only : gray_main
use reflections, only : range2rect
use coreprofiles, only : tene_scal
implicit none implicit none
! arguments
! subroutine arguments
integer, intent(in) :: ijetto, mr, mz, nbnd, nrho, ibeam integer, intent(in) :: ijetto, mr, mz, nbnd, nrho, ibeam
real(wp_), dimension(mr), intent(in) :: r real(wp_), dimension(mr), intent(in) :: r
real(wp_), dimension(mz), intent(in) :: z real(wp_), dimension(mz), intent(in) :: z
@ -21,71 +17,133 @@ subroutine gray_jetto1beam(ijetto, mr, mz, r, z, psin, psia, rax, zax, &
real(wp_), dimension(nrho), intent(in) :: psrad, fpol, te, dne, zeff, qpsi real(wp_), dimension(nrho), intent(in) :: psrad, fpol, te, dne, zeff, qpsi
real(wp_), dimension(nrho), intent(out) :: dpdv, jcd real(wp_), dimension(nrho), intent(out) :: dpdv, jcd
real(wp_), intent(out) :: pabs, icd real(wp_), intent(out) :: pabs, icd
integer, intent(out) :: ierr integer, intent(out) :: error
! local variables
real(wp_), dimension(nrho) :: psinr
integer :: iox0
real(wp_) :: r0m,rvac,alpha0,beta0,psipol0,chipol0,rwallm
real(wp_) :: fghz,x0,y0,z0,w1,w2,ri1,ri2,phiw,phir
real(wp_), dimension(5) :: rlim,zlim
logical, save :: firstcall=.true.
type(raytracing) :: rtrp
type(ecrh_cd) :: hcdp
type(antenna) :: antp
type(equilibrium) :: eqp
type(profiles) :: prfp
type(output) :: outp
! if first call read parameters from external file ! local variables
if (firstcall) then type(gray_parameters) :: params
call read_params('gray.data',rtrp,hcdp,antp,eqp,rwallm,prfp,outp,uprm) type(gray_data) :: data
rwallm=r(1) type(gray_results) :: res
antp%filenm='graybeam.data' logical, save :: firstcall = .true.
eqp%filenm='JETTO'
eqp%iequil=ijetto+1
prfp%filenm='JETTO'
outp%ipec=1
firstcall=.false.
outp%nrho=nrho
end if
! call tene_scal(te,dne,prfp%factte,prfp%factne,eqp%factb,& ! Initialisation tasks for the first call only
! prfp%iscal,prfp%iprof) first_call: if (firstcall) then
firstcall = .false.
rvac=rax ! Read parameters from external file
psinr=psrad init_params: block
use gray_params, only : read_parameters, set_globals
call read_parameters('gray.data', params)
alpha0=alphain ! Override some parameters
beta0=betain params%misc%rwall = r(1)
call read_beam2(antp%filenm,ibeam,alpha0,beta0,fghz,antp%iox,x0,y0,z0, & params%antenna%filenm = 'graybeam.data'
w1,w2,ri1,ri2,phiw,phir,ubeam) params%equilibrium%filenm = 'JETTO'
psipol0=antp%psi params%equilibrium%iequil = ijetto + 1
chipol0=antp%chi params%profiles%filenm = 'JETTO'
iox0=antp%iox params%output%ipec = 1
params%output%nrho = nrho
! set simple limiter ! Set the global variables of `gray_params`
r0m=sqrt(x0**2+y0**2)*0.01_wp_ call set_globals(params)
call range2rect(rwallm,max(r0m,r(mr)),z(1),z(mz),rlim,zlim) end block init_params
! call main subroutine for the ibeam-th beam ! Set a simple limiter
call gray_main(r,z,psin,psia,psinr,fpol,qpsi,rvac,rax,zax,rbnd,zbnd,eqp, & simple_limiter: block
psrad,te,dne,zeff,prfp, rlim,zlim, p0mw,fghz,alpha0,beta0,(/x0,y0,z0/), & use reflections, only : range2rect
w1,w2,ri1,ri2,phiw,phir,iox0,psipol0,chipol0, dpdv,jcd,pabs,icd,outp, & use limiter, only : limiter_set_globals=>set_globals
rtrp,hcdp,ierr,sqrt(psrad))
! close output (debug) files real(wp_) :: r0m
close(ucenr) r0m = sqrt(params%antenna%pos(1)**2 + params%antenna%pos(2)**2)*0.01_wp_
close(usumm) call range2rect(params%misc%rwall, max(r0m, r(mr)), z(1), z(mz), &
close(uprj0) data%equilibrium%rlim, data%equilibrium%zlim)
close(uprj0+1) ! Set the global variables of `limiter`
close(uwbm) call limiter_set_globals(data%equilibrium)
close(udisp) end block simple_limiter
close(ubres)
close(ucnt) end if first_call
close(uoutr)
close(ueq) ! Set MHD equilibrium data
close(uprfin) init_equilibrium: block
close(uflx) use equilibrium, only : set_eqspl
close(upec)
! Copy argument arrays
data%equilibrium%rv = r
data%equilibrium%zv = z
data%equilibrium%rax = rax
data%equilibrium%rvac = rax
data%equilibrium%zax = zax
data%equilibrium%psinr = psrad
data%equilibrium%fpol = fpol
data%equilibrium%rbnd = rbnd
data%equilibrium%zbnd = zbnd
data%equilibrium%psia = psia
data%equilibrium%psin = psin
data%equilibrium%qpsi = qpsi
! Compute splines
call set_eqspl(params%equilibrium, data%equilibrium)
end block init_equilibrium
! Set plasma kinetic profiles
init_profiles: block
use coreprofiles, only : set_prfspl
! Copy argument arrays
data%profiles%derad = dne
data%profiles%terad = te
data%profiles%zfc = zeff
! Compute splines
call set_prfspl(params%profiles, data%profiles)
end block init_profiles
! Set wave launcher parameters
init_antenna: block
use beams, only: read_beam2
! Copy argument variables
params%antenna%alpha = alphain
params%antenna%beta = betain
params%antenna%power = p0mw
! Read beam description file
call read_beam2(params%antenna, beamid=ibeam)
end block init_antenna
! Call main subroutine for the ibeam-th beam
call gray_main(params, data, res, error, rhout=sqrt(psrad))
! Free memory
free_memory: block
use equilibrium, only : unset_eqspl, unset_rhospl, unset_q
use coreprofiles, only : unset_prfspl
! Unset global variables of the `equilibrium` module
call unset_eqspl
call unset_rhospl
call unset_q
! Unset global variables of the `coreprofiles` module
call unset_prfspl
end block free_memory
! Close output units used for debugging
close_debug: block
use units, only : ucenr, usumm, uprj0, uwbm, udisp, ubres, &
ucnt, uoutr, ueq, uprfin, uflx, upec
integer :: i, debug_units(13)
debug_units = [ucenr, usumm, uprj0, uprj0+1, uwbm, udisp, &
ubres, ucnt, uoutr, ueq, uprfin, uflx, upec]
do i=1,size(debug_units)
close(debug_units(i))
end do
end block close_debug
! Copy over the results
pabs = res%pabs
icd = res%icd
dpdv = res%dpdv
jcd = res%jcd
end subroutine gray_jetto1beam end subroutine gray_jetto1beam