source: trunk/LMDZ.VENUS/libf/phyvenus/radlwsw.F @ 777

Last change on this file since 777 was 101, checked in by slebonnois, 14 years ago

SL: modifications pour arriver a compiler le gcm VENUS !
Ca marche !
A noter: modifs de makelmdz

File size: 6.3 KB
Line 
1!
2! $Header: /home/cvsroot/LMDZ4/libf/phylmd/radlwsw.F,v 1.2 2004/10/27 10:14:46 lmdzadmin Exp $
3!
4      SUBROUTINE radlwsw(dist, rmu0, fract,
5     .                  paprs, pplay,tsol, t,
6     .                  heat,cool,radsol,
7     .                  topsw,toplw,solsw,sollw,
8     .                  sollwdown,
9     .                  lwnet, swnet)
10c     
11c======================================================================
12c Auteur(s): Z.X. Li (LMD/CNRS) date: 19960719
13c Objet: interface entre le modele et les rayonnements
14c Arguments:
15c dist-----input-R- distance astronomique terre-soleil
16c rmu0-----input-R- cosinus de l'angle zenithal
17c fract----input-R- duree d'ensoleillement normalisee
18c solaire--input-R- constante solaire (W/m**2) (dans clesphys.h)
19c paprs----input-R- pression a inter-couche (Pa)
20c pplay----input-R- pression au milieu de couche (Pa)
21c tsol-----input-R- temperature du sol (en K)
22c t--------input-R- temperature (K)
23c heat-----output-R- echauffement atmospherique (visible) (K/jour)
24c cool-----output-R- refroidissement dans l'IR (K/jour)
25c radsol---output-R- bilan radiatif net au sol (W/m**2) (+ vers le bas)
26c topsw----output-R- flux solaire net au sommet de l'atm. (+ vers le bas)
27c toplw----output-R- ray. IR net au sommet de l'atmosphere (+ vers le haut)
28c solsw----output-R- flux solaire net a la surface (+ vers le bas)
29c sollw----output-R- ray. IR net a la surface (+ vers le bas)
30c sollwdown-output-R- ray. IR descendant a la surface (+ vers le bas)
31c lwnet____output-R- flux IR net (+ vers le haut)
32c swnet____output-R- flux solaire net (+ vers le bas)
33c
34     
35c MODIFS pour multimatrices ksi SPECIFIQUE VENUS
36c   S. Lebonnois    20/12/2006
37c   corrections     13/07/2007
38
39c======================================================================
40      use dimphy
41      USE comgeomphy
42      IMPLICIT none
43#include "dimensions.h"
44#include "YOMCST.h"
45#include "clesphys.h"
46#include "comcstVE.h"
47c
48      real rmu0(klon), fract(klon), dist
49c
50      real paprs(klon,klev+1), pplay(klon,klev)
51      real tsol(klon)
52      real t(klon,klev)
53      real heat(klon,klev), cool(klon,klev)
54      real radsol(klon), topsw(klon), toplw(klon)
55      real solsw(klon), sollw(klon)
56      real sollwdown(klon)
57      REAL swnet(klon,kflev+1),lwnet(klon,kflev+1)
58c
59      INTEGER k, kk, i, j, nb_gr
60c
61      REAL   PPB(kflev+1)
62c
63      REAL   zfract, zrmu0
64c
65      REAL   zheat(kflev), zcool(kflev)
66      REAL   ZFSNET(KFLEV+1),ZFLNET(KFLEV+1)
67      REAL   ztopsw, ztoplw
68      REAL   zsolsw, zsollw
69cIM BEG
70      REAL   zsollwdown
71cIM END
72      real,save,allocatable :: ksive(:,:,:,:) ! ksi matrixes in Vincent's file
73      real    psimap(0:kflev+1,0:kflev+1,klon)
74      real    deltapsimap(0:kflev+1,0:kflev+1,klon)
75      real    psi(0:kflev+1,0:kflev+1)
76      real    deltapsi(0:kflev+1,0:kflev+1)
77      real    latdeg
78      real    pt0(klon,0:kflev+1)
79      real,save,allocatable :: ztop(:) ! in km
80
81      logical firstcall
82      data    firstcall/.true./
83      save    firstcall
84     
85c-------------------------------------------
86      nb_gr = klon
87c-------------------------------------------
88c  Initialisations
89c-----------------
90
91      if (firstcall) then
92
93c ---------- ksive --------------
94        allocate(ksive(0:kflev+1,0:kflev+1,nnuve,nbmat))
95        call load_ksi(ksive)
96c ---------- ztop --------------
97        allocate(ztop(klon))
98        DO i = 1, klon
99             ztop(i) = 70.
100        ENDDO !i
101c ztop: d'apres fit à figure 16 du papier Zavosa et al (tmp) traitant des
102c       donnees Venera
103c       DO i = 1, klon
104c         latdeg = abs(rlatd(i))
105c         if (latdeg.lt.15) then
106c            ztop(i) = 70.
107c         elseif (latdeg.lt.50) then
108c            ztop(i) = 63.95+6*cos((latdeg-15)*RPI/2./50.)
109c         else
110c            ztop(i) = min(63.95+6*cos((latdeg-15)*RPI/2./50.),
111c    .                     63.95-5.9*sin((latdeg-60)*RPI/2/30))
112c         endif
113c       print*,'lat(',i,')=',latdeg,'  ztop=',ztop(i)
114c       ENDDO !i
115c ---------- ztop --------------
116
117      endif ! firstcall
118
119      DO i = 1, klon
120          pt0(i,0)  = tsol(i)
121          DO k = 1, klev
122            pt0(i,k) = t(i,k)
123          ENDDO
124          pt0(i,kflev+1) = 0.
125      ENDDO !i
126
127      call load_psi(paprs(:,1),ztop,ksive,pt0,psimap,deltapsimap)
128
129      DO k = 1, klev
130      DO i = 1, klon
131         heat(i,k)=0.
132         cool(i,k)=0.
133      ENDDO
134      ENDDO
135c
136c+++++++ BOUCLE SUR LA GRILLE +++++++++++++++++++++++++
137      DO 99999 j = 1, nb_gr
138 
139       DO k = 1, klev
140        zheat(k) = 0.0
141        zcool(k) = 0.0
142       ENDDO
143       DO k = 1, klev+1
144        ZFLNET(k) = 0.0
145        ZFSNET(k) = 0.0
146       ENDDO
147       ztopsw = 0.0
148       ztoplw = 0.0
149       zsolsw = 0.0
150       zsollw = 0.0
151       zsollwdown = 0.0
152     
153         zfract = fract(j)
154         zrmu0 = rmu0(j)
155 
156      DO k = 1, kflev+1
157         PPB(k) = paprs(j,k)/1.e5
158      ENDDO
159 
160      DO k = 0,kflev+1
161      DO i = 0,kflev+1
162        psi(i,k) = psimap(i,k,j)
163        deltapsi(i,k) = deltapsimap(i,k,j)
164      ENDDO
165      ENDDO
166       
167c======================================================================
168c LW call
169c---------
170      CALL LW_venus_ve(
171     .        PPB,t(j,:),psi,deltapsi,
172     .        zcool,
173     .        ztoplw,zsollw,
174     .        zsollwdown,ZFLNET)
175
176c---------
177c SW call
178c---------
179      CALL SW_venus_dc(zrmu0, zfract,
180     S        PPB,t(j,:),
181     S        zheat,
182     S        ztopsw,zsolsw,ZFSNET)
183     
184c======================================================================
185         radsol(j) = zsolsw - zsollw  ! + vers bas
186         topsw(j) = ztopsw            ! + vers bas
187         toplw(j) = ztoplw            ! + vers haut
188         solsw(j) = zsolsw            ! + vers bas
189         sollw(j) = -zsollw           ! + vers bas
190         sollwdown(j) = zsollwdown    ! + vers bas
191
192         DO k = 1, kflev+1
193         lwnet  (j,k)   = ZFLNET(k)
194         swnet  (j,k)   = ZFSNET(k)
195         ENDDO
196
197      DO k = 1, kflev
198         heat (j,k) = zheat(k)
199         cool (j,k) = zcool(k)
200      ENDDO
201c
20299999 CONTINUE
203c+++++++ FIN BOUCLE SUR LA GRILLE +++++++++++++++++++++++++
204
205c tests
206
207c     j = klon/2
208c     j = 1
209c     print*,'mu0=',rmu0(j)
210c     print*,'   net flux vis   HEAT(K/day)'
211c     do k=1,kflev
212c     print*,k,ZFSNET(k),heat(j,k)*8.56548e-3
213c     enddo
214c     print*,'   net flux IR    COOL(K/day)'
215c     do k=1,kflev
216c     print*,k,ZFLNET(k),cool(j,k)*8.56548e-3
217c     enddo
218
219      firstcall = .false.
220      RETURN
221      END
222
Note: See TracBrowser for help on using the repository browser.