source: trunk/LMDZ.COMMON/libf/dyn3d/addfi.F @ 3026

Last change on this file since 3026 was 1422, checked in by milmd, 10 years ago

In GENERIC, MARS and COMMON models replace some include files by modules (usefull for decoupling physics with dynamics).

File size: 5.1 KB
Line 
1!
2! $Id: addfi.F 1446 2010-10-22 09:27:25Z emillour $
3!
4      SUBROUTINE addfi(pdt, leapf, forward,
5     S          pucov, pvcov, pteta, pq   , pps ,
6     S          pdufi, pdvfi, pdhfi,pdqfi, pdpfi  )
7
8      USE infotrac, ONLY : nqtot
9      USE control_mod, ONLY : planet_type
10      USE comconst_mod, ONLY: kappa
11      IMPLICIT NONE
12c
13c=======================================================================
14c
15c    Addition of the physical tendencies
16c
17c    Interface :
18c    -----------
19c
20c      Input :
21c      -------
22c      pdt                    time step of integration
23c      leapf                  logical
24c      forward                logical
25c      pucov(ip1jmp1,llm)     first component of the covariant velocity
26c      pvcov(ip1ip1jm,llm)    second component of the covariant velocity
27c      pteta(ip1jmp1,llm)     potential temperature
28c      pts(ip1jmp1,llm)       surface temperature
29c      pdufi(ip1jmp1,llm)     |
30c      pdvfi(ip1jm,llm)       |   respective
31c      pdhfi(ip1jmp1)         |      tendencies  (unit/s)
32c      pdtsfi(ip1jmp1)        |
33c
34c      Output :
35c      --------
36c      pucov
37c      pvcov
38c      ph
39c      pts
40c
41c
42c=======================================================================
43c
44c-----------------------------------------------------------------------
45c
46c    0.  Declarations :
47c    ------------------
48c
49#include "dimensions.h"
50#include "paramet.h"
51#include "comgeom.h"
52c
53c    Arguments :
54c    -----------
55c
56      REAL,INTENT(IN) :: pdt ! time step for the integration (s)
57c
58      REAL,INTENT(INOUT) :: pvcov(ip1jm,llm) ! covariant meridional wind
59      REAL,INTENT(INOUT) :: pucov(ip1jmp1,llm) ! covariant zonal wind
60      REAL,INTENT(INOUT) :: pteta(ip1jmp1,llm) ! potential temperature
61      REAL,INTENT(INOUT) :: pq(ip1jmp1,llm,nqtot) ! tracers
62      REAL,INTENT(INOUT) :: pps(ip1jmp1) ! surface pressure (Pa)
63c respective tendencies (.../s) to add
64      REAL,INTENT(IN) :: pdvfi(ip1jm,llm)
65      REAL,INTENT(IN) :: pdufi(ip1jmp1,llm)
66      REAL,INTENT(IN) :: pdqfi(ip1jmp1,llm,nqtot)
67      REAL,INTENT(IN) :: pdhfi(ip1jmp1,llm)
68      REAL,INTENT(IN) :: pdpfi(ip1jmp1)
69c
70      LOGICAL,INTENT(IN) :: leapf,forward ! not used
71c
72c
73c    Local variables :
74c    -----------------
75c
76      REAL xpn(iim),xps(iim),tpn,tps
77      INTEGER j,k,iq,ij
78      REAL,PARAMETER :: qtestw = 1.0e-15
79      REAL,PARAMETER :: qtestt = 1.0e-40
80
81      REAL SSUM
82c
83c-----------------------------------------------------------------------
84
85      DO k = 1,llm
86         DO j = 1,ip1jmp1
87            pteta(j,k)= pteta(j,k) + pdhfi(j,k) * pdt
88         ENDDO
89      ENDDO
90
91      DO  k    = 1, llm
92       DO  ij   = 1, iim
93         xpn(ij) = aire(   ij   ) * pteta(  ij    ,k)
94         xps(ij) = aire(ij+ip1jm) * pteta(ij+ip1jm,k)
95       ENDDO
96       tpn      = SSUM(iim,xpn,1)/ apoln
97       tps      = SSUM(iim,xps,1)/ apols
98
99       DO ij   = 1, iip1
100         pteta(   ij   ,k)  = tpn
101         pteta(ij+ip1jm,k)  = tps
102       ENDDO
103      ENDDO
104!***********************
105! Correction on teta due to surface pressure changes
106      DO k = 1,llm
107        DO j = 1,ip1jmp1
108           pteta(j,k)= pteta(j,k)*(1+pdpfi(j)*pdt/pps(j))**kappa
109        ENDDO
110      ENDDO
111!***********************
112
113      DO k = 1,llm
114         DO j = iip2,ip1jm
115            pucov(j,k)= pucov(j,k) + pdufi(j,k) * pdt
116         ENDDO
117      ENDDO
118
119      DO k = 1,llm
120         DO j = 1,ip1jm
121            pvcov(j,k)= pvcov(j,k) + pdvfi(j,k) * pdt
122         ENDDO
123      ENDDO
124
125c
126      DO j = 1,ip1jmp1
127         pps(j) = pps(j) + pdpfi(j) * pdt
128      ENDDO
129 
130      if (planet_type=="earth") then
131      ! earth case, special treatment for first 2 tracers (water)
132       DO iq = 1, 2
133         DO k = 1,llm
134            DO j = 1,ip1jmp1
135               pq(j,k,iq)= pq(j,k,iq) + pdqfi(j,k,iq) * pdt
136               pq(j,k,iq)= AMAX1( pq(j,k,iq), qtestw )
137            ENDDO
138         ENDDO
139       ENDDO
140
141       DO iq = 3, nqtot
142         DO k = 1,llm
143            DO j = 1,ip1jmp1
144               pq(j,k,iq)= pq(j,k,iq) + pdqfi(j,k,iq) * pdt
145               pq(j,k,iq)= AMAX1( pq(j,k,iq), qtestt )
146            ENDDO
147         ENDDO
148       ENDDO
149      else
150      ! general case, treat all tracers equally)
151       DO iq = 1, nqtot
152         DO k = 1,llm
153            DO j = 1,ip1jmp1
154               pq(j,k,iq)= pq(j,k,iq) + pdqfi(j,k,iq) * pdt
155               pq(j,k,iq)= AMAX1( pq(j,k,iq), qtestt )
156            ENDDO
157         ENDDO
158       ENDDO
159      endif ! of if (planet_type=="earth")
160
161      DO  ij   = 1, iim
162        xpn(ij) = aire(   ij   ) * pps(  ij     )
163        xps(ij) = aire(ij+ip1jm) * pps(ij+ip1jm )
164      ENDDO
165      tpn      = SSUM(iim,xpn,1)/apoln
166      tps      = SSUM(iim,xps,1)/apols
167
168      DO ij   = 1, iip1
169        pps (   ij     )  = tpn
170        pps ( ij+ip1jm )  = tps
171      ENDDO
172
173
174      DO iq = 1, nqtot
175        DO  k    = 1, llm
176          DO  ij   = 1, iim
177            xpn(ij) = aire(   ij   ) * pq(  ij    ,k,iq)
178            xps(ij) = aire(ij+ip1jm) * pq(ij+ip1jm,k,iq)
179          ENDDO
180          tpn      = SSUM(iim,xpn,1)/apoln
181          tps      = SSUM(iim,xps,1)/apols
182
183          DO ij   = 1, iip1
184            pq (   ij   ,k,iq)  = tpn
185            pq (ij+ip1jm,k,iq)  = tps
186          ENDDO
187        ENDDO
188      ENDDO
189
190      RETURN
191      END
Note: See TracBrowser for help on using the repository browser.