source: LMDZ6/branches/contrails/libf/phylmd/lmdz_ratqs_ini.f90 @ 5440

Last change on this file since 5440 was 5400, checked in by evignon, 3 weeks ago

ajout de omp threadprivate manquants

File size: 2.5 KB
Line 
1MODULE lmdz_ratqs_ini
2
3IMPLICIT NONE
4
5integer :: lunout
6
7INTEGER, SAVE, PROTECTED :: nbsrf,is_lic,is_ter
8REAL, SAVE, PROTECTED :: RG,RV,RD,RCPD,RLSTT,RLVTT,RTT
9REAL, SAVE, PROTECTED :: a_ratqs_cv
10REAL, SAVE, PROTECTED :: tau_var
11REAL, SAVE, PROTECTED :: fac_tau
12REAL, SAVE, PROTECTED :: tau_cumul
13REAL, SAVE, PROTECTED :: a_ratqs_wake
14INTEGER, SAVE, PROTECTED :: dqimpl
15
16real, allocatable, SAVE :: povariance(:,:)
17!$OMP THREADPRIVATE(povariance)
18real, allocatable, SAVE :: var_conv(:,:)
19!$OMP THREADPRIVATE(var_conv)
20
21!$OMP THREADPRIVATE(nbsrf,is_lic,is_ter,RG,RV,RD,RCPD,RLSTT,RLVTT,RTT)
22!$OMP THREADPRIVATE(a_ratqs_cv,tau_var,fac_tau,tau_cumul,a_ratqs_wake,dqimpl)
23
24
25CONTAINS
26SUBROUTINE ratqs_ini(klon,klev,iflag_thermals,lunout_in,nbsrf_in,is_lic_in,is_ter_in,RG_in,RV_in,RD_in,RCPD_in,RLSTT_in,RLVTT_in,RTT_in)
27
28   USE ioipsl_getin_p_mod, ONLY : getin_p
29
30integer, intent(in) :: klon,klev,iflag_thermals,lunout_in
31integer, intent(in) :: nbsrf_in,is_lic_in,is_ter_in
32real, intent(in) :: RG_in,RV_in,RD_in,RCPD_in,RLSTT_in,RLVTT_in,RTT_in
33
34integer :: i,k
35
36nbsrf   =nbsrf_in
37is_lic  =is_lic_in
38is_ter  =is_ter_in
39RG      =RG_in   
40RV      =RV_in
41RD      =RD_in
42RCPD    =RCPD_in
43RLSTT   =RLSTT_in
44RLVTT   =RLVTT_in
45RTT     =RTT_in
46
47print*,'ratqs_ini'
48if (iflag_thermals==15.or.iflag_thermals==16) then
49   dqimpl=-1
50else
51   dqimpl=1
52endif
53lunout=lunout_in
54
55allocate(povariance(klon,klev))
56allocate(var_conv(klon,klev))
57
58
59tau_var = 700. ! temps de relaxation de la variabilit?? pour les thermiques
60fac_tau = 2.
61tau_cumul = 1000
62a_ratqs_wake = 3.    ! param??tre pilotant l'importance du terme d??pendant des poches froides
63a_ratqs_cv = 1.
64CALL getin_p('tau_var', tau_var)
65CALL getin_p('fac_tau', fac_tau)
66CALL getin_p('tau_cumul', tau_cumul)
67CALL getin_p('a_ratqs_wake', a_ratqs_wake)
68CALL getin_p('a_ratqs_cv', a_ratqs_cv)
69
70!--------------------------------------------------------
71! Initialisation des variances pour la param??trisation
72! pronostique des variances de Louis.
73! Ne marche pour le moment qu'en 1D en forcant une
74! initialisation des variances ?? une valeur constante.
75! A terme la variance doit devenir une variable d'etat
76! passee en argument
77!--------------------------------------------------------
78
79if (klon.eq.1) then
80    do k=1,klev
81      do i=1,klon
82          povariance(i,k) = 0.00000000001
83          var_conv(i,k) = 0.00000000001
84      enddo
85    enddo
86else
87    print*, 'conserver la variance dans les restarts'
88endif
89!--------------------------------------------------------
90
91 RETURN
92
93END SUBROUTINE ratqs_ini
94END MODULE lmdz_ratqs_ini
Note: See TracBrowser for help on using the repository browser.