Skip to content

Commit

Permalink
Merge branch 'cgyro_triad_energy_transfer' of https://github.com/gafu…
Browse files Browse the repository at this point in the history
…sion/gacode into cgyro_triad_energy_transfer
  • Loading branch information
NFPCjiheon committed Dec 30, 2024
2 parents 452fc95 + 75e117b commit 7903d19
Show file tree
Hide file tree
Showing 18 changed files with 1,022 additions and 1,184 deletions.
1 change: 1 addition & 0 deletions cgyro/bin/cgyro_parse.py
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@
x.add('MOMENT_PRINT_FLAG','0')
x.add('GFLUX_PRINT_FLAG','0')
x.add('FIELD_PRINT_FLAG','0')
x.add('TRIAD_PRINT_FLAG','0')
x.add('AMP0','0.0')
x.add('AMP','0.1')
x.add('GAMMA_E','0.0')
Expand Down
6 changes: 4 additions & 2 deletions cgyro/bin/cgyro_plot
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,8 @@ then
echo " = flux (time-trace of fluxes for all species)"
echo " = ky_flux (bar plot of flux versus ky)"
echo " = phi (time-dependent ZF vs. finite-n intensities)"
echo " = triad (triad energy transfer for all ky)"
echo " = triad_v2 (free energy balance of ky=0)"
echo " = ky_phi (time-dependent ky-phi intensities)"
echo " = kx_phi (average kx-phi intensities)"
echo " = kx_shift (kx-phi intensities in both domains)"
Expand Down Expand Up @@ -411,7 +413,7 @@ PYROOT=$GACODE_ROOT/f2py/pygacode/cgyro

PLT="-m pygacode.cgyro.data_plot_single $TEX $FONTSIZE"

PFLAGS="$PLOT_TYPE $LX $LY $W $NORM $EXT $TIME $FIELD $MOMENT $TMAX $THETA $YMIN $YMAX $KXMIN $KXMAX $N $ABS $FC $LOC $NSCALE $CFLUX $SPECIES $BAR $IE $MESH"
PFLAGS="$PLOT_TYPE $LX $LY $W $NORM $EXT $TIME $FIELD $MOMENT $TMAX $THETA $YMIN $YMAX $KXMIN $KXMAX $N $ABS $FC $LOC $NSCALE $CFLUX $SPECIES $BAR $IE $MESH $DN"

case "$VIS_TYPE" in

Expand Down Expand Up @@ -443,7 +445,7 @@ case "$PLOT_TYPE" in
template)
cp $PYROOT/plot_template.py . ;;

freq | ky_freq | error | geo | ball | ky_phi | phi | flux | rcorr_phi | low | zf | ky_flux | shift | corrug | kx_phi | kxky_phi | kx_shift | poly_phi | xflux | hb | hbcut | hball )
freq | ky_freq | error | geo | ball | ky_phi | phi | triad | triad_v2 | flux | rcorr_phi | low | zf | ky_flux | shift | corrug | kx_phi | kxky_phi | kx_shift | poly_phi | xflux | hb | hbcut | hball )
python $PLT $PFLAGS ;;

fluct)
Expand Down
29 changes: 29 additions & 0 deletions cgyro/bin/cgyrodb
Original file line number Diff line number Diff line change
Expand Up @@ -18,17 +18,21 @@ ignore = 'eslshared'
# Command line option parser
def opts():

<<<<<<< HEAD
mytext = '''\
output:
NEED DOCUMENTATION HERE
'''

=======
>>>>>>> 75e117b697c0d4211214ae51d6ca807d8bf5e2f6
parser = argparse.ArgumentParser(
formatter_class=argparse.RawTextHelpFormatter,
prog = 'cgyrodb',
description="CGYRO database utility",
epilog=textwrap.dedent(mytext))

<<<<<<< HEAD
parser.add_argument('-ref',
help='Refresh directories',
action='store_true')
Expand All @@ -47,6 +51,18 @@ def opts():
return args.ref,args.json,args.db,args.flux

ref,json,db,doflux = opts()
=======
parser.add_argument('-mode',
help='Mode switch (data,update)',
type=str,
default='data')

args=parser.parse_args()

return args.mode

mode = opts()
>>>>>>> 75e117b697c0d4211214ae51d6ca807d8bf5e2f6

meta = {}

Expand Down Expand Up @@ -87,6 +103,8 @@ def gendict(sim,doflux):

return mydict

ignore = 'eslshared'

# First locate all directories
y = []
for root,xd,xf in os.walk('./'):
Expand All @@ -97,6 +115,7 @@ for root,xd,xf in os.walk('./'):
if ref:
# Run through directories and update
for mdir in y:
<<<<<<< HEAD
print('Refreshing '+mdir)
os.system('cd '+mdir+' ; python $GACODE_ROOT/cgyro/bin/cgyro_parse.py')
os.system('cd '+mdir+' ; $GACODE_ROOT/cgyro/src/cgyro ')
Expand All @@ -108,6 +127,16 @@ if json:
os.system('cgyro_json -e '+mdir)

if db:
=======
<<<<<<< HEAD
print('Updating '+mdir)
os.system('cgyro_plot -plot text -e '+mdir)
=======
print('Updating '+mdir)
>>>>>>> ad9e1b42 (Added ignore feature)
os.system('cgyro -t '+mdir)
else:
>>>>>>> 75e117b697c0d4211214ae51d6ca807d8bf5e2f6
# Create master dictionary "meta"
for mdir in tqdm(y):
sim = cgyrodata(mdir+'/',silent=True)
Expand Down
40 changes: 39 additions & 1 deletion cgyro/src/cgyro_flux.f90
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ subroutine cgyro_flux
complex :: cprod
real, parameter :: x_fraction=0.2
real :: u
real :: kx

!$omp parallel do private(iv_loc,iv,is,ix,ie,dv,vpar,ic,ir,it,erot,cprod,cn) &
!$omp& private(prod1,prod2,prod3,l,icl,dvr,u,flux_norm) &
Expand Down Expand Up @@ -188,6 +189,34 @@ subroutine cgyro_flux
cflux_loc(:,:,:,itor) = cflux_loc(:,:,:,itor)+2*sin(u)*real(gflux_loc(l,:,:,:,itor))/u
enddo


!-------------------------------------------------------------
! 2-1. Compute Triad energy transfer
!-------------------------------------------------------------

kx = 2*pi*rho/length
do is=1,n_species
! Triad energy transfer : T_k
triad_loc_old(is,:,itor,1) = triad_loc(is,:,itor,1) *temp(is)/dlntdr(is_ele)
! From Nonzonal Triad energy transfer : T_k [NZ(k',k")->k]
triad_loc_old(is,:,itor,2) = triad_loc(is,:,itor,2) *temp(is)/dlntdr(is_ele)
! dEntropy / dt : dS_k/dt
triad_loc_old(is,:,itor,3) = (triad_loc(is,:,itor,3)-triad_loc_old(is,:,itor,3))/delta_t
triad_loc_old(is,:,itor,3) = triad_loc_old(is,:,itor,3) *temp(is)/dlntdr(is_ele)*0.5
! dWk_perp / dt , (ky = 0)
triad_loc_old(is,:,itor,4) = (triad_loc(is,:,itor,4)-triad_loc_old(is,:,itor,4))/delta_t
triad_loc_old(is,:,itor,4) = triad_loc_old(is,:,itor,4) *(kx*lambda_star)**2/dlntdr(is_ele)*0.5
! Entropy : S_k
triad_loc_old(is,:,itor,5) = triad_loc(is,:,itor,3) *temp(is)/dlntdr(is_ele)*0.5
! Diss. (radial)
triad_loc_old(is,:,itor,6) = triad_loc(is,:,itor,5) *temp(is)/dlntdr(is_ele)
! Diss. (theta )
triad_loc_old(is,:,itor,7) = triad_loc(is,:,itor,6) *temp(is)/dlntdr(is_ele)
! Diss. (Coll. )
triad_loc_old(is,:,itor,8) = triad_loc(is,:,itor,7) *temp(is)/dlntdr(is_ele)
enddo


!-----------------------------------------------------
! 3. Renormalize fluxes to GB or quasilinear forms
!~----------------------------------------------------
Expand Down Expand Up @@ -216,7 +245,7 @@ subroutine cgyro_flux
! GyroBohm normalizations
gflux_loc(:,:,:,:,itor) = gflux_loc(:,:,:,:,itor)/rho**2
cflux_loc(:,:,:,itor) = cflux_loc(:,:,:,itor)/rho**2

triad_loc_old(:,:,itor,:) = triad_loc_old(:,:,itor,:)/rho**2
endif
enddo

Expand All @@ -240,6 +269,15 @@ subroutine cgyro_flux
NEW_COMM_1, &
i_err)

! Reduced complex triad(ns,kx), below, is still distributed over n
call MPI_ALLREDUCE(triad_loc_old(:,:,:,:), &
triad, &
size(triad), &
MPI_DOUBLE_COMPLEX, &
MPI_SUM, &
NEW_COMM_1, &
i_err)

! Reduced real cflux(ky), below, is still distributed over n

call MPI_ALLREDUCE(cflux_loc, &
Expand Down
8 changes: 7 additions & 1 deletion cgyro/src/cgyro_globals.F90
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,7 @@ module cgyro_globals
integer :: moment_print_flag
integer :: gflux_print_flag
integer :: field_print_flag
integer :: triad_print_flag
real :: amp0
real :: amp
real :: gamma_e
Expand Down Expand Up @@ -192,7 +193,7 @@ module cgyro_globals
integer :: nsplit,nsplitA,nsplitB
integer :: ns1,ns2
integer, dimension(:), allocatable :: recv_status
integer :: fA_req, fB_req, g_req
integer :: fA_req, fB_req, eA_req, eB_req, g_req
logical :: fA_req_valid, fB_req_valid, g_req_valid
! Thetas present in the process after NL AllToAll
integer :: n_jtheta
Expand Down Expand Up @@ -243,6 +244,7 @@ module cgyro_globals
character(len=12) :: binfile_hb = 'bin.cgyro.hb'
character(len=17) :: binfile_ky_flux = 'bin.cgyro.ky_flux'
character(len=18) :: binfile_ky_cflux = 'bin.cgyro.ky_cflux'
character(len=15) :: binfile_triad = 'bin.cgyro.triad'
character(len=15), dimension(3) :: binfile_fieldb = &
(/'bin.cgyro.phib ','bin.cgyro.aparb','bin.cgyro.bparb'/)
character(len=16), dimension(3) :: binfile_kxky = &
Expand Down Expand Up @@ -344,11 +346,14 @@ module cgyro_globals
complex, dimension(:,:,:), allocatable :: h0_x
complex, dimension(:,:,:), allocatable :: h0_old
complex, dimension(:,:,:,:), allocatable :: fA_nl,fB_nl
complex, dimension(:,:,:,:), allocatable :: eA_nl,eB_nl
complex, dimension(:,:,:,:), allocatable :: g_nl
complex, dimension(:,:,:), allocatable :: fpackA,fpackB
complex, dimension(:,:,:), allocatable :: epackA,epackB
complex, dimension(:,:,:,:), allocatable :: gpack
complex, dimension(:,:,:), allocatable :: omega_cap_h
complex, dimension(:,:,:), allocatable :: omega_h
complex, dimension(:,:,:), allocatable :: diss_r
complex, dimension(:,:,:,:), allocatable :: omega_s,omega_ss
complex, dimension(:,:,:), allocatable :: omega_sbeta
complex, dimension(:,:,:), allocatable :: cap_h_c
Expand Down Expand Up @@ -382,6 +387,7 @@ module cgyro_globals
real, dimension(:,:,:,:), allocatable :: cflux
complex, dimension(:,:,:,:,:), allocatable :: gflux_loc
complex, dimension(:,:,:,:,:), allocatable :: gflux
complex, dimension(:,:,:,:), allocatable :: triad,triad_loc,triad_loc_old
real, dimension(:,:), allocatable :: cflux_tave, gflux_tave
real :: tave_min, tave_max
integer :: tave_step
Expand Down
9 changes: 8 additions & 1 deletion cgyro/src/cgyro_init_arrays.F90
Original file line number Diff line number Diff line change
Expand Up @@ -447,7 +447,14 @@ subroutine cgyro_init_arrays
+ abs(omega_cdrift_r(it,is)*xi(ix))*vel(ie) &
+ abs(omega_rot_drift_r(it,is)) &
+ abs(omega_rot_edrift_r(it)))


! (d/dr) upwind diss.
diss_r(ic,iv_loc,itor) = - (n_radial/length)*spectraldiss(u,nup_radial)*up_radial &
* (abs(omega_rdrift(it,is))*energy(ie)*(1.0+xi(ix)**2) &
+ abs(omega_cdrift_r(it,is)*xi(ix))*vel(ie) &
+ abs(omega_rot_drift_r(it,is)) &
+ abs(omega_rot_edrift_r(it)))

! omega_star
carg = &
-i_c*k_theta_base*itor*rho*(dlnndr(is)+dlntdr(is)*(energy(ie)-1.5)) &
Expand Down
10 changes: 10 additions & 0 deletions cgyro/src/cgyro_init_manager.F90
Original file line number Diff line number Diff line change
Expand Up @@ -178,6 +178,11 @@ subroutine cgyro_init_manager
allocate(cflux_loc(n_species,4,n_field,nt1:nt2))
allocate( gflux(0:n_global,n_species,4,n_field,nt1:nt2))
allocate(gflux_loc(0:n_global,n_species,4,n_field,nt1:nt2))

allocate( triad(n_species,n_radial,nt1:nt2,8))
allocate(triad_loc(n_species,n_radial,nt1:nt2,7))
allocate(triad_loc_old(n_species,n_radial,nt1:nt2,8))

allocate(cflux_tave(n_species,4))
allocate(gflux_tave(n_species,4))

Expand Down Expand Up @@ -257,6 +262,7 @@ subroutine cgyro_init_manager
allocate(cap_h_v(nc_loc,nt1:nt2,nv))
allocate(omega_cap_h(nc,nv_loc,nt1:nt2))
allocate(omega_h(nc,nv_loc,nt1:nt2))
allocate(diss_r(nc,nv_loc,nt1:nt2))
allocate(omega_s(n_field,nc,nv_loc,nt1:nt2))
allocate(omega_ss(n_field,nc,nv_loc,nt1:nt2))
allocate(omega_sbeta(nc,nv_loc,nt1:nt2))
Expand Down Expand Up @@ -296,8 +302,10 @@ subroutine cgyro_init_manager
! Nonlinear arrays
if (nonlinear_flag == 1) then
allocate(fA_nl(n_radial,nt_loc,nsplitA,n_toroidal_procs))
allocate(eA_nl(n_radial,nt_loc,nsplitA,n_toroidal_procs))
allocate(g_nl(n_field,n_radial,n_jtheta,n_toroidal))
allocate(fpackA(n_radial,nt_loc,nsplitA*n_toroidal_procs))
allocate(epackA(n_radial,nt_loc,nsplitA*n_toroidal_procs))
allocate(gpack(n_field,n_radial,n_jtheta,n_toroidal))
allocate(jvec_c_nl(n_field,n_radial,n_jtheta,nv_loc,n_toroidal))
#if defined(OMPGPU)
Expand All @@ -308,6 +316,8 @@ subroutine cgyro_init_manager
if (nsplitB > 0) then ! nsplitB can be zero at large MPI
allocate(fB_nl(n_radial,nt_loc,nsplitB,n_toroidal_procs))
allocate(fpackB(n_radial,nt_loc,nsplitB*n_toroidal_procs))
allocate(eB_nl(n_radial,nt_loc,nsplitB,n_toroidal_procs))
allocate(epackB(n_radial,nt_loc,nsplitB*n_toroidal_procs))
#if defined(OMPGPU)
!$omp target enter data map(alloc:fpackB,fB_nl)
#elif defined(_OPENACC)
Expand Down
Loading

0 comments on commit 7903d19

Please sign in to comment.