source: trunk/LMDZ.VENUS/libf/phyvenus/radlwsw_NewtonCool.F @ 3900

Last change on this file since 3900 was 3898, checked in by emillour, 3 months ago

Venus PCM:
More cleanup and prettyfying and preparing things for OpenMP.
Turned clmain_ideal into a module; added intent() to arguments.
Added THREADPRIVATE clause for saved variables, and English comments,
in radlwsw_NewtonCool and soil routines.
EM

File size: 4.1 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      MODULE radlwsw_newtoncool_mod
5     
6      implicit none
7     
8      contains
9     
10      SUBROUTINE radlwsw_newtoncool(presnivs,pt)
11     
12c======================================================================
13c   S. Lebonnois    12/04/2007
14c  VERSION NEWTONIAN COOLING pour Venus (no diurnal cycle)
15c  update 01/2014
16c======================================================================
17      use dimphy, only: klon,klev
18      USE geometry_mod, ONLY: latitude ! in radians
19      USE phys_state_var_mod, only: heat,cool,radsol,
20     .  topsw,toplw,solsw,sollw,sollwdown,lwnet,swnet,zt_eq
21      USE YOMCST_mod, ONLY: RPI
22      IMPLICIT none
23
24c ARGUMENTS
25 
26      real,intent(in) :: presnivs(klev) ! approx. pressure of GCM levels (Pa)
27      real,intent(in) :: pt(klon,klev) ! atmospheric temperature (K)
28 
29c LOCAL VARIABLES
30      INTEGER i,j,k
31      integer level
32      integer,parameter :: nlevCLee=30
33      REAL   pressCLee(nlevCLee+1),tempCLee(nlevCLee+1)
34      real   dt_epCLee(nlevCLee+1),etaCLee(nlevCLee+1)
35      real,parameter :: tauCLee=25*86400 ! in s
36
37      real   ztemp,zdt,fact
38      real   dTsdt(klev)
39     
40      data     etaCLee/9.602e-1,8.679e-1,7.577e-1,6.420e-1,5.299e-1,
41     .                 4.273e-1,3.373e-1,2.610e-1,1.979e-1,1.472e-1,
42     .                 1.074e-1,7.672e-2,5.361e-2,3.657e-2,2.430e-2,
43     .                 1.569e-2,9.814e-3,5.929e-3,3.454e-3,1.934e-3,
44     .                 1.043e-3,5.400e-4,2.710e-4,1.324e-4,6.355e-5,
45     .                 3.070e-5,1.525e-5,7.950e-6,4.500e-6,2.925e-6,
46     .                 2.265e-6/
47      data   tempCLee/728.187,715.129,697.876,677.284,654.078,628.885,
48     .                602.225,574.542,546.104,517.339,488.560,459.932,
49     .                431.741,404.202,377.555,352.042,327.887,305.313,
50     .                284.556,265.697,248.844,233.771,220.368,208.247,
51     .                197.127,187.104,178.489,171.800,167.598,165.899,
52     .                165.676/
53      data   dt_epCLee/6.101 , 6.136 , 6.176 , 6.410 , 6.634 , 6.678 ,
54     .                 6.719 , 6.762 , 7.167 , 7.524 , 9.840 ,14.948 ,
55     .                21.370 ,28.746 ,36.373 ,43.315 ,48.534 ,51.175 ,
56     .                50.757 ,47.342 ,41.536 ,34.295 ,26.758 ,19.807 ,
57     .                14.001 , 9.599 , 6.504 , 4.439 , 3.126 , 2.370 ,
58     .                2.000/
59c
60
61      logical,save :: firstcall=.true.
62C$OMP THREADPRIVATE(firstcall)
63     
64c  Initialisations
65c-----------------
66
67      if (firstcall) then
68        ! build zt_eq(), reference temperature field towards which to relax.
69        PRINT*,"******* WARNING, NEWTONIAN COOLING ********"
70
71        pressCLee = etaCLee * 9.2e6
72
73        DO i = 1, klon
74       
75          do k = 1,klev
76         
77            level = 1
78            do j=1,nlevCLee
79              if (pressCLee(j).gt.presnivs(k)) level = j
80            enddo
81           
82            fact  = (log10(presnivs(k))-log10(pressCLee(level)))
83     .        /(log10(pressCLee(level+1))-log10(pressCLee(level)))
84            ztemp = tempCLee(level)*(1-fact)+tempCLee(level+1)*fact
85            zdt   = dt_epCLee(level)*(1-fact)+dt_epCLee(level+1)*fact
86c           zt_eq(i,k) = ztemp + zdt*(cos(latitude(i))-2./RPI)
87            zt_eq(i,k) = ztemp + zdt*(cos(latitude(i))-RPI/4.)
88           
89          enddo
90         
91        ENDDO !i
92
93        firstcall = .false.
94      endif ! firstcall
95     
96c+++++++ LOOP ON COLUMNS +++++++++++++++++++++++++
97      DO j = 1,klon
98 
99          do k = 1,klev
100             dTsdt(k) = -(pt(j,k)-zt_eq(j,k))/tauCLee   ! in K/s
101          enddo
102       
103         radsol(j) = 0.           ! positive downwards
104         topsw(j) = 0.            ! positive downwards
105         toplw(j) = 0.            ! positive upwards
106         solsw(j) = 0.            ! positive downwards
107         sollw(j) = 0.            ! positive downwards
108         sollwdown(j) = 0.        ! positive downwards
109
110        DO k = 1, klev+1
111         lwnet  (j,k)   = 0.
112         swnet  (j,k)   = 0.
113        ENDDO
114
115        DO k = 1, klev
116         heat (j,k) = dTsdt(k)    ! K/s
117         cool (j,k) = 0.
118        ENDDO
119c
120      ENDDO !j
121c+++++++ END LOOP ON COLUMNS +++++++++++++++++++++++++
122
123      END SUBROUTINE radlwsw_newtoncool
124
125      END MODULE radlwsw_newtoncool_mod
Note: See TracBrowser for help on using the repository browser.