10 diff_vtor, vconv_vtor, &
33 USE deallocate_structures
40 TYPE (type_coreprof
),
POINTER :: coreprof(:)
41 TYPE (type_coretransp
),
POINTER :: coretransp(:)
45 INTEGER,
PARAMETER :: nslice = 1
50 INTEGER,
ALLOCATABLE :: nzimp(:)
52 INTEGER,
ALLOCATABLE :: ncomp(:)
53 INTEGER,
ALLOCATABLE :: ntype(:)
56 REAL(R8) :: diff_ni(30), vconv_ni(30)
57 REAL(R8) :: diff_ti(30), vconv_ti(30)
58 REAL(R8) :: diff_ne, vconv_ne
59 REAL(R8) :: diff_te, vconv_te
60 REAL(R8) :: diff_vtor(30), vconv_vtor(30)
61 REAL(R8) :: diff_nz(100), vconv_nz(100)
62 REAL(R8) :: diff_tz(100), vconv_tz(100)
65 nrho =
SIZE (coreprof(1)%rho_tor, dim=1)
68 CALL
get_comp_dimensions(coreprof(1)%COMPOSITIONS, nnucl, nion, nimp, nzimp, nneut, ntype, ncomp)
70 call deallocate_cpo(coretransp(1)%COMPOSITIONS)
71 CALL copy_cpo(coreprof(1)%COMPOSITIONS, coretransp(1)%COMPOSITIONS)
76 coretransp(1)%time = coreprof(1)%time
78 coretransp(1)%VALUES(1)%rho_tor = coreprof(1)%rho_tor
79 coretransp(1)%VALUES(1)%rho_tor_norm = coreprof(1)%rho_tor/coreprof(1)%rho_tor(nrho)
81 coretransp(1)%VALUES(1)%sigma = sigma
82 coretransp(1)%VALUES(1)%ne_transp%diff_eff(:,1) = diff_ne
83 coretransp(1)%VALUES(1)%ne_transp%vconv_eff(:,1) = vconv_ne
84 coretransp(1)%VALUES(1)%ne_transp%diff_eff(:,2) = 0.0_r8
85 coretransp(1)%VALUES(1)%ne_transp%vconv_eff(:,2) = 0.0_r8
86 coretransp(1)%VALUES(1)%ne_transp%diff_eff(:,3) = 0.0_r8
87 coretransp(1)%VALUES(1)%ne_transp%vconv_eff(:,3) = 0.0_r8
88 coretransp(1)%VALUES(1)%te_transp%diff_eff(:) = diff_te
89 coretransp(1)%VALUES(1)%te_transp%vconv_eff(:) = vconv_te
92 coretransp(1)%VALUES(1)%ni_transp%diff_eff(:,iion,1) = diff_ni(iion)
93 coretransp(1)%VALUES(1)%ni_transp%vconv_eff(:,iion,1) = vconv_ni(iion)
94 coretransp(1)%VALUES(1)%ni_transp%diff_eff(:,iion,2) = 0.0_r8
95 coretransp(1)%VALUES(1)%ni_transp%vconv_eff(:,iion,2) = 0.0_r8
96 coretransp(1)%VALUES(1)%ni_transp%diff_eff(:,iion,3) = 0.0_r8
97 coretransp(1)%VALUES(1)%ni_transp%vconv_eff(:,iion,3) = 0.0_r8
98 coretransp(1)%VALUES(1)%ti_transp%diff_eff(:,iion) = diff_ti(iion)
99 coretransp(1)%VALUES(1)%ti_transp%vconv_eff(:,iion) = vconv_ti(iion)
100 coretransp(1)%VALUES(1)%vtor_transp%diff_eff(:,iion) = diff_vtor(iion)
101 coretransp(1)%VALUES(1)%vtor_transp%vconv_eff(:,iion) = vconv_vtor(iion)
105 coretransp(1)%VALUES(1)%NZ_TRANSP(iimp)%diff_eff(:,:) = diff_nz(iimp)
106 coretransp(1)%VALUES(1)%NZ_TRANSP(iimp)%vconv_eff(:,:) = vconv_nz(iimp)
107 coretransp(1)%VALUES(1)%TZ_TRANSP(iimp)%diff_eff(:,:) = diff_tz(iimp)
108 coretransp(1)%VALUES(1)%TZ_TRANSP(iimp)%vconv_eff(:,:) = vconv_tz(iimp)
114 ALLOCATE (coretransp(1)%VALUES(1)%transportid%id(1))
115 ALLOCATE (coretransp(1)%VALUES(1)%transportid%description(1))
116 coretransp(1)%VALUES(1)%transportid%id =
'background'
117 coretransp(1)%VALUES(1)%transportid%flag = 11
118 coretransp(1)%VALUES(1)%transportid%description =
'Background transport level'
subroutine get_comp_dimensions(COMPOSITIONS, NNUCL, NION, NIMP, NZIMP, NNEUT, NTYPE, NCOMP)
subroutine background_transport(COREPROF, SIGMA, DIFF_NI, VCONV_NI, DIFF_NE, VCONV_NE, DIFF_TI, VCONV_TI, DIFF_TE, VCONV_TE, DIFF_VTOR, VCONV_VTOR, DIFF_NZ, VCONV_NZ, DIFF_TZ, VCONV_TZ, CORETRANSP)
This module contains routines for allocation/deallocation if CPOs used in ETS.
subroutine allocate_coretransp_cpo(NSLICE, NRHO, NNUCL, NION, NIMP, NZIMP, NNEUT, NTYPE, NCOMP, CORETRANSP)
This routine allocates CORETRANSP CPO.