        program etatopo
          include "ecommons.h"
          call eta_commons
          call mainprog
        end program etatopo

CCCCCCCCCC

      subroutine mainprog
       implicit none
       include "ecommons.h"
       integer nsorc2,nexvlf,isrch,zeffl,zefflc,check1,check2,check3
       integer nssbsp,nssb,nssb2m,nssbp,nssbpp,kne,knw,kse,ksw
       integer khl00,khh00,khl22,khh22,ninc
       real    dtr,pihf,a,cd,rvk2,rz0,dmin,hmin,phl,dlmdl,dphdl,rssb
       real    sumtxp,sumty,sumtyp,vk,wtamin,area,rarea,htdir,ndir
       real    sl,saob,shhob,hi,hob,wtarea,hghmn,hodir
       real    rtsubi,z0,hhdir,alah,sumtx,psbm,pav,psm,shs,hwelp
       integer ifill,jx,ix,mthdz0,imin,imax,is,jmin,jmax,llsb
       integer js,kssb,hmin1,hmax2,hmin3,nlob,ilob,nhghmn
       integer nlim,imn,nhmm,iex,ndirp,kndirt,kldirt,kwdirt,km,kndirs
       integer kldirs,kwdirs,ktdirs,nhused,m,ksdb,kspb,kssdbf,kssdb
       integer ndbmin,nsbmin,nsbhd,nphd
       integer mssdbf,msdb,mspb,mssdb,kstart,kend
       integer JTSUBH,NTSUBH,NTSUBI,ITSUBI,
     &         NHREAD,issb,jssb,iqsb,jqsb,kqsb
Cmp
       real    tlm,tph,stph,ctph,sinphi,
     +         fact,coslam,wb,sb,tph0,dlm
     +         ,tdlm,dph
Cm
       real tlat,tlon,r30sh,tslat,rtsubh,alm,aph,assb,r30s

       REAL,ALLOCATABLE:: GLAT(:),GLON(:)    
       INTEGER,ALLOCATABLE::NDB(:,:),NPB(:,:)
       REAL, ALLOCATABLE::HSB(:,:),PSB(:,:),AGTK(:)

       integer NDPSB(4)
       real  HS(4)
       real*4 dlo,dla
       integer*4 ntiles,ISTART
C
C	PARAMETER (NSSB=04)
       PARAMETER (NSSB=04)
C      PARAMETER (NTSUBH=01)
       PARAMETER (NTSUBH=02)
       parameter (nsorc2=4)
       parameter (nssbsp=nssb*nssb+1)
       parameter (nssb2m=nssb*2-1)
       parameter (nssbp=nssb+1)
       parameter (nssbpp=nssbp+1)
       PARAMETER (PIHF=1.570796,DTR=0.01745329)
       parameter (ndbmin=1)
       parameter (nsbmin=1)
       parameter (dlo=1./120.,dla=1./120.)
       parameter (ntiles=18*36)
C
c arrays for subbox calculations
       REAL,ALLOCATABLE:: hssb(:,:,:),hssa(:)
       INTEGER,ALLOCATABLE:: ndsa(:),ndsb(:,:,:)
c arrays for effective z0
       REAL,ALLOCATABLE:: z0eff(:,:), z0eff2(:,:,:)
       REAL,ALLOCATABLE:: zha(:,:),zas(:,:)
       INTEGER,ALLOCATABLE:: isorc(:)
         
       real ao(4)
       real ha(4)
       real ds(4)
       integer msq(2,2)
c arrays for statistics
       integer nssdbf(nssbsp)

       INTEGER,ALLOCATABLE:: nsdb(:),nspb(:),nssdb(:)
       INTEGER,ALLOCATABLE:: kndir(:,:,:),kldir(:,:,:),kwdir(:,:,:)

       integer kndirx(4),kldirx(4),kwdirx(4)
       real andirx(4),aldirx(4),awdirx(4)

       INTEGER,ALLOCATABLE::kisrch(:,:,:),klsrch(:,:,:),kwsrch(:,:,:)
       integer kountm(nsorc2)
       integer kountl(nsorc2)
       integer kountw(nsorc2)
       real zemean(4,nsorc2),zlmean(4,nsorc2),zwmean(4,nsorc2)
       real hamean(4,nsorc2),hlmean(4,nsorc2),hwmean(4,nsorc2)
       real asmean(4,nsorc2),almean(4,nsorc2),awmean(4,nsorc2)
       real zemin(4,nsorc2),zemax(4,nsorc2)
       real hamin(4,nsorc2),hamax(4,nsorc2)
       real asmin(4,nsorc2),asmax(4,nsorc2)
C      integer izemin(4,nsorc2),izemax(4,nsorc2)
       integer ihamin(4,nsorc2),ihamax(4,nsorc2)
       integer iasmin(4,nsorc2),iasmax(4,nsorc2)
       integer jzemin(4,nsorc2),jzemax(4,nsorc2)
       integer jhamin(4,nsorc2),jhamax(4,nsorc2)
C      integer jasmin(4,nsorc2),jasmax(4,nsorc2)
       integer kzemin(4,nsorc2),kzemax(4,nsorc2)
       integer khamin(4,nsorc2),khamax(4,nsorc2)
       integer khl2(jm),khh2(jm)
       integer kasmin(4,nsorc2),kasmax(4,nsorc2)
c arrays for exteme values
       real    exvl(nssbpp)
       real    exvlc(nssb)
c arrays for accumulating obstacle heights
       integer nadir(4)
       real    htadir(4)
       real    hhadir(4)

       REAL,ALLOCATABLE:: hgtk(:),dum2d(:,:),tmp(:,:),smk(:)
       REAL,ALLOCATABLE:: hgt(:,:),sm(:,:),hbm2(:)

       REAL,ALLOCATABLE:: tfn(:),tfx(:),tln(:),tlx(:)

       real
     .         almx,almn,apmx,apmn
     .        ,awlo,aelo,asla,anla
     .        ,alt0d,p,q
c
       INTEGER*2,ALLOCATABLE:: iht(:,:)
c
       integer i,j,k,l,n,lat,lon,khl,khh
     .        ,nlon,nlat,irecl,kaa
     .        ,nwd,ned,nsd,nnd
     .        ,nlo1,nlo2,nla1,nla2
     .        ,nrrd,ihw(jm),ihe(jm),iter
       character*255 fname
       character*8   ctile(ntiles)
       character*3   alon
       character*2   alat
       character*1   lndir,ltdir,akm

C	NAMELIST /SEARESO/ seares
        data hwelp/99999./
        DATA msq/4,1,2,3/
c
        logical inside
c
c *** Create topo for eta grid.  
c     Uses 30 s global data obtained from ftp site edcftp.cr.usgs.gov
c
c *** Code obtained from U. of Athens and modified at FSL.
c
c_______________________________________________________________________________
c
c *** Fill eta model common blocks.
c
        call eta_commons
        write(6,*) 'back from eta_commons' , seares
c *** Create eta topo file.
c
c===============================================================================
c
c *** Create topo tile filenames and lat, lon extents.
c     At FSL topo tiles are 10x10 degrees with a file name indicating
c     the SW corner of the tile (e.g. U40N110W).
c
C
Cnew (formerly parameter statements in oper)


Cmp
        ctph0=cos(tph0d*dtr)
        stph0=sin(tph0d*dtr)
        KNE=IM
        KNW=IM-1
        KSE=1-IM
        KSW=-IM
        KHL00=1
        KHH00=IMJM
        KHL22=2*IM+1
        KHH22=IMJM-2*IM
        NINC=2*IM-1
Cnew
C
        ALLOCATE(tfn(ntiles),tfx(ntiles),tln(ntiles),tlx(ntiles))
        ALLOCATE(IHT(1200,1200))
        n=0
        do lat=-90,80,10
           do lon=-180,170,10
              n=n+1
              if (lon .lt. 0) then 
                 lndir='W'
              else
                 lndir='E'
              endif
              if (lat .lt. 0) then
                 ltdir='S'
              else
                 ltdir='N'
              endif
              write(alon,'(i3.3)') abs(lon)
              write(alat,'(i2.2)') abs(lat)
              ctile(n)='U'//alat//ltdir//alon//lndir
              tfn(n)=float(lat)
              tfx(n)=float(lat+10)
              tln(n)=float(lon)
              tlx(n)=float(lon+10)
           enddo
        enddo
c
c *** Find lat-lon extremes for eta grid.
        write(6,*) 'wbd, sbd ', wbd,sbd
c 
        call corners(im,jm,imjm,tph0d,tlm0d,
     .               dlmd,dphd,apmn,almn,apmx,almx)
c
        print *,'ETA grid window:'
        print *,'   Northwest =',apmx,almn
        print *,'   Southeast =',apmn,almx
        print *,' '

C	stop
c
c *** Boundary point heights are set to zero (where hbm2=0).
c
        do j=1,jm
           khl2(j)=im*(j-1)-(j-1)/2+2
           khh2(j)=im*j-j/2-1
        enddo
c
        ALLOCATE(HBM2(IMJM))
        do k=1,imjm
           hbm2(k)=0.
        enddo
c
        do j=3,jm2
           khl=khl2(j)
           khh=khh2(j)
C	write(6,*) 'khl, khh ', khl,khh
           do k=khl,khh
              hbm2(k)=1.
           enddo
        enddo
c
c *** Initialize height (hsb), ocean pts (psb), and total pts (ndb) within
c        each eta grid diamond to zero.
c

        ALLOCATE(NDB(IMJM,4))
        ALLOCATE(HSB(IMJM,4))
        ALLOCATE(PSB(IMJM,4))

        do m=1,4
           do k=1,imjm
              hsb(k,m)=0.
              psb(k,m)=0.
              ndb(k,m)=0
           enddo
        enddo
c
c *** Process tiles that cover eta grid domain.
c
        ALLOCATE( HSSB(nssb,nssb,imjm),NDSB(nssb,nssb,imjm) )

        HSSB=0.
        NDSB=0

        do n=1,ntiles
           check1=0
           check2=0
           check3=0
           if (apmn .le. tfx(n) .and. apmx .ge. tfn(n)) then
              IF (almn.le.tlx(n).and.almx.ge.tln(n)) check1=1
Cmp	      West extending into East
              if (almn .lt. -180 .and. tln(n).gt.0 .and.
     +           (almn+360).le.tlx(n)) check2=1
Cmp	      East extending into West
              if (almx .gt. 180 .and. tlx(n) .lt. 0 .and.
     +            almn.ge.tln(n) .and. (almx-360).ge.tln(n) ) check3=1
           endif
C	write(6,*) 'lon bounds: this tile: ', almn,almx,tln(n),tlx(n)
           if (check1 .eq. 1 .or. check2 .eq. 1 .or. check3 .eq. 1) then
Cmp	write(6,*) 'inside for ', tlx(n),tfx(n),check1,check2,check3
c            
               fname=topo_in(1:index(topo_in,' ')-1)//ctile(n)
c           
c ********* Check that tile parameters match expected 10x10 degree size.
c
               awlo=tln(n)
               aelo=tlx(n)
               asla=tfn(n)
               anla=tfx(n)
               nlon=int((aelo-awlo)/dlo)+1
               nlat=int((anla-asla)/dla)+1
C
               irecl=nlon*2
Ctst            nwd=(awlo-almn)/dlo
               if (almn .lt. -180 .and. awlo .gt. 0) then
                  nwd=(awlo-(almn+360.))/dlo
               elseif (almn .gt. 0 .and. awlo .lt. 0) then
                  nwd=(awlo-(almn-360.))/dlo
               else
                  nwd=(awlo-almn)/dlo
               endif
               if (aelo .gt. 0 .and. almx .lt. 0)  then
                  ned=(aelo-(almx+360.))/dlo
               elseif (aelo .lt. 0 .and. almx .gt. 180) then
                  ned=(aelo-(almx-360.))/dlo
               else
                  ned=(aelo-almx)/dlo
               endif
               nsd=(asla-apmn)/dla
               nnd=(anla-apmx)/dla
c
               if (nwd .le. 0) then
                  nlo1=-nwd-4
               else
                  nlo1=1
               endif
c
               if (ned .ge. 0) then
                  nlo2=nlon-ned+4
               else
                  nlo2=nlon
               endif
c
               if (nnd .ge. 0) then
                  nla1=nnd-4
               else
                  nla1=1
               endif
c
               if (nsd .le. 0) then
                  nla2=nlat+nsd+4
               else
                  nla2=nlat
               endif           
c
               if (nlat .ne. 1200 .or. nlon .ne. 1200) then
                  print *,'Unexpected tile size:',nlon,nlat
                  print *,'Should be 1200 x 1200'
                  print *,'Abort...'
                  stop
               endif
C           print*,' ','(',nlo1,'-',nlo2,'),(',nla1,'-',nla2,')'
c
c ********* Open input topo file.
c
               open(unit=1,file=fname,status='old'
     .         ,form='unformatted',access='direct',recl=irecl)
C     .         ,err=900)
               l=index(fname//' ',' ')-1
Cmp            print *,'reading topo data ',fname(1:l)
               print *,'reading topo data ',fname(l-8:l)
Cmp	write(6,*) ' '
c
c ********* Process row by row.
c
Cno            last=.false.
Cno            nrrd=nla1

CCCCCCCCCCCCCCCCCCCCCCCCCCCCCC

Cmp      alt0d=anla-dla/2.-(nrrd-1)*dla
	alt0d=tfx(n)
	assb=float(nssb)
      rssb=1.0/assb
      r30s=1.0/120.0
      r30sh=r30s*0.5
      RTSUBH=R30sh/(NTSUBh*1.0)

Cnew            do while (.not. last)

	do710: do nrrd=1,nlat
        read(1,rec=nrrd)(iht(i,nrrd),i=1,nlon)
	if (nrrd .eq. nlat/2) write(302,*) (iht(I,NRRD),I=1,nlon)

Cmp     swap the topo data element by element
C#ifdef LITTLE
        do I=1,NLON
        call swapval(iht(I,nrrd))
        enddo
C#endif
	if (nrrd .eq. nlat/2) write(301,*) (iht(I,NRRD),I=1,nlon)

	
        enddo do710
        close(1)

Cmp	at this point the 1200 X 1200 block of data has been read

	do7109: do nrrd=1,nlat
      tlat=(ALT0D-(2*nrrd-1)*r30sh)
      if (tlat.gt.apmx) cycle do7109
      if (tlat.lt.apmn) cycle do7109
        do7108: do i=nlo1,nlo2
	tlon=(awlo*1.0+(2*i-1)*(1./240.))
C      if ((tlon.gt.blonem).and.(tlon.lt.blonw ).or.
C     1    (tlon.gt.blone ).and.(tlon.lt.blonwp).or.
C     2    (tlon.gt.blonep).and.(tlon.lt.blonwq)) go to 7108
Cnew
      do7107: DO jtsubh=1,ntsubh
      tslat=tlat+(jtsubh*2-ntsubh)*rtsubh
      ntsubi=ntsubh-ifix(ntsubh*(1.0-cos(dtr*tslat)))
      rtsubi=r30sh/(ntsubi*1.0)

      do7106: DO itsubi=1,ntsubi
	ALM=(tlon+(ITSUBi*2-ntsubi)*RTSUBi)
	APH=tslat
	nhread=nhread+1
      ALM=ALM*DTR
      APH=APH*DTR
        
	call PQK_NEW(alm,aph,inside,p,q,kaa)
	IF (.NOT.INSIDE) cycle do7106
          
c  assign the subboxes based on the values of p and q
          issb = 1 + ifix(p*assb)
          jssb = 1 + ifix(q*assb)
          iqsb = 1 + ifix(p*2.0)
          jqsb = 1 + ifix(q*2.0)
c
          kqsb=msq(iqsb,jqsb)

          
          if (NDB(kaa,kqsb).ge.0) then
            HSB(kaa,kqsb)=HSB(kaa,kqsb)+iht(i,nrrd)
            NDB(kaa,kqsb)=NDB(kaa,kqsb)+1
          endif

          if (ndsb(issb,jssb,kaa).ge.0) then
            hssb(issb,jssb,kaa)=hssb(issb,jssb,k)+iht(i,nrrd)
            ndsb(issb,jssb,kaa)=ndsb(issb,jssb,k)+1
          if ((issb.lt.1).or.(issb.gt.nssb).or.
     1          (jssb.lt.1).or.(jssb.gt.nssb).or.
     2          (kaa   .lt.1).or.(kaa   .gt.imjm)) then
              write(6,'('' data written outside the box'',4i6,2f7.3)')
     1          issb,jssb,kaa   ,kaa,p,q
            endif
          endif
          nhused=nhused+1
c 
        enddo do7106
        enddo do7107
        enddo do7108  
        enddo do7109

Cmp    endif on whole section?
        ENDIF 
Cmp	enddo on number of tiles?
      enddo


	DEALLOCATE(tfx,tfn,tlx,tln)
	DEALLOCATE(IHT)

CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC

	write(6,*) 'done reading data?'
	write(6,*) 'nssbsp= ', nssbsp
	write(6,*) 'imjm= ', imjm
c zero out counters for filling of grid boxes
c
	ALLOCATE(NSDB(102))
	ALLOCATE(NSPB(102))
	ALLOCATE(NSSDB(102))
      do 4115 k=1,102
        nsdb(k)=0
        nspb(k)=0
        nssdb(k)=0
 4115 continue
      do 4117 k=1,nssbsp
        nssdbf(k)=0
 4117 continue

c convert positive numbers of points, fill counters
c

	ALLOCATE(ISORC(IMJM))
	ISORC=0
	ALLOCATE(NPB(IMJM,4))
      do 5177 k=1,imjm
        do 5163 m=1,4
          if (ndb(k,m).gt.0) then
            if (mod(isorc(k),2).eq.0) then
              isorc(k)=isorc(k)+1
            endif
          endif
Ctest
C          if (ndb(k,m).ge.ndbmin) then
C            ndb(k,m)=-ndb(k,m)
C          endif
Ctest
          ksdb=min(1+iabs(ndb(k,m)),102)
          kspb=min(1+iabs(npb(k,m)),102)
          nsdb(ksdb)=nsdb(ksdb)+1
          nspb(kspb)=nspb(kspb)+1
 5163   continue
        kssdbf=1
        do 5167 j=1,nssb
          do 5165 i=1,nssb

Ctest?
C            if (ndsb(i,j,k).ge.nsbmin) then
C              ndsb(i,j,k)=-ndsb(i,j,k)
C            endif
Ctest?
            kssdb=min(1+iabs(ndsb(i,j,k)),102)
            nssdb(kssdb)=nssdb(kssdb)+1
            if (ndsb(i,j,k).lt.0) kssdbf=kssdbf+1
 5165     continue
 5167   continue
        isorc(k)=isorc(k)*2
        nssdbf(kssdbf)=nssdbf(kssdbf)+1
 5177 continue
c
c report the numbers of boxes and subboxes with each number of points
c
      write(6,'('' '')')
c
      mssdbf=0
      do 5403 k=1,nssbsp
        km=k-1
        write(6,'('' boxes with'',i8,'' subboxes filled:'',i10)')
     1    km,nssdbf(k)
        mssdbf=mssdbf+nssdbf(k)
 5403 continue
      write  (6,'(''           '',8x,''     total boxes:'',i10)')
     1    mssdbf
c
      write(6,'('' '')')
c
      msdb=0
      mspb=0
      mssdb=0
      do 5405 k=1,102
        km=k-1
        if (km.eq.101) then
          akm='>'
          km=km-1
        else
          akm=' '
        endif
        write(6,'('' topo,land,subboxes with '',a1,i3,
     1    '' points:'',3i8)')
     2    akm,km,nsdb(k),nspb(k),nssdb(k)
        msdb=msdb+nsdb(k)
        mspb=mspb+nspb(k)
        mssdb=mssdb+nssdb(k)
 5405 continue
      write  (6,'('' topo,land,subboxes      '',1x,3x,
     1    '' totals:'',3i8)')
     2  msdb,mspb,mssdb
c
      write(6,'('' '')')
C
c
c *** All rows of topo data have been processed.
c     Now calculate the heights (hgtk) and sea mask (smk).

	ALLOCATE(GLAT(IMJM))
	ALLOCATE(GLON(IMJM))

C	dtr=acos(-1.)/180.
	
        tph0=tph0d*dtr
        wb=wbd*dtr
        sb=sbd*dtr
        dlm=dlmd*dtr
        dph=dphd*dtr
	tph=sb-dph
	tdlm=dlm+dlm

C	write(6,*) 'original values '
C	write(6,*) tph0,wb,sb,dlm,dph,tph,dtr

	 do j=1,jm
	khl=im*(j-1)-(j-1)/2+1
	khh=im*j-j/2

c
         tlm=wb-tdlm+mod(j+1,2)*dlm
         tph=tph+dph
         stph=sin(tph)
         ctph=cos(tph)
c
         do k=khl,khh
            tlm=tlm+tdlm
            sinphi=ctph0*stph+stph0*ctph*cos(tlm)
            glat(k)=asin(sinphi)
            coslam=ctph*cos(tlm)/(cos(glat(k))*ctph0)
     .            -tan(glat(k))*tan(tph0)
            coslam=min(coslam,1.)
            fact=1.
            if (tlm .gt. 0.0) fact=-1.
            glon(k)=-tlm0d*dtr+fact*acos(coslam)
	glat(k)=glat(k)/dtr
	glon(k)=-glon(k)/dtr
C	write(6,*) glat(k),glon(k)
         enddo
      enddo

CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
c
      do1077: do M=1,4
      do1076: do k=1,imjm

	if (NDB(K,M) .le. 0) then
C	write(6,*) 'K,M,NDB(K,M)= ', K,M,NDB(K,M)
	endif
C     IF (NDB(K,M).GT.0) GO TO 131
C       NO DATA IN THE SUB-BOX: ASSUME PERCENTAGE OF WATER
C       SURFACE OF THE SUB-BOX TO BE 50 PERCENT, AND LEAVE
C       ELEVATION ZERO:
      write(2000,*)k,m,npb(k,m)
      if (npb(k,m).le.0) then
        PSB(K,M)=50.
      else
        PSB(K,M)=PSB(K,M)/npb(K,M)
      endif

      IF (NDB(K,M).LE.0) THEN
        HSB(K,M)=0.0
      ELSE
        HSB(K,M)=HSB(K,M)/NDB(K,M)
Cmp	write(6,*) 'ave hgt= ', HSB(K,M),NDB(K,M)
      ENDIF
      enddo do1076
      enddo do1077

	DEALLOCATE(NPB)

	ALLOCATE(HGTK(IMJM))
	ALLOCATE(SMK(IMJM))
c
CNEW
      do108: DO K=1,IMJM
        HGTK(K)=0.
      enddo do108
C

        if (.not. sigma) then
        kstart=KHL22
        kend=KHH22
        endif

        if (sigma) then
        kstart=1
        kend=IMJM
        endif

        write(6,*) 'looping on 109 from  ', kstart, ' to ', kend


C      DO 109 K=KHL22,KHH22
       do109: DO  K=kstart,kend

C
      PSM=0.
      do111: DO  M=1,4
        PSM=PSM+PSB(K,M)
      ENDDO do111
      PAV=PSM*0.25

      IF (PAV.LE.50.) GO TO 121

C       (IF NO DATA WAS AVAILABLE WITHIN ANY OF THE FOUR SUB-BOXES,
C       OR THE PERCENTAGE OF WATER SURFACE IS EXACTLY 50, THE POINT
C       IS DECLARED AS LAND)
C
C       THE POINT IS DEFINED AS SEA/LAKE:
C***  CALCULATE THE ELEVATION BY ASSIGNING TO THE FOUR SUB-BOX SQUARE
C***  THE ELEVATION OF THE SUB-BOX WHICH HAD THE MAXIMUM PERCENTAGE OF
C***  WATER COVERAGE, PSB(K,M). (NOTE: "LARGE LAKES OR INLAND SEAS
C***  WILL NOT BE CODED AS 100" ON THE NAVY TAPE !!)
C***
      PSBM=50.
      do411: DO M=1,4
      IF(NDB(K,M).EQ.0.OR.PSB(K,M).LE.PSBM) cycle do411
	if (.not. sigma) then
         HGTK(K)=HBM2(K)*HSB(K,M)
	else
	 HGTK(K)=HSB(K,M)
	endif
         PSBM   =        PSB(K,M)
      ENDDO do411
      IF (HGTK(K).LE.HWELP) cycle do109
      WRITE(6,412) K,PSBM,HGTK(K)
 412  FORMAT('  K=',I5,'  PSBM=',F5.1,'  HGTK(K)=',F5.0)
C       WATER POINT IS HIGHER THAN HWELP.  DECLARE IT LAND:
      SMK(K)=0.
           cycle do109
C
C       THE POINT IS DEFINED AS LAND:
C
  121      SMK(K)=0.
C	write(6,*) 'ever here?????'
C
      HS   (1)=AMAX1(HSB(K,4),HSB(K,1))
      NDPSB(1)=      NDB(K,4)+NDB(K,1)
      HS   (2)=AMAX1(HSB(K,3),HSB(K,2))
      NDPSB(2)=      NDB(K,3)+NDB(K,2)
      HS   (3)=AMAX1(HSB(K,4),HSB(K,3))
      NDPSB(3)=      NDB(K,4)+NDB(K,3)
      HS   (4)=AMAX1(HSB(K,1),HSB(K,2))
      NDPSB(4)=      NDB(K,1)+NDB(K,2)
C
C     NOW CALCULATE THE NUMBER OF PAIRS OF SUB-BOXES WHICH HAVE
C     NAVY MOUNTAIN DATA IN AT LEAST ONE OF THE TWO SUB-BOXES
C
C       HOW MANY PAIRS OF SUB-BOXES ARE THERE WITH HEIGHT DATA?

      NPHD=4
      do151: DO N=1,4
        IF(NDPSB(N).EQ.0) NPHD=NPHD-1
      ENDDO do151  
      IF(NPHD.GT.0) GO TO 112

C
C       THERE WAS NO DATA WITHIN THE GRID BOX AND ITS ELEVATION IS
C       LEFT ZERO.  DON'T WORRY ABOUT IT: IF IT'S A LAND POINT ITS
C       ELEVATION WILL BE RAISED IN 'PTETA' TO MATCH THAT UNDER
C       THE LOWEST NEIGHBORING NON-ZERO WIND POINT.  HOWEVER:
C       SHOULD IT BE A WATER POINT AFTER ALL?  DECLARE IT A WATER
C       POINT IF THE AVERAGE OF THE FOUR SUB-BOXES NEIGHBORING TO
C       K AND SOUTH OF IT IS MORE THAN 50 PERCENT WATER:

      PAV=0.25*(PSB(K+KSE,3)+PSB(K+KSE,2)
     &         +PSB(K+KSW,1)+PSB(K+KSW,2))
Cmp      IF(PAV.GT.50.) SMK(K)=1.
      cycle do109
C
 112  SHS=0.
      do110: DO N=1,4
        SHS=SHS+HS(N)
      ENDDO do110

	if (.not. sigma) then
      HGTK(K)=HBM2(K)*SHS/NPHD
	else
      HGTK(K)=SHS/NPHD
	endif
C
      enddo do109

	DEALLOCATE(PSB)

C****SMK**smk************************
C
C	2700,1350 for 8 minute
C	5400,2700 for 4 minute
C
C	Use the eta_sea_us call if domain is within box extending from
C	10N,180W to 80N,30W.  This uses 2 minute data
C
C

C	PAUSE 

	if     (seares .eq. 2) then
		CALL get_sea(smk,4501,2101)
	elseif (seares .eq. 4) then
		CALL get_sea(SMK,5400,2700)
	elseif (seares .eq. 8) then
		CALL get_sea(SMK,2700,1350)
	elseif (seares .eq. 30) then
		CALL get_sea30(SMK)
	else
		write(6,*) 'BAD VALUE FOR SEARES!!!!!! ' , seares
		STOP
	endif

C	PAUSE

C
C*************************************
C
C     FOR AESTHETIC REASONS, MAKE SURE POINTS ALONG THE BUFFER LINES
C     REMAIN DECLARED WATER
	if (.not. sigma) then
          do431: DO K=KHL22,KHH22
             SMK(K)=1.+HBM2(K)*(SMK(K)-1.)
          ENDDO do431
	endif

	ALLOCATE(DUM2D(IMT,JMT))

        call conh12t(smk,imjm,1,dum2d,imt,jmt)
	write(6,*) 'sea mask  '
        do J=JMT,1,-2
C        write(6,273)(dum2d(I,J),I=1,IMT,4)
        enddo

	DEALLOCATE(DUM2D)

C-----------------------------------------------------------
C***  CALCULATE AND SAVE AVERAGE ELEVATIONS
C***
	
	ALLOCATE(AGTK(IMJM))


      AGTK(KHL00:KHH00)=0.
      do302: DO K=KHL00,KHH00
        NSBHD=4
        do303: DO N=1,4
         IF(NDB(K,N).EQ.0)NSBHD=NSBHD-1
        ENDDO do303
C	if (NSBHD .ne. 0) write(6,*) 'NSBHD= ', NSBHD
        IF(NSBHD.EQ.0)  cycle do302
        AGTK(K)=(HSB(K,1)+HSB(K,2)+HSB(K,3)+HSB(K,4))/NSBHD
C	write(6,*) 'AGTK(K)= ', AGTK(K)
      ENDDO do302

	DEALLOCATE(HSB)
	DEALLOCATE(NDB)
C***
C***  THE silhouette/mean MOUNTAINS:  AT LAND POINTS WITH CONCAVE
C***  ACTUAL (AVERAGE) TOPOGRAPHY, REPLACE THE
C***  SILHOUETTE ELEVATION WITH THE AVERAGE ELEVATION
C***  (22 FEB 94)
      do311: DO K=KHL22,KHH22
      IF(SMK(K).GT.0.5) cycle do311
      ALAH=AGTK(K+1)+AGTK(K+NINC)+AGTK(K-1)
     1    +AGTK(K-NINC)+2.*(AGTK(K+KNE)
     2    +AGTK(K+KNW)+AGTK(K+KSW)+AGTK(K+KSE))
     3    -12.*AGTK(K)
      IF(ALAH.GE.0.)HGTK(K)=AGTK(K)
      ENDDO do311
c
c     If K is a point seen as a "valley" when looking at three-point
c     averages in any one of the four directions, and it is at the
c     same time not higher than each of its four nearest neighbors,
c     and also not higher than each of its four second-nearest
c     neighbors, choose always the mean elevation (23 June 97)
c
c     (Saddle points are expected to be frequently declared mean as
c     a result)
c
      do316: DO K=KHL22,KHH22
      IF(SMK(K).GT.0.5) cycle
      if (agtk(k).gt.agtk(k+kne) .and. agtk(k).gt.agtk(k+ knw) .and.
     2    agtk(k).gt.agtk(k+ksw) .and. agtk(k).gt.agtk(k+ kse))
     3    cycle do316
      if (agtk(k).gt.agtk(k+  1) .and. agtk(k).gt.agtk(k+ninc) .and.
     2    agtk(k).gt.agtk(k-  1) .and. agtk(k).gt.agtk(k-ninc))
     3    cycle do316
        sumtx =agtk(k-   1)+agtk(k)+agtk(k+   1)
        sumtxp=agtk(k+ ksw)+agtk(k)+agtk(k+ kne)
        sumty =agtk(k-ninc)+agtk(k)+agtk(k+ninc)
        sumtyp=agtk(k+ kse)+agtk(k)+agtk(k+ knw)
          if (sumtx .lt.agtk(k+ ksw)+agtk(k-ninc)+agtk(k+ kse) .and.
     2        sumtx .lt.agtk(k+ knw)+agtk(k+ninc)+agtk(k+ kne))
     3          hgtk(k)=agtk(k)
          if (sumtxp.lt.agtk(k-ninc)+agtk(k+ kse)+agtk(k+   1) .and.
     2        sumtxp.lt.agtk(k-   1)+agtk(k+ knw)+agtk(k+ninc))
     3          hgtk(k)=agtk(k)
          if (sumty .lt.agtk(k+ kse)+agtk(k+   1)+agtk(k+ kne) .and.
     2        sumty .lt.agtk(k+ ksw)+agtk(k-   1)+agtk(k+ knw))
     3          hgtk(k)=agtk(k)
          if (sumtyp.lt.agtk(k+   1)+agtk(k+ kne)+agtk(k+ninc) .and.
     2        sumtyp.lt.agtk(k-ninc)+agtk(k+ ksw)+agtk(k-   1))
     3          hgtk(k)=agtk(k)
      ENDDO do316
c
c    the silhouette/mean topography is done
      write(6,'('' silhouette/mean topography is done'')')
C

CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
CCCCCCCCCCCCCCC       CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
CCCCCCCCCCCCCCC Z0EFF CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
CCCCCCCCCCCCCCC       CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
C
c    process the high-resolution arrays for roughness data
c
c zero out the arrays for the grid box averages
c
	ALLOCATE(HSSA(IMJM),NDSA(IMJM))

      do 4203 k=1,imjm
        hssa(k)=0.0
        ndsa(k)=0
 4203 continue
c
c invert the negative numbers and find grid-box average height
c
      do 4303 k=1,imjm
        do 4302 jssb=1,nssb
          do 4301 issb=1,nssb
            if (ndsb(issb,jssb,k).lt.0) then
              ndsb(issb,jssb,k)=-ndsb(issb,jssb,k)
            endif
            if (ndsb(issb,jssb,k).gt.0) then
              hssa(k)=hssa(k)+hssb(issb,jssb,k)
              ndsa(k)=ndsa(k)+ndsb(issb,jssb,k)
              hssb(issb,jssb,k)=hssb(issb,jssb,k)/
     1                             ndsb(issb,jssb,k)
C	write(6,*) 'found an hssb value! ',
C     + issb,jssb,hssb(issb,jssb,k)
            endif
 4301     continue
 4302   continue
 4303 continue
c fill in the blanks with the average over the whole box
c
      do 4343 k=1,imjm
        ifill=0
        if (ndsa(k).eq.0) then
          write(6,'('' We have problems, no heights in k'',i8,2f6.1)')
     1      k,glat(k),glon(k)
          ndsa(k)=1
          hssa(k)=0
        else
          hssa(k)=hssa(k)/ndsa(k)
        endif
        do 4342 jssb=1,nssb
          do 4341 issb=1,nssb
            if (ndsb(issb,jssb,k).eq.0.0) then
              hssb(issb,jssb,k)=hssa(k)
              ndsb(issb,jssb,k)=1
              ifill=ifill+1
            endif
 4341     continue
 4342   continue
        if (ifill.gt.0) then
C          write(6,'('' '',i6,'' filled points for k='',i8)')
C     1      ifill,k
        endif
 4343 continue

	DEALLOCATE(GLAT,GLON)
c
      write(6,'('' empty subboxes have been filled'')')
c
      do 4439 k=1,imjm
C         IMT=2*IM-1
          JX=(K-1)/IMT+1
          IX=K-(JX-1)*IMT
          IF(IX.LE.IM)THEN
            I=2*IX-1
            J=2*JX-1
          ELSE
            I=2*(IX-IM)
            J=2*JX
          ENDIF
c       write(6,'('' '',3i6,''=k,i,j'',f20.10,i10,''=h,n'')')
c    1    k,i,j,hssa(k),ndsa(k)
 4439 continue

	DEALLOCATE(HSSA,NDSA)
c
c  constants:
c
      a=6371229.0
      z0 = 0.15
c     cd = 0.3
c     cd = 0.8
      cd = 0.6
      vk = 0.4
      rvk2 = 1.0 / ( vk ** 2 )
      rz0 = 1.0 / z0
      dmin=1.0e-6
      hmin=2.0*z0+dmin
      wtamin=dmin
c
      write(6,'('' constants defined'')')
c
c zero out statistics
c

	ALLOCATE(KNDIR(NSSBSP,4,NSORC2))
	ALLOCATE(KLDIR(NSSBSP,4,NSORC2))
	ALLOCATE(KWDIR(NSSBSP,4,NSORC2))

	ALLOCATE(kisrch(3,4,nsorc2),klsrch(3,4,nsorc2))
	ALLOCATE(kwsrch(3,4,nsorc2))

      do 4494 l=1,nsorc2
        do 4493 m=1,4
          hamean(m,l)=0.0
          hlmean(m,l)=0.0
          hwmean(m,l)=0.0
          asmean(m,l)=0.0
          almean(m,l)=0.0
          awmean(m,l)=0.0
          zemean(m,l)=0.0
          zlmean(m,l)=0.0
          zwmean(m,l)=0.0
          hamin(m,l)= 1.0e30
          hamax(m,l)=-1.0e30
          asmin(m,l)= 1.0e30
          asmax(m,l)=-1.0e30
          zemin(m,l)= 1.0e30
          zemax(m,l)=-1.0e30
          ihamax(m,l)=0
          ihamin(m,l)=0
          iasmax(m,l)=0
          iasmin(m,l)=0
C          izemax(m,l)=0
C          izemin(m,l)=0
          jhamax(m,l)=0
          jhamin(m,l)=0
C          jasmax(m,l)=0
C          jasmin(m,l)=0
          jzemax(m,l)=0
          jzemin(m,l)=0
          khamax(m,l)=0
          khamin(m,l)=0
          kasmax(m,l)=0
          kasmin(m,l)=0
          kzemax(m,l)=0
          kzemin(m,l)=0
          do 4491 k=1,nssbsp
            kndir(k,m,l)=0
            kldir(k,m,l)=0
            kwdir(k,m,l)=0
 4491     continue
          do 4492 k=1,3
            kisrch(k,m,l)=0
            kwsrch(k,m,l)=0
            klsrch(k,m,l)=0
 4492     continue
 4493   continue
 4494 continue
c
      write(6,'('' statistics zeroed out'')')
c
c calculate 4 z0's for each grid box
c

	write(6,*) 'memory here?'

C	PAUSE

	ALLOCATE (zha(imjm,4),zas(imjm,4))
	ALLOCATE (z0eff(imjm,4))

      do 4557 k=1,imjm
C	write(6,*) 'here 1 ', k
Cmp
C	goto 4557
Cmp
c
          l=isorc(k)+1
c
c       find the local mesh lengths
c
C----------------------------------------------------------
C***
C***  CONVERT FROM ONE-DIMENSIONAL K VALUES ON THE E-GRID
C***  TO I,J VALUES ON THE FILLED E-GRID.
C***
C----------------------------------------------------------
C
C       IMT=2*IM-1
        JX=(K-1)/IMT+1
        IX=K-(JX-1)*IMT
        IF(IX.LE.IM)THEN
          I=2*IX-1
          J=2*JX-1
        ELSE
          I=2*(IX-IM)
          J=2*JX
        ENDIF

        phl = ( j-1 ) * dphd + sbd
c
        dlmdl = dlmd * dtr * cos(phl*dtr)
        dphdl = dphd * dtr
c
c       find the length of the sides of the obstacles
c
        ds(1)=a*rssb*dphdl
        ds(3)=a*rssb*dlmdl
        ds(2)=sqrt(ds(1)**2+ds(3)**2)
        ds(4)=ds(2)
        area=dphdl*dlmdl*a*a*2.0
        rarea=1.0/area
c
          if ((i.eq.j).or.((im-i).eq.(jm-j))) then
Cmp            write(6,'('' '',i6,''=i'',i6,''=j'')') i,j
Cmp            write(6,'('' ds  ew nesw ns nwse'',4f12.3)')
Cmp     1        ds
          endif
c
c
c       test whether this is a boundary point
c
        if (hbm2(k).eq.0.0) then
c
c         set boundary points to z0
c
          do 4007 m=1,4
            z0eff(k,m)=z0
            zha(k,m)=0.0
            zas(k,m)=0.0
 4007     continue
C	write(6,*) 'setting boundary point'

        else

c
c         calculate z0eff for interior points
c
          mthdz0=2
c
c         mthdz0 1, find obstacles by searching for
c         relative minima and maxima along lines in each direction
c   Abandoned, as this was an older and an inferior option, having had
c              no consolidation of obstacles.  FM, June 97
c
c         mthdz0 2, find obstacles by searching for
c         relative minima and maxima along lines in each direction
c         and eliminating insignificant relative extrema
c
          if (mthdz0.eq.2) then
c
c         loop for directions
c
C	write(6,*) 'hit loop 4287'

          do 4287 m=1,4
            hhdir=0.0
            htdir=0.0
           ndir=0.0
            imin=1
            if (mod(m,2).eq.1) then
c             cardinal direction, diagonal on grid
              imax=nssb2m
            else
c             diagonal direction, along grid
              imax=nssb
            endif
c
c           loop to select a line of subboxes
c
            do 4285 is=imin,imax
C	write(6,*) 'inside 4285 ',imin,is,imax
              if (mod(m,2).eq.1) then
c               cardinal direction, diagonal on grid
                jmin=max(0,is-nssb)
                jmax=min(nssbp,is+1)
              else
c               diagonal direction, along grid
                jmin=0
                jmax=nssbp
              endif
              llsb=jmax-jmin+1
              nexvlf=0
c
c             loop to search for extrema along the line of subboxes
c
              do 4223 js=jmin,jmax
C	write(6,*) 'start 4223 ', jmin,js,jmax
c               select subbox indices by direction indicator
                if (m.eq.1) then
c                 east to west
                  issb=1+is-js
                  jssb=js
                  kssb=k
                endif
                if (m.eq.2) then
c                 southwest to northeast
                  issb=js
                  jssb=is
                  kssb=k
                endif
                if (m.eq.3) then
c                 south to north
                  issb=js
                  jssb=nssb-is+js
                  kssb=k
                endif
                if (m.eq.4) then
c                 southeast to northwest
                  issb=is
                  jssb=js
                  kssb=k
                endif
c               reindex to the interior of a box
                if (issb.lt.1) then
                  issb=issb+nssb
                  kssb=kssb+ksw
                endif
                if (jssb.lt.1) then
                  jssb=jssb+nssb
                  kssb=kssb+kse
                endif
                if (issb.gt.nssb) then
                  issb=issb-nssb
                  kssb=kssb+kne
                endif
                if (jssb.gt.nssb) then
                  jssb=jssb-nssb
                  kssb=kssb+knw
                endif
c               find minima and maxima
                if (js.eq.jmin) then
c                 first point, taken to be first minimum
                  hmin1=hssb(issb,jssb,kssb)
                  isrch=1
                else
c                 any other point
                  if (isrch.eq.1) then
c                   looking for the first minimum
                    if (hmin1.gt.hssb(issb,jssb,kssb)) then
c                     lower the first minimum
                      hmin1=hssb(issb,jssb,kssb)
                    elseif (hmin1.lt.hssb(issb,jssb,kssb)) then
c                     we have a minimum, now look for maximum
                      nexvlf=nexvlf+1
                      exvl(nexvlf)=hmin1
                      hmax2=hssb(issb,jssb,kssb)
                      isrch=2
                    endif
                  elseif (isrch.eq.2) then
c                   looking for a maximum
                    if (hmax2.lt.hssb(issb,jssb,kssb)) then
c                     raise the maximum
                      hmax2=hssb(issb,jssb,kssb)
                    elseif (hmax2.gt.hssb(issb,jssb,kssb)) then
c                     we have a maximum, now look for minimum
                      hmin3=hssb(issb,jssb,kssb)
                      isrch=3
                    endif
                  elseif (isrch.eq.3) then
c                   looking for a minimum
                    if (hmin3.gt.hssb(issb,jssb,kssb)) then
c                     lower the minimum
                      hmin3=hssb(issb,jssb,kssb)
                    endif
                    if ((hmin3.lt.hssb(issb,jssb,kssb)).or.
     .                  (js.eq.jmax)) then
c                     we either have another minimum or are done
c                     add an obstacle to the totals
c                     hodir=hmax2-0.5*(hmin1+hmin3)
c                     htdir=htdir+hodir
c                     hhdir=hhdir+hodir**2
c                     ndir=ndir+1
c                     add an obstacle to the array of extrema
                      nexvlf=nexvlf+1
                      exvl(nexvlf)=hmax2
                      nexvlf=nexvlf+1
                      exvl(nexvlf)=hmin3
c                     move the minimum value to front of next mt
                      hmin1=hmin3
c                     now we are looking for another maximum
                      hmax2=hssb(issb,jssb,kssb)
                      isrch=2
                    endif
                  endif
                endif
C		write(6,*) 'end 4223 '
 4223         continue
C	write(6,*) 'BEYOND 4223'
C	write(6,*) 'isrch, m, l= ', isrch,m,l
              kisrch(isrch,m,1)=kisrch(isrch,m,1)+1
              kisrch(isrch,m,l)=kisrch(isrch,m,l)+1
              if (smk(k).gt.0.5) then
                kwsrch(isrch,m,1)=kwsrch(isrch,m,1)+1
                kwsrch(isrch,m,l)=kwsrch(isrch,m,l)+1
              else
                klsrch(isrch,m,1)=klsrch(isrch,m,1)+1
                klsrch(isrch,m,l)=klsrch(isrch,m,l)+1
              endif
C	write(6,*) 'BEYOND SRCH'
c
c  consolidation of obstacles
c
C	write(6,*) 'how many obstacles? ', nexvlf
              if (nexvlf.ge.5) then
c
c  calculate z0eff of the line just processed,
c  assuming that the width of the obstacles is unity
c
c  sl = length of the line along which obstacles are calculated
c  nlob = n of the peak of the last obstacle along the line
c
               if (m.eq.1) then
                  sl=llsb*ds(3)*2.0
                elseif (m.eq.3) then
                  sl=llsb*ds(1)*2.0
                else
                  sl=llsb*ds(2)
                endif
c
                nlob=nexvlf-1
                saob=0.0
                shhob=0.0
                do 4235 ilob=2,nlob,2
                  hi=exvl (ilob)-0.5*(exvl (ilob-1)+exvl (ilob+1))
                  saob=saob+hi
                  shhob=shhob+hi**2
 4235           continue
                if (saob.gt.hmin) then
                  hob=shhob/saob
                else
                  hob=hmin
                  saob=hmin
                  shhob=hmin**2
                endif
c
c  calculate a tentative value of z0eff for this line
c
	if (0.5*rz0*hob .lt. 0) write(6,*) 'neg alog', 0.5*rz0*hob
                wtarea=
     2            0.5*cd*rvk2*saob/sl +
     3            1.0/((alog(0.5*rz0*hob))**2)

                if (wtarea.lt.wtamin) then
                  write(6,'('' nonpositive tentative wtarea'',
     2              f20.10,2i8)')
     3              wtarea,k,m
                  wtarea=wtamin
                endif
                zeffl =0.5*hob/exp(1.0/sqrt(wtarea))

Cmp	write(6,*) 'in z0eff code, wtarea,zeffl = ', wtarea,zeffl
c
c  of the one or more inside minima, find the highest
c
 4243           continue
                hghmn=exvl(3)
                nhghmn=3
                nlim=3
c
c  nlim = n of the last minimum
c
c  nlim = 5 if there is only one inside minimum; it is the highest
c
                if(nexvlf.gt.5) then
                  nlim=nexvlf-2
                  do 4245 imn=5,nlim,2
                    if (hghmn.lt.exvl(imn)) then
                      hghmn=exvl(imn)
                      nhghmn=imn
                    endif
 4245             continue
                endif
c
c  the highest inside minimum has been found.
c  does removing it and compressing exvl increase z0eff of the line?
c
                nhmm=nhghmn-1
                do 4251 iex=1,nhmm                  
		exvlc(iex)=exvl(iex)
 4251           continue
                if (exvl(nhghmn+1).gt.exvl(nhmm)) then
                  exvlc(nhmm)=exvl(nhghmn+1)
                endif
c
c  the higher of the two maxima has been selected and stored
c  now transfer the remainder of exvl to exvlc
c
                do 4253 iex=nhghmn,nlim
                  exvlc(iex)=exvl(iex+2)
 4253           continue
c
c  calculate z0eff of the compressed array, zefflc
c
                nlob=nlim-1
                saob=0.0
                shhob=0.0
                do 4255 ilob=2,nlob,2
                  hi=exvlc(ilob)-0.5*(exvlc(ilob-1)+exvlc(ilob+1))
                  saob=saob+hi
                  shhob=shhob+hi**2
 4255           continue
                if (saob.gt.hmin) then
                  hob=shhob/saob
                else
                  hob=hmin
                  saob=hmin
                  shhob=hmin**2
                endif
c
c  calculate a tentative value of z0eff for this line
c
                wtarea=
     2            0.5*cd*rvk2*saob/sl +
     3            1.0/((alog(0.5*rz0*hob))**2)
                if (wtarea.lt.wtamin) then
                  write(6,'('' nonpositive tentative wtarea'',
     2              f20.10,2i8)')
     3              wtarea,k,m
                  wtarea=wtamin
                endif
                zefflc=0.5*hob/exp(1.0/sqrt(wtarea))
c
                if (zeffl.lt.zefflc) then
c
c  switch to compressed exvl and either exit the consolidation code
c  or search for another minimum to remove
c
                  do 4257 iex=nhmm,nlim
                    exvl(iex)=exvlc(iex)
 4257             continue
                  nexvlf=nlim
c
                  if (nexvlf.lt.5) go to 4263
c
                  zeffl =zefflc
                  go to 4243
                else
                  go to 4263
                endif
c
              endif
c
 4263         continue
c
c  There has been at most only one obstacle to start with,
c  or consolidation of obstacles is completed.
c  Add obstacles, if any, to the totals
c
              if (nexvlf.ge.3) then
                nlob=nexvlf-1
                do 4267 ilob=2,nlob,2
                  hodir=exvl(ilob)-0.5*(exvl(ilob-1)+exvl(ilob+1))
        if (hodir .eq. 0) then
        write(6,*) 'increasing hodir!!! '
        hodir=hmin
        endif
                  htdir=htdir+hodir
                  hhdir=hhdir+hodir**2
                  ndir=ndir+1
 4267           continue
              endif
C	write(6,*) 'end 4285 ', is
 4285       continue
C	write(6,*) 'past 4285, m= ', m
c           in case we didn't find any obstacles
            if (ndir.eq.0) then
              ndir=1
              htdir=hmin
              hhdir=hmin**2
            endif
c           fill directional obstacle totals
            nadir(m)=ndir
            htadir(m)=htdir
            hhadir(m)=hhdir
            ndirp=ndir+1
	   kndir(ndirp,m,1)=kndir(ndirp,m,1)+1
            kndir(ndirp,m,l)=kndir(ndirp,m,l)+1
            if (smk(k).gt.0.5) then
              kwdir(ndirp,m,1)=kwdir(ndirp,m,1)+1
              kwdir(ndirp,m,l)=kwdir(ndirp,m,l)+1
            else
              kldir(ndirp,m,1)=kldir(ndirp,m,1)+1
              kldir(ndirp,m,l)=kldir(ndirp,m,l)+1
            endif
 4287     continue
C	write(6,*) 'past 4287 ', K
c
c         end of mthdz0 2
c
          else
c
c         default mthdz0, all h and a are based on hmin
c
          do 4428 m=1,4
            nadir(m)=1
            htadir(m)=hmin
            hhadir(m)=hmin**2
 4428     continue
c
c         end of default mthdz0
c
          endif
c
          if ((i.eq.j).or.((im-i).eq.(jm-j))) then
Cmp            write(6,'('' na  ew nesw ns nwse'',4i12)')
C     1        nadir
C            write(6,'('' hta ew nesw ns nwse'',4f12.4)')
C     1        htadir
C            write(6,'('' hha ew nesw ns nwse'',4f12.2)')
Cmp     1        hhadir
          endif
c
          do 4437 m=1,4
c
c         find the total area of obstacles in each direction
c
            ao(m)=htadir(m)*ds(m)*rarea
c
c         find the average heights of obstacles, use hmin to avoid zero
c           the average is weighted by the height of the obstacle
c
	if (htadir(m) .lt. 0) write(6,*) 'divide by zero!'
            ha(m)=hhadir(m)/htadir(m)
c
 4437     continue
c
c
          if ((i.eq.j).or.((im-i).eq.(jm-j))) then
Cmp            write(6,'('' ao  ew nesw ns nwse'',4f12.5)')
C     1        ao
C            write(6,'('' ha  ew nesw ns nwse'',4f12.3)')
Cmp     1        ha
          endif
c
c         calculate z0eff
c
          do 4552 m=1,4
            zha(k,m)=ha(m)
            zas(k,m)=ao(m)
c
c accumulate statistics on zha and zas
c
            if (hamin(m,1).gt.zha(k,m)) then
              hamin(m,1)=zha(k,m)
              ihamin(m,1)=i
              jhamin(m,1)=j
              khamin(m,1)=k
            endif
            if (hamin(m,l).gt.zha(k,m)) then
              hamin(m,l)=zha(k,m)
              ihamin(m,l)=i
              jhamin(m,l)=j
              khamin(m,l)=k
            endif
            if (hamax(m,1).lt.zha(k,m)) then
              hamax(m,1)=zha(k,m)
              ihamax(m,1)=i
              jhamax(m,1)=j
              khamax(m,1)=k
            endif
            if (hamax(m,l).lt.zha(k,m)) then
              hamax(m,l)=zha(k,m)
              ihamax(m,l)=i
              jhamax(m,l)=j
              khamax(m,l)=k
	endif
            hamean(m,1)=hamean(m,1)+zha(k,m)
            hamean(m,l)=hamean(m,l)+zha(k,m)
            if (smk(k).gt.0.5) then
              hwmean(m,1)=hwmean(m,1)+zha(k,m)
              hwmean(m,l)=hwmean(m,l)+zha(k,m)
            else
              hlmean(m,1)=hlmean(m,1)+zha(k,m)
              hlmean(m,l)=hlmean(m,l)+zha(k,m)
            endif
c
            if (asmin(m,1).gt.zas(k,m)) then
              asmin(m,1)=zas(k,m)
              iasmin(m,1)=i
C              jasmin(m,1)=j
              kasmin(m,1)=k
            endif
            if (asmin(m,l).gt.zas(k,m)) then
              asmin(m,l)=zas(k,m)
              iasmin(m,l)=i
C              jasmin(m,l)=j
              kasmin(m,l)=k
            endif
            if (asmax(m,1).lt.zas(k,m)) then
              asmax(m,1)=zas(k,m)
              iasmax(m,1)=i
C              jasmax(m,1)=j
              kasmax(m,1)=k
            endif
            if (asmax(m,l).lt.zas(k,m)) then
              asmax(m,l)=zas(k,m)
              iasmax(m,l)=i
C              jasmax(m,l)=j
              kasmax(m,l)=k
            endif
            asmean(m,1)=asmean(m,1)+zas(k,m)
            asmean(m,l)=asmean(m,l)+zas(k,m)
            if (smk(k).gt.0.5) then
              awmean(m,1)=awmean(m,1)+zas(k,m)
              awmean(m,l)=awmean(m,l)+zas(k,m)
            else
              almean(m,1)=almean(m,1)+zas(k,m)
              almean(m,l)=almean(m,l)+zas(k,m)
            endif
c
c test for out-of-range values
c
            if (zha(k,m).le.hmin) then
c             write(6,'('' nonpositive zha(k,m,1)'',f20.10,2i8)')
c    1          zha(k,m),k,m
              zha(k,m)=hmin
            endif
c
            if (zas(k,m).lt.0.0) then
              write(6,'('' negative zha(k,m,1)'',f20.10,2i8)')
     1          zas(k,m),k,m
              zas(k,m)=0.0
            endif
c
c calculate the effective z0
c from zas and zha
c
            wtarea=
     1        0.5*cd*rvk2*zas(k,m)+
     2        1.0/((alog(0.5*rz0*zha(k,m)))**2)
            if (wtarea.lt.wtamin) then
              write(6,'('' nonpositive wtarea'',f20.10,2i8)')
     1          wtarea,k,m
              wtarea=wtamin
            endif
            z0eff(k,m)=0.5*zha(k,m)/exp(1.0/sqrt(wtarea))
C	if (z0eff(k,m).ne. 0.15) then
C	write(6,*) 'zoeff= ', z0eff(k,m)
C	endif
c
c accumulate statistics
c
            if (zemin(m,1).gt.z0eff(k,m)) then
              zemin(m,1)=z0eff(k,m)
C              izemin(m,1)=i
              jzemin(m,1)=j
              kzemin(m,1)=k
            endif
            if (zemin(m,l).gt.z0eff(k,m)) then
              zemin(m,l)=z0eff(k,m)
C              izemin(m,l)=i
              jzemin(m,l)=j
              kzemin(m,l)=k
            endif
            if (zemax(m,1).lt.z0eff(k,m)) then
              zemax(m,1)=z0eff(k,m)
C	izemax(m,1)=i
              jzemax(m,1)=j
              kzemax(m,1)=k
            endif
            if (zemax(m,l).lt.z0eff(k,m)) then
              zemax(m,l)=z0eff(k,m)
C              izemax(m,l)=i
              jzemax(m,l)=j
              kzemax(m,l)=k
            endif
            zemean(m,1)=zemean(m,1)+z0eff(k,m)
            zemean(m,l)=zemean(m,l)+z0eff(k,m)
            if (smk(k).gt.0.5) then
              zwmean(m,1)=zwmean(m,1)+z0eff(k,m)
              zwmean(m,l)=zwmean(m,l)+z0eff(k,m)
            else
              zlmean(m,1)=zlmean(m,1)+z0eff(k,m)
              zlmean(m,l)=zlmean(m,l)+z0eff(k,m)
            endif

c
 4552     continue
c
          kountm(1)=kountm(1)+1
          kountm(l)=kountm(l)+1
          if (smk(k).gt.0.5) then
            kountw(1)=kountw(1)+1
            kountw(l)=kountw(l)+1
          else
            kountl(1)=kountl(1)+1
            kountl(l)=kountl(l)+1
          endif
c
        endif
C	write(6,*) 'end 4557 ', K
 4557 continue

	DEALLOCATE(ISORC)
	DEALLOCATE(HBM2)

	
c
      write(6,'('' z0eff calculation done'')')
c
c print statistics
c
      do 4876 l=nsorc2,1,-1
c
c report the numbers of boxes with each number of obstacles
      write(6,'('' '')')
      write(6,'('' statistics for topography source data'',i4)')
     .  l
      write(6,'('' '')')
c
        kndirt=0
        kldirt=0
        kwdirt=0
        do 4561 m=1,4
          kndirx(m)=0
          kldirx(m)=0
          kwdirx(m)=0
          andirx(m)=0.0
          aldirx(m)=0.0
          awdirx(m)=0.0
 4561   continue
      do 4563 k=1,nssbsp
        km=k-1
        kndirs=kndir(k,1,l)+kndir(k,2,l)+kndir(k,3,l)+kndir(k,4,l)
        kldirs=kldir(k,1,l)+kldir(k,2,l)+kldir(k,3,l)+kldir(k,4,l)
        kwdirs=kwdir(k,1,l)+kwdir(k,2,l)+kwdir(k,3,l)+kwdir(k,4,l)
        ktdirs=kndirs+kldirs+kwdirs
        if (ktdirs.gt.0) then
          write(6,'('' '',i3,''o'',4(1x,i6,i5,i6))')
     1    km,(kndir(k,m,l),kldir(k,m,l),kwdir(k,m,l),m=1,4)
          do 4562 m=1,4
            kndirx(m)=kndirx(m)+kndir(k,m,l)
            kldirx(m)=kldirx(m)+kldir(k,m,l)
            kwdirx(m)=kwdirx(m)+kwdir(k,m,l)
            andirx(m)=andirx(m)+km*kndir(k,m,l)
            aldirx(m)=aldirx(m)+km*kldir(k,m,l)
            awdirx(m)=awdirx(m)+km*kwdir(k,m,l)
 4562     continue
          kndirt=kndirt+kndirs
          kldirt=kldirt+kldirs
          kwdirt=kwdirt+kwdirs
        endif
 4563 continue
      do 4564 m=1,4
        if (kndirx(m).gt.0) then
          andirx(m)=andirx(m)/kndirx(m)
        endif
        if (kldirx(m).gt.0) then
          aldirx(m)=aldirx(m)/kldirx(m)
        endif
        if (kwdirx(m).gt.0) then
          awdirx(m)=awdirx(m)/kwdirx(m)
        endif
 4564 continue

	 do 4587 m=1,4
        if (kountm(l).gt.0) then
          hamean(m,l)=hamean(m,l)/kountm(l)
          asmean(m,l)=asmean(m,l)/kountm(l)
          zemean(m,l)=zemean(m,l)/kountm(l)
        endif
        if (kountl(l).gt.0) then
          hlmean(m,l)=hlmean(m,l)/kountl(l)
          almean(m,l)=almean(m,l)/kountl(l)
          zlmean(m,l)=zlmean(m,l)/kountl(l)
        endif
        if (kountw(l).gt.0) then
          hwmean(m,l)=hwmean(m,l)/kountw(l)
          awmean(m,l)=awmean(m,l)/kountw(l)
          zwmean(m,l)=zwmean(m,l)/kountw(l)
        endif
 4587 continue
 4876 continue

	DEALLOCATE(KNDIR)
	DEALLOCATE(KLDIR)
	DEALLOCATE(KWDIR)
	DEALLOCATE(HSSB,NDSB)
	
	write(6,*) 'to conh12t'


C	call conh12t(AGTK,imjm,1,AGT,imt,jmt)

C	write(6,*) 'zoeff values' 
	do I=1,IMJM,50
C	write(6,297) (z0eff(I,M),M=1,4)
	enddo
  297	format(4(e10.4,x))
c
	ALLOCATE(Z0EFF2(IM,JM,4))
      do 8903 m=1,4
	call conh12(z0eff(1,m),imjm,1,z0eff2(1,1,m),im,jm)
 8903 continue

	write(6,*) '2d zoeff values' 
	do J=JM,1,-2
C	write(6,299) (z0eff2(I,J,2),I=1,IM,3)
	enddo
  299	format(33(f4.2,x))


CCCCC write out the ZEFF file CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC

	open(unit=27,file='ZEFF',form='unformatted',access='sequential'
     +	,status='unknown')


	ALLOCATE(TMP(IM,JM))
	do m=1,4
C	write(6,*) 'BOGUS ZEFF!!!!!!!!!!!!!!!!!!!!'
C	write(6,*) 'BOGUS ZEFF!!!!!!!!!!!!!!!!!!!!'
C	write(6,*) 'BOGUS ZEFF!!!!!!!!!!!!!!!!!!!!'
	tmp=-999.
	do j=1,jm
	do i=1,im
	TMP(I,J)=z0eff2(I,J,M)
Cbog	TMP(I,J)=z0eff2(I,J,M)*5.
	enddo
	enddo
	write(27) TMP
	enddo

	DEALLOCATE(Z0EFF2)
	DEALLOCATE(Z0EFF)
	DEALLOCATE(ZHA)
	DEALLOCATE(ZAS)
	DEALLOCATE(TMP)
	


CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCcc
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC

c
c *** Reorder hgtk and smk array to old 2-d configuration.
c

	ALLOCATE (HGT(IM,JM))
	ALLOCATE (SM(IM,JM))
        write(300,*)hgtk
      call conh12(hgtk,imjm,1,hgt,im,jm)
      call conh12(smk,imjm,1,sm,im,jm)

	DEALLOCATE(SMK)
	DEALLOCATE(HGTK)


	write(6,*) 'sea mask at end of topo '
        do J=JM,1,-JM/30
        write(6,273)(sm(I,J),I=1,IM,IM/15)
        enddo
  273   format(80f2.0)


C	write(6,*) 'topo data before vertical interp (W,center,E) '
	ISTART=1

	do J=jm,1,-4
	write(6,275) (hgt(I,J),I=1,IM,IM/15)
  275	format(22(f7.0,x))
	enddo

C
C Check for bogus, elevated water points (water islands)
C
	do J=1,jm
      ihw(j)=-1+mod(j+1,2)
      ihe(j)=ihw(j)+1
	enddo


	do ITER=1,5
	write(6,*) ' START ITERATION ', ITER

	do J=3,jm-2
	do I=3,im-2
	
	if (hgt(i,j) .gt. 0  .and. sm(i,j) .eq. 1) then
C elevated water
	if ( ( hgt(I+IHE(J),J+1).eq.0 .and. sm(I+IHE(J),J+1) .eq. 1) .or.
     +	 ( hgt(I+IHW(J),J+1).eq.0 .and. sm(I+IHW(J),J+1) .eq. 1) .or.
     +	 ( hgt(I+IHW(J),J-1).eq.0 .and. sm(I+IHW(J),J-1) .eq. 1) .or.
     +	 ( hgt(I+IHE(J),J-1).eq.0 .and. sm(I+IHE(J),J-1) .eq. 1) .or.
     +   ( hgt(I-1,J).eq.0 .and. sm(I-1,J).eq.1 ) .or.
     +   ( hgt(I+1,J).eq.0 .and. sm(I+1,J).eq.1 ) .or.
     +   ( hgt(I,J+2).eq.0 .and. sm(I,J+2).eq.1 ) .or.
     +   ( hgt(I,J-2).eq.0 .and. sm(I,J-2).eq.1 )) then

	if (hgt(i,J) .lt. 100) then
	write(6,*) 'making elevated water point zero elev at : ', i,j
	hgt(i,j)=0. 
	else
	write(6,*) 'making elevated water point a land point at: ', i,j
	sm(i,j)=0.
	endif

	endif
	endif

	enddo
	enddo

	enddo
	

c *** Write eta grid topo.
c
      open(1,file=topo_out,status='unknown',form='unformatted')
      write(1) hgt,sm
      close(1)

	DEALLOCATE(HGT)
	DEALLOCATE(SM)
c     stop
c     open(1,file='planine')
c     do j=jmt,1,-1
c        write(1,'(1000F6.0)')(hgt(i,j),i=1,imt)
c     enddo
c     close(1)
c
Cstatic      return
c
c *** Error trapping.
c
C900   print *,'Error opening input topo data.**********************'
C      print *,'   Filename = ',fname
C      print*, '*************************************************'
C        print*, '***********!!!!!!!!!!!!!!!!!********************'
Cprint*, '***********!!!!!!!!!!!!!!!!!********************'
Cprint*, '***********!!!!!!!!!!!!!!!!!********************'
Cprint*, ' M I S S I N G   S O M E   D A T A !!!!!!!!!!!!'
Cprint*, '***********!!!!!!!!!!!!!!!!!********************'
Cprint*, '***********!!!!!!!!!!!!!!!!!********************'
Cprint*, '***********!!!!!!!!!!!!!!!!!********************'
Cprint*, '*************************************************'
C      stop
c
	return
      end


c&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
C&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
CC************************************************************

                             SUBROUTINE PQK_NEW
     &(ALM,APH,INSIDE,P,Q,K      )
C     ******************************************************************
C     *                                                                *
C     *  ROUTINE TO TRANSFORM ALAMBDA,APHI (LONGITUDE,LATITUDE) INTO   *
C     *  TRANSFORMED (ROTATED) LONGITUDE,LATITUDE, CHECK WHETHER THE   *
C     *  VALUES OBTAINED ARE WITHIN THE MODEL REGION, AND, IF THEY     *
C     *  ARE, CALCULATE VALUES OF P,Q (COORDINATES WITHIN A SQUARE     *
C     *  FORMED BY CONNECTING FOUR NEIGHBORING HEIGHT POINTS) AND K.   *
C     *                                                                *
C     ******************************************************************
C     *                                                                *
C     *  GRID CONSTANTS:                                               *
C     *  WBD,SBD - WESTERN AND SOUTHERN BOUNDARIES ON LL OR TLL GRID   *
C     *            IN DEGREES                                          *
C     *  TLM0D,TPH0D - ANGLES OF ROTATION OF THE LL COORDINATE SYSTEM  *
C     *            IN THE DIRECTION OF LAMBDA AND PHI RESPECTIVELY     *
C     *            IN ORDER TO OBTAIN THE TLL COORDINATE SYSTEM        *
C     *  DLMD,DPHD - MESH SIDES IN DEGREES                             *
C     *                                                                *
C     ******************************************************************
c     *  5/95  Wobus  use whole domain, calculate the actual eta box k *
c     *               and internal coordinates p and q here            *
c     ******************************************************************
c     include "parmeta"
C      include "parmgrd"
       include 'ecommons.h'
C      include "parmsub"
C      include "parmloc"
      PARAMETER (DTR=0.01745329,D50=0.50,H1=1.)
      common /pqkcnt/nwest,neast,nsouth,nnorth
      common /pqkcnt/kwest,keast,ksouth,knorth
      common /pqkcnt/kpneg,kqneg,kklow,kkhigh
C----------------------------------------------------------------------
                          L O G I C A L
     &  INSIDE
C
C---------------------------CONSTANTS-----------------------------------

      RIM1=IM1
      TLM0=TLM0D*DTR
      TPH0=TPH0D*DTR
      DLM=DLMD*DTR
      DPH=DPHD*DTR

      RDLM=H1/DLM
      RDPH=H1/DPH
crlwb
c test for whole domain
c     ALMWB=WBD*DTR +DLM
c     APHSB=SBD*DTR +DPH
c     ALMEB=ALMWB   +2*(IM-2)*DLM
c     APHNB=APHSB   +  (JM-3)*DPH
c     WB=ALMWB-DLM
c     SB=APHSB-DPH
      wb=wbd*dtr
      sb=sbd*dtr
      ALMWB=WB     - DLM
      APHSB=SB     - DPH
      ALMEB=ALMWB  +(2*IM  )*DLM
      APHNB=APHSB  +(  JM+1)*DPH
crlwe
          STPH0= SIN(TPH0)
          CTPH0= COS(TPH0)
C
C--------------ALM,APH IS LON,LAT IN RADIAN MEASURE;--------------------
C------------TRANSFORM INTO ROTATED LONGITUDE,LATITUDE------------------
C
          RLM=ALM-TLM0
          SRLM= SIN(RLM)
          CRLM= COS(RLM)
          SAPH= SIN(APH)
          CAPH= COS(APH)
          CC=CRLM*CAPH
C
          ANUM=SRLM*CAPH
          DENOM=CTPH0*CC+STPH0*SAPH
C
          ALM= ATAN2(ANUM,DENOM)
          APH= ASIN(CTPH0*SAPH-STPH0*CC)

	if (neast .lt. 5) then
C	write(6,*) 'bounds (w,s,e,n)'
C	write(6,*) almwb,aphsb,almeb,aphnb
C	write(6,*) 'we are at ',alm,aph
	endif
C
C-----IS ALM,APH INSIDE THE MODEL DOMAIN?-------------------------------
C
      kmiss=0
      if (alm.lt.almwb) then
        nwest=nwest+1
        kmiss=kmiss-1
      endif
      if (alm.gt.almeb) then
        neast=neast+1
        kmiss=kmiss-2
      endif
      if (aph.lt.aphsb) then
        nsouth=nsouth+1
        kmiss=kmiss-4
      endif
      if (aph.gt.aphnb) then
        nnorth=nnorth+1
        kmiss=kmiss-8
      endif
C	write(6,*) 'w,e,s,n ', nwest,neast,nsouth,nnorth
      if (kmiss.ne.0) go to 102
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCc
C
C---------X1,Y1 IS A COORDINATE SYSTEM WITH DLM,DPH AS LENGTH UNITS-----
c            add y offset to index the centers of the boxes
c            instead of the southern corners
      X1=(ALM-WB)*RDLM
      Y1=(APH-SB)*RDPH+1.0
C---------X2,Y2 ROTATED FOR +45 DEG. & TRANSLATED FOR IM1---------------
      X2=D50*( X1+Y1)
      Y2=D50*(-X1+Y1)+RIM1
C---------I2,J2 ARE COORDINATES OF center POINTS OF GRID BOXES--------
      I2=  INT(X2)
      J2=  INT(Y2)
C---------REMAINING PARAMETERS NEEDED TO KNOW THE POSITION--------------
C         OF THE TRANSFORMED POINT WITHIN THE MODEL REGION
      P=X2-I2
      Q=Y2-J2
C-----------------INDEX K CORRESPONDS TO I2,J2--------------------------
      JR=J2-IM1
      I3=I2-JR
      J3=I2+JR
      K=J3*IM-J3/2+(I3+2)/2
C---------------see if the point is in the domain-----------------------
c  note, i3 runs from 0 thru imt-1
c        j3 runs from 0 thru jm-1
c        P and q must be nonnegative for correct 0,0 point
      kmiss=0
      if (i3.lt.0) then
        kwest=kwest+1
        kmiss=kmiss+1
      endif
      if (i3.ge.imt) then
        keast=keast+1
        kmiss=kmiss+2
      endif
      if (j3.lt.0) then
        ksouth=ksouth+1
        kmiss=kmiss+4
      endif
      if (j3.ge.jm) then
        knorth=knorth+1
        kmiss=kmiss+8
      endif
      if (p.lt.0) then
        kpneg=kpneg+1
        kmiss=kmiss+16
      endif
      if (q.lt.0.0) then
        kqneg=kqneg+1
        kmiss=kmiss+32
      endif
      if (k.le.0) then
        kklow=kklow+1
        kmiss=kmiss+64
      endif
      if (k.gt.imjm) then
        kkhigh=kkhigh+1
        kmiss=kmiss+128
      endif
      if (kmiss.gt.0) go to 102
c
             INSIDE=.TRUE.
             RETURN
C-----------------------------------------------------------------------
c
  102 continue
      if (kmiss.eq.64) then
        write(6,'('' unexpected k too low '',3i8,2f10.6)')
     1    k,i3,j3,p,q
      endif
      if (kmiss.eq.128) then
        write(6,'('' unexpected k too high'',3i8,2f10.6)')
     1    k,i3,j3,p,q
      endif
             INSIDE=.FALSE.
             RETURN
                             END
                             
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
CCCCCCCCCCCCCCCCCCCCC  GET_SEA  CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
	subroutine get_sea(isea,idim,jdim)

      implicit none
c
      include 'ecommons.h'
c
      integer nbx,nby,idim,jdim
c
      integer 
     .         k,jx,ix,ji
     .         ,i,ii,j,khl22,khh22,GDS(200)
     .         ,III,JJJ,icount,ilimit,jlimit
c
      real isea(imjm),
     +	    r2d,tph0,wb,sb,dlm,dph,tdlm,tdph,glatd,glond
     .      ,tph,tlm,stph,ctph,sinphi,coslam,fact,dtr,x,y
     .      ,dlat,frac,sum

        PARAMETER (DTR=0.01745329)

	REAL, ALLOCATABLE:: DUM2D(:,:)
	REAL, ALLOCATABLE:: SEABYTE(:,:),GLATR(:,:),GLONR(:,:)

	nbx=idim
	nby=jdim

	        write(6,*) 'starting sea program, seares= ', seares
	write(6,*) 'sigma= ', sigma

	if (seares .eq. 4) then    

	write(6,*) 'opening 4 minute'
	open(unit=2,file='global_4m.ieee',form='unformatted',
     .	access='sequential',err=920,status='old')

	elseif (seares .eq. 8) then

	write(6,*) 'opening 8 minute'
	open(unit=2,file='global_8m.ieee',form='unformatted',
     .  access='sequential',err=920,status='old')

	elseif (seares .eq. 2) then

        open(2,file='US_2m_slm.ieee',form='unformatted',
     . access='sequential',status='old',ERR=920)
     
     	else
     	
	write(6,*) 'opening something with an unsupported IRES value...'
	stop

	endif

	ALLOCATE (SEABYTE(IDIM,JDIM))

        write(6,*) 'unit 2 open ', nbx,nby
        do J=1,nby
        read(2) (seabyte(I,J),I=1,nbx)
        enddo
	goto 921

  920   write(6,*) '!!!!!!!!!trouble opening the seamask data!!!!!!'
  921      write(6,*) 'data read successfully '
        close(2)

	GDS=0
	
	if (seares .eq. 2) then
	GDS(1)=0
	GDS(2)=4501
	GDS(3)=2101
	GDS(4)=9983
	GDS(5)=179983
	GDS(6)=128
	GDS(7)=80017
	GDS(8)=-29983
	GDS(9)=033
	GDS(10)=033
	elseif (seares .eq. 4) then
	GDS(1)=0
	GDS(2)=5400
	GDS(3)=2700
	GDS(4)=-89933
	GDS(5)=-179933
	GDS(6)=128
	GDS(7)=89933
	GDS(8)=179933
	GDS(9)=067
	GDS(10)=067
	elseif (seares .eq. 8) then
	GDS(1)=0
	GDS(2)=2700
	GDS(3)=1350
	GDS(4)=-89967
	GDS(5)=-179967
	GDS(6)=128
	GDS(7)=89967
	GDS(8)=179967
	GDS(9)=133
	GDS(10)=133
	endif

	dlat=GDS(9)/1000.
        ilimit=0.5*(dlmd/dlat)
        jlimit=0.5*(dphd/dlat)

!	ilimit=max0(1,ilimit)
!	jlimit=max0(1,jlimit)

        write(6,*) 'if possible, will go +/- ', ilimit, 'in I and +/-',
     +          jlimit, 'in J'


Cmp     values will be ones or twos (1=land, 2=water)
C
Cmp     for output (0=land, 1=water)

C	compute lat lon on e-grid
	r2d=57.2957795
      tph0=tph0d*dtr
      wb=wbd*dtr
      sb=sbd*dtr
      dlm=dlmd*dtr
      dph=dphd*dtr
      tdlm=dlm+dlm
      tdph=dph+dph
      tph=sb-dph
      ctph0=cos(tph0)
      stph0=sin(tph0)

	ALLOCATE(GLATR(IM,JM),GLONR(IM,JM))

      do j=1,jm
         tlm=wb-tdlm+mod(j+1,2)*dlm
         tph=tph+dph
         stph=sin(tph)
         ctph=cos(tph)
c
        do i=1,im
            tlm=tlm+tdlm
            sinphi=ctph0*stph+stph0*ctph*cos(tlm)
            glatr(i,j)=asin(sinphi)
            coslam=ctph*cos(tlm)/(cos(glatr(i,j))*ctph0)
     .            -tan(glatr(i,j))*tan(tph0)
            coslam=min(coslam,1.)
            fact=1.
            if (tlm .gt. 0.0) fact=-1.
            glonr(i,j)=-tlm0d*dtr+fact*acos(coslam)
C
         enddo
      enddo
C
C	Initialize as all sea...boundaries arent recomputed and
C	will remain sea points
C
	ISEA=1
	

	if (.not. SIGMA) then
	KHL22=2*IM+1
	KHH22=IMJM-2*IM
	else
	KHL22=1
	KHH22=IMJM
	endif

	do K=KHL22,KHH22

C added 001003
C COMPUTE OUTPUT GRID lats AND lons

C	convert K value to get I,J
	IMT=2*IM-1
        JX=(K-1)/IMT+1
        IX=K-(JX-1)*IMT
        IF(IX.LE.IM)THEN
          I=IX
          J=2*JX-1
        ELSE
          I=IX-IM
          J=2*JX
        ENDIF

C DETERMINE LAT/LON OF TARGET (output) GRID POINT
C
	GLATD = GLATR(i,j)*r2d
	GLOND = GLONR(I,J)*r2d
	IF (GLOND .LT. 0) GLOND=GLOND+360
        GLOND = 360. - GLOND
C
C DETERMINE NEAREST NEIGHBOR FROM INPUT GRID
C
C	write(6,*) 'i,j,glat,glon: ', i,j,glatd,glond
          call ced_ij(GLATD,glond,x,y,gds)
C	write(6,*) 'found x,y: ', x,y

        II=INT(X+0.5)
        JI=INT(Y+0.5)

C	If input data is 1 --> land --> isea=0
C	If input data is 0 --> water --> isea=1
C


        if (II .ge. ilimit .and. II .le. nbx-ilimit .and.
     +      JI .ge. jlimit .and. JI .le. nby-jlimit) then

        ICOUNT=0
        sum=0.

        do JJJ=JI-jlimit,JI+jlimit
           do III=II-ilimit,II+ilimit
              sum=sum+seabyte(III,JJJ)
              ICOUNT=ICOUNT+1
           enddo
        enddo
C

        frac=sum/float(icount)

        if (frac .gt. FRACLK) then
        isea(k)=0
        else
        isea(k)=1
        endif



	ELSE
	
	write(6,*) 'too close to boundary...just use n.n.'

	if (seabyte(II,JI) .eq. 1) then
	isea(k)=0
	elseif (seabyte(II,JI) .eq. 0) then
	isea(k)=1
	else
	write(6,*) 'bad seabyte value!!!!! ', II,JI, seabyte(II,JI)
	endif
	

	ENDIF

      enddo

	DEALLOCATE(SEABYTE)
	DEALLOCATE(GLATR,GLONR)
c
        write(6,*) 'GOT TO THIS POINT'

	ALLOCATE (dum2d(im,jm))
        call conh12(isea,imjm,1,dum2d,im,jm)
        do J=JM-1,1,-JM/40
C        write(6,273)(dum2d(I,J),I=1,IM,IM/53)
        enddo
  273   format(71f2.0)

	DEALLOCATE(DUM2D)
c
      return
      end

CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC

       subroutine CORNERS(im,jm,IMJM,tph0d,tlm0d,dlmd,dphd,minlat,wlon,
     +                                                maxlat,elon)
C
C
C     *  ROUTINE TO FIND EARTH LATITUDE/LONGITUDE FOR THE CORNER       *
C     *               POINTS OF AN ETA MODEL GRID                      *
C

C-----------------------------------------------------------------------
C                             D I M E N S I O N
C     & KHL0  (JM),KHH0  (JM), GLAT(IMJM),GLON(IMJM)

	REAL,ALLOCATABLE::GLAT(:),GLON(:)
	INTEGER,ALLOCATABLE::KHL0(:),KHH0(:)

                             D A T A
     & PI/3.141592654/

        REAL DLMD,DPHD,WBD,SBD,TPH0D,TLM0D,minlat,wlon,maxlat,elon

C*******************************
        WBD=-(float(IM)-1.)*DLMD
        SBD=(-(float(JM)-1.)/2.)*DPHD

      DTR=PI/180.
      TPH0=TPH0D*DTR
      WB=WBD*DTR
      SB=SBD*DTR
      DLM=DLMD*DTR
      DPH=DPHD*DTR
      TDLM=DLM+DLM
      TDPH=DPH+DPH
C
      STPH0=SIN(TPH0)
      CTPH0=COS(TPH0)
C
	ALLOCATE(KHL0(JM),KHH0(JM))
	ALLOCATE(GLAT(IMJM),GLON(IMJM))

         DO 100 J=1,JM
      KHL0(J)=IM*(J-1)-(J-1)/2+1
      KHH0(J)=IM*J-J/2
C     WRITE(6,9999) J, KHL0(J), KHH0(J)
C9999 FORMAT(2X,3(I10,1X))
  100 CONTINUE
C--------------GEOGRAPHIC LAT AND LONG OF TLL GRID POINTS---------------
              TPH=SB-DPH
        maxlat=-999.
	minlat=99.
        do199: DO J=1,JM
          KHL=KHL0(J)
          KHH=KHH0(J)
C
          TLM=WB-TDLM+MOD(J+1,2)*DLM
          TPH=TPH+DPH
          STPH=SIN(TPH)
          CTPH=COS(TPH)
          do200: DO K=KHL,KHH
            TLM=TLM+TDLM
            SPH=CTPH0*STPH+STPH0*CTPH*COS(TLM)
            GLAT(K)=ASIN(SPH)
            CLM=CTPH*COS(TLM)/(COS(GLAT(K))*CTPH0)
     +          -TAN(GLAT(K))*TAN(TPH0)
            IF(CLM.GT.1.)      CLM=1.
            FACT=1.
            IF(TLM.GT.0.)      FACT=-1.
            GLON(K)=(-TLM0D*DTR+FACT*ACOS(CLM))/DTR

Cmp     at this point GLON is in DEGREES WEST
            if (GLON(K) .lt. 0) GLON(K)=GLON(K)+360.
            if (GLON(K) .gt. 360.) GLON(K)=GLON(K)-360.
            if (GLON(K) .lt. 180) GLON(K)=-GLON(K)         ! make WH negative
            if (GLON(K) .gt. 180) GLON(K)=360.-GLON(K)     ! make EH

            GLAT(K)=GLAT(K)/DTR

            if (glat(k) .gt. maxlat) maxlat=glat(k)
	    if (glat(k) .lt. minlat) minlat=glat(k)

          ENDDO do200
        ENDDO do199

	DEALLOCATE(KHL0,KHH0)
	
	
	if (TPH0D .ge. 0) then
        wlon=glon(imjm-im+1)
        elon=glon(imjm)
	else
	wlon=glon(1)
	elon=glon(im)
	endif

C	write(6,*) 'raw lon values (w,e) ', wlon, elon
        if (tlm0d .lt. 0 .and. wlon .gt. 0) wlon=wlon-360.
        if (tlm0d .gt. 0 .and. elon .lt. 0) elon=elon+360.

	DEALLOCATE(GLAT,GLON)

        RETURN
      END

CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC

       SUBROUTINE SWAPVAL(A)
C
C      REVERSE ORDER OF BYTES IN INTEGER*2 WORD, or REAL*2
C
       INTEGER*2   A
C
       CHARACTER*1 JTEMP(2)
       CHARACTER*1 KTEMP
C
       EQUIVALENCE (JTEMP(1),ITEMP)
C
         ITEMP    = A
         KTEMP    = JTEMP(2)
         JTEMP(2) = JTEMP(1)
         JTEMP(1) = KTEMP
         A     = ITEMP
       RETURN
       END

C add subroutines

      subroutine conh12t(h1,imjm,lm,h2,imt,jmt)
c
c *** Routine for reordering thibue-height-point-1-dimensional
c        matrices for 2-dimensional indexing (imt,jmt).
c
      implicit none
c
      integer*4 imt,jmt,imjm,lm,i,j,k,l
c
      real*4 h1(imjm,lm),h2(imt,jmt,lm)
c_______________________________________________________________________________
c
      do l=1,lm
         k=0
         do j=1,jmt
            do i=1,imt,2
               k=k+1
               h2(i,j,l)=h1(k,l)
            enddo
c
            if (j .lt. jmt) then
               do i=2,imt,2
                  k=k+1
                  h2(i,j,l)=h1(k,l)
               enddo
            endif
         enddo
      enddo
c
      return
      end
c
c===============================================================================

c===============================================================================
c
      subroutine conh12(h1,imjm,lm,h2,im,jm)
c
c *** Routine for reordering thibue-height-point-1-dimensional
c        matrices (im,jm) for 2-dimensional indexing.
c
      implicit none
c
      integer*4 im,jm,imjm,lm,i,j,k,l,imm1
c
      real*4 h1(imjm,lm),h2(im,jm,lm)
c_______________________________________________________________________________
c
      imm1=im-1
      do l=1,lm
         k=0
         do j=1,jm
         do i=1,imm1+mod(j,2)
            k=k+1
            h2(i,j,l)=h1(k,l)
         enddo
         enddo
         do j=2,jm-1,2
            h2(im,j,l)=h2(imm1,j,l)
         enddo
      enddo
c
      return
      end
c
c===============================================================================

        subroutine ced_ij(RLAT,RLON,XPTS,YPTS,KGDS)

        integer kgds(200)


        IM=KGDS(2)
        JM=KGDS(3)
        RLAT1=KGDS(4)*1.E-3
        RLON1=KGDS(5)*1.E-3
        RLAT2=KGDS(7)*1.E-3
        RLON2=KGDS(8)*1.E-3
        ISCAN=MOD(KGDS(11)/128,2)
        JSCAN=MOD(KGDS(11)/64,2)
        NSCAN=MOD(KGDS(11)/32,2)
        HI=(-1.)**ISCAN
        HJ=(-1.)**(1-JSCAN)
        DLON=HI*(MOD(HI*(RLON2-RLON1)-1+3600,360.)+1)/(IM-1)
        DLAT=(RLAT2-RLAT1)/(JM-1)
        XMIN=0
        XMAX=IM+1
        IF(IM.EQ.NINT(360/ABS(DLON))) XMAX=IM+2
        YMIN=0
        YMAX=JM+1
        NRET=0
	LROT=0
	FILL=-999

            IF(ABS(RLON).LE.360.AND.ABS(RLAT).LE.90) THEN
              XPTS=1+HI*MOD(HI*(RLON-RLON1)+3600,360.)/DLON
              YPTS=1+(RLAT-RLAT1)/DLAT

Cmp
		if (XMAX .eq. 5401 .or. XMAX .eq. 2701) then

	if (XPTS .gt. XMAX) then
	XPTS=XPTS-XMAX
	write(6,*) 'xpts now: ', xpts
	endif

	if (XPTS .lt. XMIN) then
	XPTS=XPTS+XMAX
	write(6,*) 'xpts now: ', xpts
	endif

		endif
Cmp
              IF(XPTS.GE.XMIN.AND.XPTS.LE.XMAX.AND.
     &           YPTS.GE.YMIN.AND.YPTS.LE.YMAX) THEN
                NRET=NRET+1
                IF(LROT.EQ.1) THEN
                  CROT=1
                  SROT=0
                ENDIF
              ELSE
                XPTS=FILL
                YPTS=FILL
              ENDIF
            ELSE
              XPTS=FILL
              YPTS=FILL
            ENDIF

        return
        end

CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
        subroutine get_sea30(isea)
        include 'ecommons.h' 
        parameter(ID1=1,ID2=43204,IRECL=ID2)
        parameter(dlat=1./120.)  
        parameter(r2d=57.29577951,dtr=0.017453293)
        integer ounit,iunit,iirecl
        parameter(OUNIT=50)
        character*12 fnameout
        INTEGER*1 LANDIN(ID1,ID2)
        INTEGER,ALLOCATABLE:: LAND2D(:,:)
        INTEGER GDS(200)
        character*2 uname
        CHARACTER*1 LANDIN_CHR(ID1,ID2)

        REAL, ALLOCATABLE:: GLATR(:,:),GLONR(:,:)
        real isea(imjm)
        real dum2d(im,jm)

        cshift=dlat/2.

C
C
C	details about target grid

C       compute lat lon on e-grid

        write(6,*) 'im,jm,wbd,sbd,tph0d,dtr ', im,jm,wbd,sbd,tph0d,dtr
      tph0=tph0d*dtr
      wb=wbd*dtr
      sb=sbd*dtr
      dlm=dlmd*dtr
      dph=dphd*dtr
      tdlm=dlm+dlm
      tdph=dph+dph
      tph=sb-dph
      ctph0=cos(tph0)
      stph0=sin(tph0)

        ALLOCATE(GLATR(IM,JM),GLONR(IM,JM))

      do j=1,jm
         tlm=wb-tdlm+mod(j+1,2)*dlm
         tph=tph+dph
         stph=sin(tph)
         ctph=cos(tph)
c
        do i=1,im
            tlm=tlm+tdlm
            sinphi=ctph0*stph+stph0*ctph*cos(tlm)
            glatr(i,j)=asin(sinphi)
            coslam=ctph*cos(tlm)/(cos(glatr(i,j))*ctph0)
     .            -tan(glatr(i,j))*tan(tph0)
            coslam=min(coslam,1.)
            fact=1.
            if (tlm .gt. 0.0) fact=-1.
            glonr(i,j)=-tlm0d*dtr+fact*acos(coslam)
C
         enddo
      enddo

      call corners(im,jm,imjm,tph0d,tlm0d,dlmd,dphd,apmn,almn,apmx,almx)

      rnlat=apmx+0.1
      slat=apmn-0.1
      west=almn-0.1
      east=almx+0.1

      write(6,*) glatr(im/2,jm),glatr(1,1),glonr(1,jm),glonr(im,jm),r2d

      write(6,*) 'west= ', west
      write(6,*) 'east= ', east
      write(6,*) 'north= ', rnlat
      write(6,*) 'south= ', slat

        IST=((west+180.-cshift)/dlat)+1
        IEND=((east+180.-cshift)/dlat)+1

        write(6,*) 'IST, IEND: ', IST,IEND

        wtrue=(ist-1)*dlat+cshift-180.
        etrue=(iend-1)*dlat+cshift-180.

        JST=-(RNLAT-90)/dlat+1
        JEND=-(SLAT-90)/dlat+1

        write(6,*) 'JST, JEND: ', JST, JEND

        rntrue=90.-(jst-1)*dlat-cshift
        strue=90.-(jend-1)*dlat-cshift

        ILIM=IEND-IST+1
        JLIM=JEND-JST+1

        write(6,*) 'ILIM, JLIM: ', ILIM, JLIM

C	STOP

        allocate(land2d(ILIM,JLIM))

        LAND2D=-99.

        JSUNIT=INT((JST-1)/600)+1
        JENDUNIT=INT((JEND-1)/600)+1

        write(6,*) 'true bounds: '
        write(6,*) 'N: ', rntrue
        write(6,*) 'W: ', wtrue
        write(6,*) 'S: ', strue
        write(6,*) 'E: ', etrue


CC	come up with an estimate of how many input 30 s points should
CC	be included.  Consider roughly enough to average over the size of
CC	the eta gridbox.

        ilimit=0.5*(dlmd/dlat)
        jlimit=0.5*(dphd/dlat)

        ilimit=max0(ilimit,1)
        jlimit=max0(jlimit,1)

C	ilimit=1
C	jlimit=1

        write(6,*) 'if possible, will go +/- ', ilimit, 'in I and +/-',
     +             jlimit, 'in J'

        do J=JSUNIT,JENDUNIT
        write(uname,'(i2.2)') INT(J)
        fnameout='smask.30s.'//uname

#ifdef DEC
        iirecl=IRECL/4
#else
        iirecl=IRECL
#endif
        IIUNIT=J+60
        open(unit=IIUNIT,file=fnameout,
     +                  access='direct',recl=IIRECL)
        write(6,*) 'opened unit,file ', IIUNIT,fnameout
        enddo

        GDS=0

        GDS(1)=0
        GDS(2)=ILIM
        GDS(3)=JLIM
        GDS(4)=INT(RNTRUE*1000)
        GDS(5)=INT(WTRUE*1000)
        GDS(6)=128
        GDS(7)=INT(STRUE*1000)
        GDS(8)=INT(ETRUE*1000)
        GDS(9)=INT(1./120.*1000)
        GDS(10)=INT(1./120.*1000)

        do J=1,10
        write(6,*) 'J,GDS(J): ', J,GDS(J)
        enddo

        do 80 N=JST,JEND

        IUNIT=INT((N-1)/600)+61
        IREC=N-(IUNIT-61)*600

        READ(IUNIT,REC=IREC,ERR=100) LANDIN_CHR

          DO IID1 = 1,ID1
            DO IID2 = 1,ID2
              LANDIN(IID1,IID2) = ICHAR(LANDIN_CHR(IID1,IID2))
            END DO
          END DO

         if (IST .ge. 1 .and. IEND .le. ID2 ) then

        do I=IST,IEND
        land2d(I-IST+1,N-JST+1)=LANDIN(1,I)
        enddo

        else

C	write(6,*) 'special case!!!!'

        IF (IST .lt. 1) then

C	put the eastern part of LANDIN into LAND2D

       if (N .eq. JST) then
       write(6,*) 'LAND2D defined from : ', ID2+IST-(ID2+IST)+1,
     +             ID2-(ID2+IST)+1
       write(6,*) '2nd part defines: ',ILIM-IEND+1, ILIM
       endif

        DO I=ID2+IST,ID2
        LAND2D(I-(ID2+IST)+1,N-JST+1)=LANDIN(1,I)
        ENDDO

        DO I=1,IEND
        LAND2D(ILIM-(IEND)+I,N-JST+1)=LANDIN(1,I)
        ENDDO

        ENDIF


C	
        if (IEND .gt. ID2) then
C	Eastern part of target domain from western part of input data
           if (N .eq. JST) then
              write(6,*) 'LAND2D defined from : ', 1, ID2-IST+1
              write(6,*) '2nd part defines: ',2+ID2-IST, IEND-ID2+
     +                   (ID2-IST+1)
           endif

           DO I=IST,ID2
              LAND2D(I-IST+1,N-JST+1)=LANDIN(1,I)
           ENDDO

           DO I=1,IEND-ID2
              LAND2D(I+(ID2-IST+1),N-JST+1)=LANDIN(1,I)
           ENDDO

        ENDIF


C	STOP 

        endif

   80   continue

        ISEA=1

        KHL22=2*IM+1
        KHH22=IMJM-2*IM

	write(6,*) 'loop K from ', KHL22, KHH22
        do K=KHL22,KHH22
C       convert K value to get I,J
        IMT=2*IM-1
        JX=(K-1)/IMT+1
        IX=K-(JX-1)*IMT
        IF(IX.LE.IM)THEN
          I=IX
          J=2*JX-1
        ELSE
          I=IX-IM
          J=2*JX
        ENDIF

C DETERMINE LAT/LON OF TARGET (output) GRID POINT
C
        GLATD = GLATR(i,j)*r2d
        GLOND = GLONR(I,J)*r2d
        IF (GLOND .LT. 0) GLOND=GLOND+360
        GLOND = 360. - GLOND

        call ced_ij(glatd,glond,x,y,gds)

        II=INT(X+0.5)
        JI=INT(Y+0.5)

	if (II .ge. ilimit .and. II .le. ILIM-ilimit .and. 
     +      JI .ge. jlimit .and. JI .le. JLIM-jlimit) then

	ICOUNT=0
	sum=0.

	do JJJ=JI-jlimit,JI+jlimit
	   do III=II-ilimit,II+ilimit
	      sum=sum+land2d(III,JJJ)
	      ICOUNT=ICOUNT+1
	   enddo
	enddo
C

	frac=sum/float(icount)

	if (K .eq. KHL22) then
	write(6,*) 'based this point on ', icount, '30 s data points'
	write(6,*) 'sea mask fraction (lower=fewer lakes) = ', fraclk
	endif

	if (frac .gt. 0 .and. frac .lt. 1) then
C!	write(6,*) 'K, fraction = ', K,frac
	endif

C       If input data is 1 --> land --> isea=0
C       If input data is 0 --> water --> isea=1

	if (frac .gt. FRACLK) then
	isea(k)=0
	else
	isea(k)=1
	endif
	

	ELSE

	write(6,*) 'too close to the boundary...use n.n. ', K

        if (land2d(II,JI) .eq. 1) then
        isea(k)=0
        elseif (land2d(II,JI) .eq. 0) then
        isea(k)=1
        else
        write(6,*) 'bad land2d values!!!! ', II,JI,land2d(II,JI)
        endif

	ENDIF


        enddo

	icount=0

	do K=1,imjm
	if  (isea(K) .eq. 1) then
	ICOUNT=ICOUNT+1
	endif
	enddo

	write(6,*) 'have ', ICOUNT , ' sea points out of ', 
     +			imjm, 'points total'

        call conh12(isea,imjm,1,dum2d,im,jm)
	write(6,*) 'sea within sea30 subroutine'
        do J=JM-1,1,-JM/40
        write(6,273)(dum2d(I,J),I=1,IM,IM/30)
        enddo
  273   format(71f2.0)

	RETURN

	STOP
  100	write(6,*) 'bad read!!!!'

	END
