23 REAL (R8),
POINTER :: CURRENT
24 REAL (R8),
POINTER :: CURRENT_NI
25 REAL (R8),
POINTER :: VLOOP
26 REAL (R8),
POINTER :: LI
27 REAL (R8),
POINTER :: BETA_N
28 REAL (R8),
POINTER :: BETA_TOR
29 REAL (R8),
POINTER :: BETA_POL
30 REAL (R8),
POINTER :: WDIA
31 REAL (R8),
POINTER :: QOH
49 REAL (R8),
POINTER :: &
86 INTEGER :: SIGMA_SOURCE
89 INTEGER,
POINTER :: PSI_BND_TYPE
90 REAL (R8),
POINTER :: PSI_BND_RHO
91 REAL (R8),
POINTER :: PSI_BND(:)
93 INTEGER,
POINTER :: NE_BND_TYPE
94 REAL (R8),
POINTER :: NE_BND_RHO
95 REAL (R8),
POINTER :: NE_BND(:)
97 INTEGER,
POINTER :: NI_BND_TYPE(:)
98 REAL (R8),
POINTER :: NI_BND_RHO(:)
99 REAL (R8),
POINTER :: NI_BND(:,:)
101 INTEGER,
POINTER :: TI_BND_TYPE(:)
102 REAL (R8),
POINTER :: TI_BND_RHO(:)
103 REAL (R8),
POINTER :: TI_BND(:,:)
105 INTEGER,
POINTER :: TE_BND_TYPE
106 REAL (R8),
POINTER :: TE_BND_RHO
107 REAL (R8),
POINTER :: TE_BND(:)
109 INTEGER,
POINTER :: VTOR_BND_TYPE(:)
110 REAL (R8),
POINTER :: VTOR_BND_RHO(:)
111 REAL (R8),
POINTER :: VTOR_BND(:,:)
113 REAL (R8),
POINTER :: &
149 contrib_2_energy_flux_ni(:,:), &
151 int_source_ni(:,:), &
164 contrib_2_energy_flux_ne(:), &
183 int_source_ti(:,:), &
216 flux_mtor_conv(:,:), &
217 flux_mtor_cond(:,:), &
219 int_source_mtor(:,:), &
241 INTEGER,
POINTER :: SIGMA_SOURCE
243 REAL (R8),
POINTER :: &
255 diff_ne_model(:,:), &
256 vconv_ne_model(:,:), &
264 diff_ni_model(:,:,:), &
265 vconv_ni_model(:,:,:), &
299 REAL (R8),
POINTER :: &
348 REAL (R8),
POINTER :: &
379 REAL (R8),
POINTER :: &
400 REAL (R8),
POINTER :: &
414 G2M(:), & !<R> at previous time step
415 G3M(:), & !<[nabla_RHO/R]^2> at previous time step
428 INTEGER :: SOLVER_TYPE
433 INTEGER :: SIGMA_SOURCE
439 INTEGER :: QUASI_NEUT
444 INTEGER :: DEBUG_LEVEL
446 REAL (R8) :: ohmic_heating_multiplier
448 REAL (R8),
POINTER :: &
465 CHARACTER*1000 :: ERROR_MESSAGE
505 INTEGER,
INTENT (IN) :: nrho
507 INTEGER,
INTENT (INOUT) :: ifail
512 ALLOCATE (geometry%RHO(nrho), &
513 geometry%RHO_NORM(nrho), &
514 geometry%HRHO(nrho), &
515 geometry%VPR(nrho), &
516 geometry%VPRM(nrho), &
519 geometry%G2M(nrho), &
521 geometry%G3M(nrho), &
522 geometry%FDIA(nrho), &
529 geometry%RHO_BND_PRIME, &
531 geometry%PHI_BND_PRIME, &
537 write(*,*)
'ALLOCATE_MAGNETIC_GEOMETRY: Failure to allocate'
547 geometry%RHO(:) = 0.0_r8
548 geometry%RHO_NORM(:) = 0.0_r8
549 geometry%HRHO(:) = 0.0_r8
550 geometry%VPR(:) = 0.0_r8
551 geometry%VPRM(:) = 0.0_r8
552 geometry%G1(:) = 0.0_r8
553 geometry%G2(:) = 0.0_r8
554 geometry%G2M(:) = 0.0_r8
555 geometry%G3(:) = 0.0_r8
556 geometry%G3M(:) = 0.0_r8
557 geometry%FDIA(:) = 0.0_r8
560 geometry%RGEO = 0.0_r8
561 geometry%BGEO = 0.0_r8
562 geometry%BGEOM = 0.0_r8
563 geometry%RHO_BND = 0.0_r8
564 geometry%RHO_BND_PRIME = 0.0_r8
565 geometry%PHI_BND = 0.0_r8
566 geometry%PHI_BND_PRIME = 0.0_r8
579 INTEGER,
INTENT (INOUT) :: ifail
584 DEALLOCATE (geometry%RHO, &
601 geometry%RHO_BND_PRIME, &
603 geometry%PHI_BND_PRIME, &
610 write(*,*)
'DEALLOCATE_MAGNETIC_GEOMETRY: Failure to deallocate'
633 INTEGER,
INTENT (INOUT) :: ifail
636 ALLOCATE (global%CURRENT, &
651 write(*,*)
'DEALLOCATE_MAGNETIC_GEOMETRY: Failure to deallocate'
657 global%CURRENT = 0.0_r8
658 global%CURRENT_NI = 0.0_r8
659 global%VLOOP = 0.0_r8
661 global%BETA_N = 0.0_r8
662 global%BETA_TOR = 0.0_r8
663 global%BETA_POL = 0.0_r8
680 INTEGER,
INTENT (INOUT) :: ifail
683 DEALLOCATE (global%CURRENT, &
698 write(*,*)
'DEALLOCATE_MAGNETIC_GEOMETRY: Failure to deallocate'
720 INTEGER,
INTENT (IN) :: nrho, nion
722 INTEGER,
INTENT (INOUT) :: ifail
760 profiles%CONTRIB_2_ENERGY_FLUX_NI(nrho,nion), &
761 profiles%INT_SOURCE_NI(nrho,nion), &
776 profiles%CONTRIB_2_ENERGY_FLUX_NE(nrho), &
794 profiles%INT_SOURCE_TI(nrho,nion), &
829 profiles%FLUX_MTOR_CONV(nrho,nion), &
830 profiles%FLUX_MTOR_COND(nrho,nion), &
832 profiles%INT_SOURCE_MTOR(nrho,nion), &
849 write(*,*)
'ALLOCATE_PLASMA_PROFILES: Failure to allocate'
896 profiles%CONTRIB_2_ENERGY_FLUX_NI(:,:)= 0.0_r8
897 profiles%INT_SOURCE_NI(:,:) = 0.0_r8
912 profiles%CONTRIB_2_ENERGY_FLUX_NE(:) = 0.0_r8
930 profiles%INT_SOURCE_TI(:,:) = 0.0_r8
965 profiles%FLUX_MTOR_CONV(:,:) = 0.0_r8
966 profiles%FLUX_MTOR_COND(:,:) = 0.0_r8
968 profiles%INT_SOURCE_MTOR(:,:) = 0.0_r8
996 INTEGER,
INTENT (INOUT) :: ifail
1034 profiles%CONTRIB_2_ENERGY_FLUX_NI, &
1048 profiles%CONTRIB_2_ENERGY_FLUX_NE, &
1117 IF (istat /= 0)
THEN
1118 ifail = max(ifail,1)
1119 write(*,*)
'DEALLOCATE_PLASMA_PROFILES: Failure to deallocate'
1122 ifail = max(ifail,0)
1148 INTEGER,
INTENT (IN) :: nrho, nion
1150 INTEGER,
INTENT (INOUT) :: ifail
1155 ALLOCATE (transport%SIGMA_SOURCE, &
1156 transport%SIGMA(nrho), &
1158 transport%DIFF_NE(nrho,3), &
1159 transport%VCONV_NE(nrho,3), &
1162 transport%DIFF_NE_MODEL(nrho,3), &
1163 transport%VCONV_NE_MODEL(nrho,3), &
1165 transport%DIFF_NI(nrho,nion,3), &
1166 transport%VCONV_NI(nrho,nion,3), &
1169 transport%DIFF_NI_MODEL(nrho,nion,3), &
1170 transport%VCONV_NI_MODEL(nrho,nion,3), &
1173 transport%DIFF_TI(nrho,nion), &
1174 transport%VCONV_TI(nrho,nion), &
1175 transport%QGI(nrho,nion), &
1177 transport%DIFF_TE(nrho), &
1178 transport%VCONV_TE(nrho), &
1179 transport%QGE(nrho), &
1181 transport%DIFF_VTOR(nrho,nion), &
1182 transport%VCONV_VTOR(nrho,nion), &
1187 IF (istat /= 0)
THEN
1188 ifail = max(ifail,1)
1189 write(*,*)
'ALLOCATE_TRANSPORT_COEFFICIENTS: Failure to allocate'
1192 ifail = max(ifail,0)
1196 transport%NRHO = nrho
1197 transport%NION = nion
1199 transport%SIGMA_SOURCE = 1
1203 transport%SIGMA(:) = 0.0_r8
1205 transport%DIFF_NE(:,:) = 0.0_r8
1206 transport%VCONV_NE(:,:) = 0.0_r8
1209 transport%DIFF_NE_MODEL(:,:) = 0.0_r8
1210 transport%VCONV_NE_MODEL(:,:) = 0.0_r8
1212 transport%DIFF_NI(:,:,:) = 0.0_r8
1213 transport%VCONV_NI(:,:,:) = 0.0_r8
1216 transport%DIFF_NI_MODEL(:,:,:) = 0.0_r8
1217 transport%VCONV_NI_MODEL(:,:,:) = 0.0_r8
1219 transport%C1(:) = 0.0_r8
1220 transport%DIFF_TI(:,:) = 0.0_r8
1221 transport%VCONV_TI(:,:) = 0.0_r8
1222 transport%QGI(:,:) = 0.0_r8
1224 transport%DIFF_TE(:) = 0.0_r8
1225 transport%VCONV_TE(:) = 0.0_r8
1226 transport%QGE(:) = 0.0_r8
1228 transport%DIFF_VTOR(:,:) = 0.0_r8
1229 transport%VCONV_VTOR(:,:) = 0.0_r8
1248 INTEGER,
INTENT (INOUT) :: ifail
1253 DEALLOCATE (transport%SIGMA_SOURCE, &
1256 transport%DIFF_NI, &
1257 transport%VCONV_NI, &
1258 transport%DIFF_NI_MODEL, &
1259 transport%VCONV_NI_MODEL, &
1261 transport%DIFF_NE, &
1262 transport%VCONV_NE, &
1263 transport%DIFF_NE_MODEL, &
1264 transport%VCONV_NE_MODEL, &
1267 transport%DIFF_TI, &
1268 transport%VCONV_TI, &
1272 transport%DIFF_TE, &
1273 transport%VCONV_TE, &
1275 transport%DIFF_VTOR, &
1276 transport%VCONV_VTOR, &
1282 IF (istat /= 0)
THEN
1283 ifail = max(ifail,1)
1284 write(*,*)
'DEALLOCATE_TRANSPORT_COEFFICIENTS: Failure to deallocate'
1287 ifail = max(ifail,0)
1313 INTEGER,
INTENT (IN) :: nrho, nion
1315 INTEGER,
INTENT (INOUT) :: ifail
1320 ALLOCATE (sources%SIGMA(nrho), &
1322 sources%CURR_EXP(nrho), &
1323 sources%CURR_IMP(nrho), &
1325 sources%SE_EXP(nrho), &
1326 sources%SE_IMP(nrho), &
1328 sources%SI_EXP(nrho,nion), &
1329 sources%SI_IMP(nrho,nion), &
1331 sources%QI_EXP(nrho,nion), &
1332 sources%QI_IMP(nrho,nion), &
1334 sources%QOH(nrho), &
1335 sources%QE_EXP(nrho), &
1336 sources%QE_IMP(nrho), &
1338 sources%UI_EXP(nrho,nion), &
1339 sources%UI_IMP(nrho,nion), &
1345 IF (istat /= 0)
THEN
1346 ifail = max(ifail,1)
1347 write(*,*)
'ALLOCATE_SOURCES_AND_SINKS: Failure to allocate'
1350 ifail = max(ifail,0)
1358 sources%SIGMA(:) = 0.0_r8
1360 sources%CURR_EXP(:) = 0.0_r8
1361 sources%CURR_IMP(:) = 0.0_r8
1363 sources%SE_EXP(:) = 0.0_r8
1364 sources%SE_IMP(:) = 0.0_r8
1366 sources%SI_EXP(:,:) = 0.0_r8
1367 sources%SI_IMP(:,:) = 0.0_r8
1369 sources%QI_EXP(:,:) = 0.0_r8
1370 sources%QI_IMP(:,:) = 0.0_r8
1372 sources%QOH(:) = 0.0_r8
1373 sources%QE_EXP(:) = 0.0_r8
1374 sources%QE_IMP(:) = 0.0_r8
1376 sources%UI_EXP(:,:) = 0.0_r8
1377 sources%UI_IMP(:,:) = 0.0_r8
1395 INTEGER,
INTENT (INOUT) :: ifail
1400 DEALLOCATE (sources%SIGMA, &
1425 IF (istat /= 0)
THEN
1426 ifail = max(ifail,1)
1427 write(*,*)
'DEALLOCATE_SOURCES_AND_SINKS: Failure to deallocate'
1430 ifail = max(ifail,0)
1459 INTEGER,
INTENT (IN) :: nrho, nion
1461 INTEGER,
INTENT (INOUT) :: ifail
1466 ALLOCATE (collisions%SIGMA(nrho), &
1467 collisions%VZI(nrho,nion), &
1468 collisions%QZI(nrho,nion), &
1469 collisions%VEI(nrho,nion), &
1470 collisions%QEI(nrho,nion), &
1471 collisions%WZI(nrho,nion), &
1472 collisions%UZI(nrho,nion), &
1473 collisions%VIE(nrho), &
1474 collisions%QIE(nrho), &
1475 collisions%VII(nrho,nion,nion), &
1476 collisions%WII(nrho,nion,nion), &
1482 IF (istat /= 0)
THEN
1483 ifail = max(ifail,1)
1484 write(*,*)
'ALLOCATE_COLLISIONALITY: Failure to allocate'
1487 ifail = max(ifail,0)
1491 collisions%NRHO = nrho
1492 collisions%NION = nion
1495 collisions%SIGMA(:) = 0.0_r8
1496 collisions%VZI(:,:) = 0.0_r8
1497 collisions%QZI(:,:) = 0.0_r8
1498 collisions%VEI(:,:) = 0.0_r8
1499 collisions%QEI(:,:) = 0.0_r8
1500 collisions%WZI(:,:) = 0.0_r8
1501 collisions%UZI(:,:) = 0.0_r8
1502 collisions%VIE(:) = 0.0_r8
1503 collisions%QIE(:) = 0.0_r8
1504 collisions%VII(:,:,:) = 0.0_r8
1505 collisions%WII(:,:,:) = 0.0_r8
1523 INTEGER,
INTENT (INOUT) :: ifail
1528 DEALLOCATE (collisions%SIGMA, &
1544 IF (istat /= 0)
THEN
1545 ifail = max(ifail,1)
1546 write(*,*)
'DEALLOCATE_COLLISIONALITY: Failure to deallocate'
1549 ifail = max(ifail,0)
1572 INTEGER,
INTENT (IN) :: nrho, nimp, nzimp
1574 INTEGER,
INTENT (INOUT) :: ifail
1579 ALLOCATE (
impurity%NZ(nrho,nimp,nzimp), &
1580 impurity%FLUX_NZ(nrho,nimp,nzimp), &
1586 IF (istat /= 0)
THEN
1587 ifail = max(ifail,1)
1588 write(*,*)
'ALLOCATE_IMPURITY_PROFILES: Failure to allocate'
1591 ifail = max(ifail,0)
1623 INTEGER,
INTENT (INOUT) :: ifail
1636 IF (istat /= 0)
THEN
1637 ifail = max(ifail,1)
1638 write(*,*)
'DEALLOCATE_IMPURITY_PROFILES: Failure to deallocate'
1641 ifail = max(ifail,0)
1665 INTEGER,
INTENT (IN) :: nrho, nion
1667 INTEGER,
INTENT (INOUT) :: ifail
1692 IF (istat /= 0)
THEN
1693 ifail = max(ifail,1)
1694 write(*,*)
'ALLOCATE_TIME_EVOLUTION: Failure to allocate'
1697 ifail = max(ifail,0)
1733 INTEGER,
INTENT (INOUT) :: ifail
1757 IF (istat /= 0)
THEN
1758 ifail = max(ifail,1)
1759 write(*,*)
'DEALLOCATE_TIME_EVOLUTION: Failure to deallocate'
1762 ifail = max(ifail,0)
1788 INTEGER,
INTENT (INOUT) :: ifail
1793 ALLOCATE (control%TAU, &
1801 IF (istat /= 0)
THEN
1802 ifail = max(ifail,1)
1803 write(*,*)
'ALLOCATE_RUN_CONTROL: Failure to allocate'
1806 ifail = max(ifail,0)
1810 control%SOLVER_TYPE = 0
1811 control%SIGMA_SOURCE = 1
1812 control%QUASI_NEUT = 0
1813 control%TAU = 0.0_r8
1814 control%AMIX = 1.0_r8
1815 control%AMIXTR = 1.0_r8
1816 control%CONV = 1.0_r8
1817 control%CONVREC = 0.0_r8
1835 INTEGER,
INTENT (INOUT) :: ifail
1840 DEALLOCATE (control%TAU, &
1849 IF (istat /= 0)
THEN
1850 ifail = max(ifail,1)
1851 write(*,*)
'DEALLOCATE_RUN_CONTROL: Failure to deallocate'
1854 ifail = max(ifail,0)
subroutine allocate_magnetic_geometry(NRHO, GEOMETRY, ifail)
subroutine profiles(p0, rbphi, dp0, drbphi, a)
subroutine allocate_global_param(GLOBAL, ifail)
subroutine allocate_plasma_profiles(NRHO, NION, PROFILES, ifail)
subroutine allocate_sources_and_sinks(NRHO, NION, SOURCES, ifail)
Allocate profiles of sources needed by the transport solver.
subroutine allocate_run_control(CONTROL, ifail)
Allocate parameters required by the run control and iterations loop.
subroutine allocate_impurity_profiles(NRHO, NIMP, NZIMP, IMPURITY, ifail)
Allocate plasma profiles needed by the transport solver.
subroutine deallocate_run_control(CONTROL, ifail)
Deallocate plasma profiles needed by the transport solver.
subroutine allocate_transport_coefficients(NRHO, NION, TRANSPORT, ifail)
Allocate profiles of transport coefficients needed by the transport solver.
subroutine deallocate_magnetic_geometry(GEOMETRY, ifail)
subroutine deallocate_transport_coefficients(TRANSPORT, ifail)
Deallocate plasma profiles needed by the transport solver.
subroutine deallocate_sources_and_sinks(SOURCES, ifail)
Deallocate plasma profiles needed by the transport solver.
subroutine deallocate_collisionality(COLLISIONS, ifail)
Deallocate plasma profiles needed by the transport solver.
subroutine deallocate_time_evolution(EVOLUTION, ifail)
Deallocate plasma profiles needed by the transport solver.
subroutine allocate_collisionality(NRHO, NION, COLLISIONS, ifail)
Allocate profiles of sources needed by the transport solver???
The module declares types of variables used in ETS (transport code)
subroutine deallocate_impurity_profiles(IMPURITY, ifail)
Deallocate plasma profiles needed by the transport solver.
subroutine evolution(T, R_in, R_out, El, Tr_l, Tr_U, Ip)
subroutine deallocate_plasma_profiles(PROFILES, ifail)
Deallocate plasma profiles needed by the transport solver.
subroutine allocate_time_evolution(NRHO, NION, EVOLUTION, ifail)
Allocate parameters required by time evolution.
subroutine deallocate_global_param(GLOBAL, ifail)