source: LMDZ6/branches/Amaury_dev/libf/dyn3dmem/fluxstokenc_p.f90 @ 5497

Last change on this file since 5497 was 5159, checked in by abarral, 6 months ago

Put dimensions.h and paramet.h into modules

File size: 3.9 KB
Line 
1! $Id: caladvtrac_p.F 1299 2010-01-20 14:27:21Z fairhead $
2
3
4
5SUBROUTINE fluxstokenc_p(pbaru, pbarv, masse, teta, phi)
6  USE parallel_lmdz
7  USE control_mod, ONLY: iapp_tracvl, planet_type, iphysiq
8  USE caladvtrac_mod
9  USE mod_hallo
10  USE bands
11  USE times
12  USE lmdz_vampir
13  USE write_field_loc
14  USE lmdz_tracstoke
15
16  USE lmdz_dimensions, ONLY: iim, jjm, llm, ndm
17  USE lmdz_paramet
18  IMPLICIT NONE
19
20  ! Auteurs:   F.Hourdin , P.Le Van, F.Forget, F.Codron
21
22  !=======================================================================
23
24  !   Shema de  Van Leer
25
26  !=======================================================================
27
28
29
30
31  !   Arguments:
32  !   ----------
33  REAL :: pbaru(ijb_u:ije_u, llm), pbarv(ijb_v:ije_v, llm)
34  REAL :: masse(ijb_u:ije_u, llm)
35  REAL :: teta(ijb_u:ije_u, llm)
36  REAL :: phi(ijb_u:ije_u, llm)
37
38  INTEGER, SAVE :: pasflx = 0
39  !$OMP THREADPRIVATE(pasflx)
40  INTEGER :: ijb, ije, ijbu, ijbv, ijeu, ijev, j
41  INTEGER :: ij, l
42  TYPE(Request), SAVE :: Request_vanleer
43  !$OMP THREADPRIVATE(Request_vanleer)
44
45
46
47  !WRITE(*,*) 'caladvtrac 58: entree'
48  ijbu = ij_begin
49  ijeu = ij_end
50
51  ijbv = ij_begin - iip1
52  ijev = ij_end
53  IF (pole_nord) ijbv = ij_begin
54  IF (pole_sud)  ijev = ij_end - iip1
55
56  IF(pasflx==0) THEN
57    !$OMP DO SCHEDULE(STATIC,OMP_CHUNK)
58    DO l = 1, llm
59      tetac(ijbu:ijeu, l) = 0.
60      phic(ijbu:ijeu, l) = 0.
61      pbarucc(ijbu:ijeu, l) = 0.
62      pbarvcc(ijbv:ijev, l) = 0.
63    ENDDO
64    !$OMP END DO NOWAIT
65  ENDIF
66
67  !   accumulation des flux de masse horizontaux
68  !$OMP DO SCHEDULE(STATIC,OMP_CHUNK)
69  DO l = 1, llm
70    DO ij = ijbu, ijeu
71      pbarucc(ij, l) = pbarucc(ij, l) + pbaru(ij, l)
72      tetac(ij, l) = tetac(ij, l) + teta(ij, l)
73      phic(ij, l) = phic(ij, l) + phi(ij, l)
74
75    ENDDO
76    DO ij = ijbv, ijev
77      pbarvcc(ij, l) = pbarvcc(ij, l) + pbarv(ij, l)
78    ENDDO
79  ENDDO
80  !$OMP END DO NOWAIT
81
82  !   selection de la masse instantannee des mailles avant le transport.
83  IF(pasflx==0) THEN
84
85    ijb = ij_begin
86    ije = ij_end
87
88    !$OMP DO SCHEDULE(STATIC,OMP_CHUNK)
89    DO l = 1, llm
90      massec(ijb:ije, l) = masse(ijb:ije, l)
91    ENDDO
92    !$OMP END DO NOWAIT
93
94  ENDIF
95
96  pasflx = pasflx + 1
97
98
99  !   Test pour savoir si on advecte a ce pas de temps
100
101  IF (pasflx==(iphysiq * istphy)) THEN
102    !WRITE(*,*) 'caladvtrac 133'
103    !$OMP MASTER
104    CALL suspend_timer(timer_caldyn)
105    !$OMP END MASTER
106
107    ijb = ij_begin
108    ije = ij_end
109
110
111    !$OMP DO SCHEDULE(STATIC,OMP_CHUNK)
112    DO l = 1, llm
113      pbarucc(ijb:ije, l) = pbarucc(ijb:ije, l) / REAL(iphysiq * istphy)
114      tetac(ijb:ije, l) = tetac(ijb:ije, l) / REAL(iphysiq * istphy)
115      phic(ijb:ije, l) = phic(ijb:ije, l) / REAL(iphysiq * istphy)
116    ENDDO
117    !$OMP ENDDO NOWAIT
118
119    IF (pole_sud) ije = ij_end - iip1
120
121    !$OMP DO SCHEDULE(STATIC,OMP_CHUNK)
122    DO l = 1, llm
123      pbarvcc(ijb:ije, l) = pbarvcc(ijb:ije, l) / REAL(iphysiq * istphy)
124    ENDDO
125    !$OMP ENDDO NOWAIT
126
127
128    !$OMP BARRIER
129    CALL Register_Hallo_u(pbarucc, llm, 1, 1, 1, 1, Request_vanleer)
130    CALL Register_Hallo_v(pbarvcc, llm, 1, 1, 1, 1, Request_vanleer)
131    CALL SendRequest(Request_vanleer)
132    !$OMP BARRIER
133    CALL WaitRequest(Request_vanleer)
134    !$OMP BARRIER
135
136    !c   ..  Modif P.Le Van  ( 20/12/97 )  ....
137    !c
138
139    !   traitement des flux de masse avant advection.
140    ! 1. calcul de w
141    ! 2. groupement des mailles pres du pole.
142
143    CALL groupe_loc(massec, pbarucc, pbarvcc, pbarugg, pbarvgg, wgg)
144
145    ijb = ij_begin
146    ije = ij_end
147
148    !$OMP BARRIER
149    CALL WriteField_u('pbarug', pbarugg)
150    CALL WriteField_v('pbarvg', pbarvgg)
151    CALL WriteField_u('wg', wgg)
152    CALL WriteField_u('tetag', tetac)
153    CALL WriteField_u('phig', phic)
154    CALL WriteField_u('masseg', massec)
155
156
157    !$OMP MASTER
158    CALL Set_Distrib(distrib_caldyn)
159    CALL VTe(VThallo)
160    CALL resume_timer(timer_caldyn)
161    !$OMP END MASTER
162
163
164    !$OMP BARRIER
165    pasflx = 0
166  ENDIF ! if iadvtr.EQ.iapp_tracvl
167
168END SUBROUTINE fluxstokenc_p
Note: See TracBrowser for help on using the repository browser.