!----------------------------------------------------------------------- 
!BOP
! !ROUTINE:  initcom --- Initialize model commons
!
! !INTERFACE:

subroutine initcom 2,15

! !USES:
   use shr_kind_mod,  only: r8 => shr_kind_r8
   use physconst,     only: pi, rair
   use pmgrid
   use pspect
   use commap,        only: w, clat, clon, w_staggered, clat
   use commap,        only: clat_staggered, clon, latdeg, londeg
   use commap,        only: latdeg_st, londeg_st
   use abortutils,    only: endrun
   use rgrid,         only: fullgrid
   use spmd_utils,    only: masterproc
   use hycoef,        only: hycoef_init
   use cam_logfile,   only: iulog
   implicit none

!-----------------------------------------------------------------------

! !DESCRIPTION:
!
!   Initialize Model commons.
! 
! !REVISION HISTORY:
!
!   92.06.01      Bath          Creation from CCM1
!   96.02.01      Buja          Modifications
!   01.01.19      Lin           incorporated Rasch's bug fix for the 
!                               "Gaussian" weights
!   02.04.04      Sawyer        Removed comspe
!
!EOP
!-----------------------------------------------------------------------
!BOC
!
! !LOCAL VARIABLES:

   real(r8), parameter ::  D0_0                     =  0.0_r8
   real(r8), parameter ::  D1_0                     =  1.0_r8
   real(r8), parameter ::  D1_5                     =  1.5_r8
   real(r8), parameter ::  D2_0                     =  2.0_r8
   real(r8), parameter ::  D90_0                    =  90.0_r8
   real(r8), parameter ::  D180_0                   = 180.0_r8
   real(r8), parameter ::  D360_0                   = 360.0_r8
   real(r8), parameter ::  D1EM8                    =  1.0e-8_r8

   integer i           ! longitude index
   integer j           ! Latitude index
   integer k           ! Level index
   integer m           ! Index for legendre array
   integer irow        ! Latitude pair index
   integer lat         ! Latitude index

   real(r8) dp             ! Spacing between latitudes
   real(r8) sum
!
!-----------------------------------------------------------------------
!
! Initialize commap.  Set hybrid level dependent arrays
!
   call hycoef_init

! L-R dynamics uses a regular latitude distribution (not gausian).
! The algorithm below is a bastardized version of LSM: map.F.

   dp = D180_0/(plat-1)
   do lat = 1, plat
      latdeg(lat) = -D90_0 + (lat-1)*dp
      clat(lat) = latdeg(lat)*pi/D180_0
   end do

! Calculate latitudes for the staggered grid

   do lat = 1, plat-1
      clat_staggered(lat) = (clat(lat) + clat(lat+1)) / D2_0
      latdeg_st     (lat) = clat_staggered(lat)*D180_0/pi
   end do

! Weights are defined as cos(phi)*(delta-phi)
! For a sanity check, the sum of w across all lats should be 2, or 1 across
! half of the latitudes.

   do lat = 2, plat-1
      w(lat) = sin(clat_staggered(lat)) - sin(clat_staggered(lat-1))
   end do
   w(1) = sin(clat_staggered(1)) + D1_0
   w(plat) = w(1)

   sum = D0_0
   do lat=1,plat
      if (masterproc) write(iulog,*) 'initcom: lat, clat, w ', lat, clat(lat), w(lat)
      sum = sum + w(lat)
   end do

   if (abs(sum - D2_0) > D1EM8) then
      write(iulog,*) 'INITCOM 1: weights do not sum to 2. sum=',sum
      call endrun
   end if

   dp = pi / real(plat-1,r8)
   do lat = 1, plat-1
      w_staggered(lat) = sin(clat(lat+1)) - sin(clat(lat))
   end do

   sum = D0_0
   do lat=1,plat-1
      sum = sum + w_staggered(lat)
   end do

   if (abs(sum - D2_0) > D1EM8) then
      write(iulog,*) 'INITCOM 2: weights do not sum to 2. sum=',sum
      call endrun
   end if
!
! Determine whether full or reduced grid
!
   fullgrid = .true.
   if (masterproc) write(iulog,*) 'Number of longitudes per latitude = ', plon
!
! Longitude array
!
   do lat=1,plat
      do i=1,plon
         londeg(i,lat) = (i-1)*D360_0/plon
         clon(i,lat)   = (i-1)*D2_0*pi/plon
      end do
   end do
   do lat=1,plat
      do i=1,splon
         londeg_st(i,lat) = (i-D1_5)*D360_0/splon
      end do
   end do
!
! Set flag indicating dynamics grid is now defined.
! NOTE: this ASSUMES initcom is called after spmdinit.  The setting of nlon done here completes
! the definition of the dynamics grid.
!
   return
!EOC
end subroutine initcom
!-----------------------------------------------------------------------