SCALE-RM
scalelib
src
atmos-rm
dynamics
scale_atmos_dyn_tinteg_tracer_euler.F90
Go to the documentation of this file.
1
!-------------------------------------------------------------------------------
11
!-------------------------------------------------------------------------------
12
#include "scalelib.h"
13
module
scale_atmos_dyn_tinteg_tracer_euler
14
!-----------------------------------------------------------------------------
15
!
16
!++ used modules
17
!
18
use
scale_precision
19
use
scale_io
20
use
scale_prof
21
use
scale_atmos_grid_cartesc_index
22
use
scale_index
23
use
scale_tracer
24
25
#ifdef DEBUG
26
use
scale_debug
,
only
: &
27
check
28
use
scale_const
,
only
: &
29
undef =>
const_undef
, &
30
iundef =>
const_undef2
31
#endif
32
!-----------------------------------------------------------------------------
33
implicit none
34
private
35
!-----------------------------------------------------------------------------
36
!
37
!++ Public procedure
38
!
39
public
::
atmos_dyn_tinteg_tracer_euler_setup
40
public
::
atmos_dyn_tinteg_tracer_euler
41
42
!-----------------------------------------------------------------------------
43
!
44
!++ Public parameters & variables
45
!
46
!-----------------------------------------------------------------------------
47
!
48
!++ Private procedure
49
!
50
!-----------------------------------------------------------------------------
51
!
52
!++ Private parameters & variables
53
!
54
!-----------------------------------------------------------------------------
55
contains
56
57
!-----------------------------------------------------------------------------
59
subroutine
atmos_dyn_tinteg_tracer_euler_setup
( &
60
tinteg_type )
61
use
scale_prc
,
only
: &
62
prc_abort
63
implicit none
64
65
character(len=*)
:: tinteg_type
66
67
integer
:: iv
68
!---------------------------------------------------------------------------
69
70
if
( tinteg_type /=
'EULER'
)
then
71
log_error(
"ATMOS_DYN_Tinteg_tracer_euler_setup"
,*)
'TINTEG_TRACER_TYPE is not EULER. Check!'
72
call
prc_abort
73
end if
74
75
return
76
end subroutine
atmos_dyn_tinteg_tracer_euler_setup
77
78
!-----------------------------------------------------------------------------
80
subroutine
atmos_dyn_tinteg_tracer_euler
( &
81
QTRC, & ! (out)
82
qflx, &
! (out)
83
qtrc0, rhoq_t, &
! (in)
84
dens0, dens, &
! (in)
85
mflx_hi, num_diff, &
! (in)
86
gsqrt, mapf, &
! (in)
87
cdz, rcdz, rcdx, rcdy, &
! (in)
88
bnd_w, bnd_e, bnd_s, bnd_n, &
! (in)
89
twod, &
! (in)
90
dtl, &
! (in)
91
flag_fct_tracer, &
! (in)
92
flag_fct_along_stream )
! (in)
93
use
scale_comm_cartesc
,
only
: &
94
comm_vars8, &
95
comm_wait
96
use
scale_atmos_dyn_tstep_tracer
,
only
: &
97
atmos_dyn_tstep_tracer
98
implicit none
99
real
(
rp
),
intent(inout)
:: qtrc (
ka
,
ia
,
ja
)
100
real
(
rp
),
intent(out)
:: qflx (
ka
,
ia
,
ja
,3)
101
real
(
rp
),
intent(in)
:: qtrc0 (
ka
,
ia
,
ja
)
102
real
(
rp
),
intent(in)
:: rhoq_t (
ka
,
ia
,
ja
)
103
real
(
rp
),
intent(in)
:: dens0 (
ka
,
ia
,
ja
)
104
real
(
rp
),
intent(in)
:: dens (
ka
,
ia
,
ja
)
105
real
(
rp
),
intent(in)
:: mflx_hi (
ka
,
ia
,
ja
,3)
106
real
(
rp
),
intent(in)
:: num_diff(
ka
,
ia
,
ja
,3)
107
real
(
rp
),
intent(in)
:: gsqrt (
ka
,
ia
,
ja
,7)
108
real
(
rp
),
intent(in)
:: mapf (
ia
,
ja
)
109
real
(
rp
),
intent(in)
:: cdz(
ka
)
110
real
(
rp
),
intent(in)
:: rcdz(
ka
)
111
real
(
rp
),
intent(in)
:: rcdx(
ia
)
112
real
(
rp
),
intent(in)
:: rcdy(
ja
)
113
logical
,
intent(in)
:: bnd_w
114
logical
,
intent(in)
:: bnd_e
115
logical
,
intent(in)
:: bnd_s
116
logical
,
intent(in)
:: bnd_n
117
logical
,
intent(in)
:: twod
118
real
(
rp
),
intent(in)
:: dtl
119
logical
,
intent(in)
:: flag_fct_tracer
120
logical
,
intent(in)
:: flag_fct_along_stream
121
122
!------------------------------------------------------------------------
123
! Start RK
124
!------------------------------------------------------------------------
125
126
call
atmos_dyn_tstep_tracer
( &
127
qtrc, &
! (out)
128
qflx, &
! (out)
129
qtrc, qtrc0, rhoq_t, &
! (in)
130
dens0, dens, &
! (in)
131
mflx_hi, num_diff, &
! (in)
132
gsqrt, mapf, &
! (in)
133
cdz, rcdz, rcdx, rcdy, &
! (in)
134
twod, &
! (in)
135
dtl, &
! (in)
136
flag_fct_tracer, flag_fct_along_stream )
! (in)
137
138
return
139
end subroutine
atmos_dyn_tinteg_tracer_euler
140
141
end module
scale_atmos_dyn_tinteg_tracer_euler
scale_prc::prc_abort
subroutine, public prc_abort
Abort Process.
Definition:
scale_prc.F90:350
scale_index
module Index
Definition:
scale_index.F90:11
scale_const::const_undef2
integer, parameter, public const_undef2
undefined value (INT2)
Definition:
scale_const.F90:40
scale_atmos_dyn_tinteg_tracer_euler
module Atmosphere / Dyn Tinteg
Definition:
scale_atmos_dyn_tinteg_tracer_euler.F90:13
scale_precision
module PRECISION
Definition:
scale_precision.F90:14
scale_atmos_grid_cartesc_index::ka
integer, public ka
Definition:
scale_atmos_grid_cartesC_index.F90:47
scale_prc
module PROCESS
Definition:
scale_prc.F90:11
scale_precision::rp
integer, parameter, public rp
Definition:
scale_precision.F90:41
scale_io
module STDIO
Definition:
scale_io.F90:10
scale_atmos_grid_cartesc_index
module atmosphere / grid / cartesC index
Definition:
scale_atmos_grid_cartesC_index.F90:12
scale_const
module CONSTANT
Definition:
scale_const.F90:11
scale_atmos_grid_cartesc_index::ia
integer, public ia
Definition:
scale_atmos_grid_cartesC_index.F90:48
scale_debug::check
subroutine, public check(current_line, v)
Undefined value checker.
Definition:
scale_debug.F90:59
scale_atmos_dyn_tinteg_tracer_euler::atmos_dyn_tinteg_tracer_euler
subroutine, public atmos_dyn_tinteg_tracer_euler(QTRC, qflx, QTRC0, RHOQ_t, DENS0, DENS, mflx_hi, num_diff, GSQRT, MAPF, CDZ, RCDZ, RCDX, RCDY, BND_W, BND_E, BND_S, BND_N, TwoD, dtl, FLAG_FCT_TRACER, FLAG_FCT_ALONG_STREAM)
EULER.
Definition:
scale_atmos_dyn_tinteg_tracer_euler.F90:93
scale_atmos_dyn_tstep_tracer
module Atmosphere / Dynamical scheme
Definition:
scale_atmos_dyn_tstep_tracer.F90:12
scale_prof
module profiler
Definition:
scale_prof.F90:11
scale_atmos_grid_cartesc_index::ja
integer, public ja
Definition:
scale_atmos_grid_cartesC_index.F90:49
scale_atmos_dyn_tinteg_tracer_euler::atmos_dyn_tinteg_tracer_euler_setup
subroutine, public atmos_dyn_tinteg_tracer_euler_setup(tinteg_type)
Setup.
Definition:
scale_atmos_dyn_tinteg_tracer_euler.F90:61
scale_tracer
module TRACER
Definition:
scale_tracer.F90:12
scale_debug
module DEBUG
Definition:
scale_debug.F90:11
scale_comm_cartesc
module COMMUNICATION
Definition:
scale_comm_cartesC.F90:11
scale_atmos_dyn_tstep_tracer::atmos_dyn_tstep_tracer
procedure(step), pointer, public atmos_dyn_tstep_tracer
Definition:
scale_atmos_dyn_tstep_tracer.F90:72
scale_const::const_undef
real(rp), public const_undef
Definition:
scale_const.F90:43
Generated by
1.8.17