source: trunk/LMDZ.VENUS/libf/phyvenus/radlwsw.NewtonCool @ 1240

Last change on this file since 1240 was 892, checked in by slebonnois, 12 years ago

SL: Important commit ! Adaptation of Venus physics to parallel computation / template for arch on the LMD servers using ifort / documentation for 1D column physics and for parallel computations

File size: 5.4 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   S. Lebonnois    12/04/2007
36c  VERSION NEWTONIAN COOLING pour Venus (no diurnal cycle)
37
38c======================================================================
39      use dimphy
40      USE comgeomphy
41      IMPLICIT none
42#include "dimensions.h"
43#include "YOMCST.h"
44#include "clesphys.h"
45c
46      real rmu0(klon), fract(klon), dist
47c
48      real paprs(klon,klev+1), pplay(klon,klev)
49      real tsol(klon)
50      real t(klon,klev)
51      real heat(klon,klev), cool(klon,klev)
52      real radsol(klon), topsw(klon), toplw(klon)
53      real solsw(klon), sollw(klon)
54      real sollwdown(klon)
55      REAL swnet(klon,klev+1),lwnet(klon,klev+1)
56c
57      INTEGER i,j,k
58      integer    nlevCLee,level
59      parameter (nlevCLee=30)
60      REAL   pressCLee(nlevCLee+1),tempCLee(nlevCLee+1)
61      real   dt_epCLee(nlevCLee+1),etaCLee(nlevCLee+1)
62      real   tauCLee
63      parameter (tauCLee=25*86400) ! en s
64      real   ztemp,zdt,fact
65      real   dTsdt(klev),zt_eq(klon,klev)
66      real   dureejour
67      parameter (dureejour=10.087e6)
68      save   zt_eq
69     
70      data     etaCLee/9.602e-1,8.679e-1,7.577e-1,6.420e-1,5.299e-1,
71     .                 4.273e-1,3.373e-1,2.610e-1,1.979e-1,1.472e-1,
72     .                 1.074e-1,7.672e-2,5.361e-2,3.657e-2,2.430e-2,
73     .                 1.569e-2,9.814e-3,5.929e-3,3.454e-3,1.934e-3,
74     .                 1.043e-3,5.400e-4,2.710e-4,1.324e-4,6.355e-5,
75     .                 3.070e-5,1.525e-5,7.950e-6,4.500e-6,2.925e-6,
76     .                 2.265e-6/
77      data   tempCLee/728.187,715.129,697.876,677.284,654.078,628.885,
78     .                602.225,574.542,546.104,517.339,488.560,459.932,
79     .                431.741,404.202,377.555,352.042,327.887,305.313,
80     .                284.556,265.697,248.844,233.771,220.368,208.247,
81     .                197.127,187.104,178.489,171.800,167.598,165.899,
82     .                165.676/
83      data   dt_epCLee/6.101 , 6.136 , 6.176 , 6.410 , 6.634 , 6.678 ,
84     .                 6.719 , 6.762 , 7.167 , 7.524 , 9.840 ,14.948 ,
85     .                21.370 ,28.746 ,36.373 ,43.315 ,48.534 ,51.175 ,
86     .                50.757 ,47.342 ,41.536 ,34.295 ,26.758 ,19.807 ,
87     .                14.001 , 9.599 , 6.504 , 4.439 , 3.126 , 2.370 ,
88     .                2.000/
89c
90
91      logical firstcall
92      data    firstcall/.true./
93      save    firstcall
94     
95c  Initialisations
96c-----------------
97
98      if (firstcall) then
99
100        PRINT*,"******* ATTENTION, NEWTONIAN COOLING ********"
101
102        pressCLee = etaCLee * 9.2e6
103
104        DO i = 1, klon
105       
106          do k = 1,klev
107         
108            level = 1
109            do j=1,nlevCLee
110              if (pressCLee(j).gt.pplay(i,k)) level = j
111            enddo
112           
113            fact  = (log10(pplay(i,k))-log10(pressCLee(level)))
114     .        /(log10(pressCLee(level+1))-log10(pressCLee(level)))
115            ztemp = tempCLee(level)*(1-fact)+tempCLee(level+1)*fact
116            zdt   = dt_epCLee(level)*(1-fact)+dt_epCLee(level+1)*fact
117c           zt_eq(i,k) = ztemp + zdt*(cos(rlatd(i)*RPI/180.)-2./RPI)
118            zt_eq(i,k) = ztemp + zdt*(cos(rlatd(i)*RPI/180.)-RPI/4.)
119           
120          enddo
121         
122        ENDDO !i
123
124      endif ! firstcall
125     
126c+++++++ BOUCLE SUR LA GRILLE +++++++++++++++++++++++++
127      DO j = 1,klon
128 
129          do k = 1,klev
130             dTsdt(k) = -(t(j,k)-zt_eq(j,k))/tauCLee   ! en K/s
131          enddo
132       
133         radsol(j) = 0.           ! + vers bas
134         topsw(j) = 0.            ! + vers bas
135         toplw(j) = 0.            ! + vers haut
136         solsw(j) = 0.            ! + vers bas
137         sollw(j) = 0.            ! + vers bas
138         sollwdown(j) = 0.        ! + vers bas
139
140        DO k = 1, klev+1
141         lwnet  (j,k)   = 0.
142         swnet  (j,k)   = 0.
143        ENDDO
144
145        DO k = 1, klev
146         heat (j,k) = dTsdt(k)*dureejour ! K/Venusday
147         cool (j,k) = 0.
148        ENDDO
149c
150      ENDDO !j
151c+++++++ FIN BOUCLE SUR LA GRILLE +++++++++++++++++++++++++
152
153      firstcall = .false.
154      RETURN
155      END
156
Note: See TracBrowser for help on using the repository browser.