Merge remote-tracking branch 'origin/release-v4.5.2'
[WRF.git] / var / da / da_tools / da_msl2geo1.inc
blobe39997f7d9a858c7974f9f3bff353ebab6c736f3
1 !/**----------------------------------------------------------------------    
2 ! @sub       msl2geo1
4 ! Convert a list of geometric mean sea level altitudes to geopotential height
5 ! Use a more accurate conversion found at:
6 ! http://mtp.jpl.nasa.gov/notes/altitude/altitude.html
8 ! @parameter  
9 ! @ input:    z   -- list of geometric altitudes (in km)
10 ! @           lat -- latitude  of profile in degrees
11 ! @           lon -- longitude of profile in degrees.
12 ! @ output:   h   -- list of geopotential altitudes, in km
13 ! -----------------------------------------------------------------------*/
14 subroutine da_msl2geo1 (z, lat, lon, h)
15       implicit none
16       real*8 h, lat, lon, z     ! Note lon is currently not used
17       real*8 pi, latr, zm
18       real*8 semi_major_axis, semi_minor_axis, grav_polar, grav_equator
19       real*8 earth_omega, grav_constant, flattening, somigliana
20       real*8 grav_ratio, sin2, termg, termr, grav, eccentricity
22 !     Parameters below from WGS-84 model software inside GPS receivers.
23       parameter(semi_major_axis = 6378.1370d3)    ! (m)
24       parameter(semi_minor_axis = 6356.7523142d3) ! (m)
25       parameter(grav_polar = 9.8321849378)        ! (m/s2)
26       parameter(grav_equator = 9.7803253359)      ! (m/s2)
27       parameter(earth_omega = 7.292115d-5)        ! (rad/s)
28       parameter(grav_constant = 3.986004418d14)   ! (m3/s2)
29       parameter(grav = 9.80665d0)                 ! (m/s2) WMO std g at 45 deg lat
30       parameter(eccentricity = 0.081819d0)        ! unitless
32 !     Derived geophysical constants
33       parameter(flattening = (semi_major_axis-semi_minor_axis) /  &
34                               semi_major_axis)
36       parameter(somigliana =  &
37        (semi_minor_axis/semi_major_axis)*(grav_polar/grav_equator)-1.d0)
39       parameter(grav_ratio = (earth_omega*earth_omega *  &
40        semi_major_axis*semi_major_axis * semi_minor_axis)/grav_constant)
42       pi   = 3.14159265358979d0
43       latr = lat * (pi/180.d0)        ! in radians
44       zm   = z*1000d0                 ! in meters
46       if (z.eq.-999.d0) then
47          h = -999.d0
48       else 
49          sin2  = sin(latr) * sin(latr)
50          termg = grav_equator *  &
51           ( (1.d0+somigliana*sin2) /  &
52             sqrt(1.d0-eccentricity*eccentricity*sin2) )
53          termr = semi_major_axis   /  &
54           (1.d0 + flattening + grav_ratio - 2.d0*flattening*sin2)
56 !     geopotential height 
58          h=((termg/grav)*((termr*zm)/(termr+zm)))*0.001 ! in km
60       endif
61   
62 end  subroutine da_msl2geo1