1 | SUBROUTINE o3cm (amb, bmb, sortie, ntab) |
---|
2 | IMPLICIT none |
---|
3 | c====================================================================== |
---|
4 | c Auteur(s): Z.X. Li (LMD/CNRS) date: 19930818 |
---|
5 | c Objet: Ce programme calcule le contenu en ozone "sortie" |
---|
6 | c (unite: cm.atm) entre deux niveaux "amb" et "bmb" (unite: mb) |
---|
7 | c "ntab" est le nombre d'intervalles pour l'integration, sa |
---|
8 | c valeur depend bien sur de l'epaisseur de la couche et de |
---|
9 | c la precision qu'on souhaite a obtenir |
---|
10 | c====================================================================== |
---|
11 | REAL amb, bmb, sortie |
---|
12 | INTEGER ntab |
---|
13 | c====================================================================== |
---|
14 | INTEGER n |
---|
15 | REAL xtab(500), xa, xb, ya, yb, xincr |
---|
16 | c====================================================================== |
---|
17 | external mbtozm |
---|
18 | c====================================================================== |
---|
19 | c la fonction en ligne w(x) donne le profil de l'ozone en fonction |
---|
20 | c de l'altitude (unite: cm.atm / km) |
---|
21 | c (Green 1964, Appl. Opt. 3: 203-208) |
---|
22 | REAL wp, xp, h, x, w, con |
---|
23 | PARAMETER (wp=0.218, xp=23.25, h=4.63, con=1.0) |
---|
24 | w(x) = wp/h * EXP((x-xp)/h)/ (con+EXP((x-xp)/h))**2 |
---|
25 | c====================================================================== |
---|
26 | IF (ntab .GT. 499) STOP 'BIG ntab' |
---|
27 | xincr = (bmb-amb) / FLOAT(ntab) |
---|
28 | xtab(1) = amb |
---|
29 | DO n = 2, ntab |
---|
30 | xtab(n) = xtab(n-1) + xincr |
---|
31 | ENDDO |
---|
32 | xtab(ntab+1) = bmb |
---|
33 | sortie = 0.0 |
---|
34 | DO n = 1, ntab |
---|
35 | CALL mbtozm(xtab(n), xa) |
---|
36 | CALL mbtozm(xtab(n+1), xb) |
---|
37 | xa = xa / 1000. |
---|
38 | xb = xb / 1000. |
---|
39 | ya = w(xa) |
---|
40 | yb = w(xb) |
---|
41 | sortie = sortie + (ya+yb)/2.0 * ABS(xb-xa) |
---|
42 | ENDDO |
---|
43 | RETURN |
---|
44 | END |
---|
45 | SUBROUTINE mbtozm(rmb,zm) |
---|
46 | IMPLICIT none |
---|
47 | c====================================================================== |
---|
48 | c Auteur(s): Z.X. Li (LMD/CNRS) |
---|
49 | c Objet: transformer une hauteur de mb (rmb) en metre (zm) |
---|
50 | c====================================================================== |
---|
51 | REAL rmb, zm |
---|
52 | c====================================================================== |
---|
53 | REAL gama, tzero, pzero, g, r |
---|
54 | PARAMETER (gama=6.5e-3, tzero=288., pzero=1013.25) |
---|
55 | PARAMETER (g=9.81, r=287.0) |
---|
56 | zm = tzero/gama * ( 1.-(rmb/pzero)**(r*gama/g) ) |
---|
57 | RETURN |
---|
58 | END |
---|