NCEPLIBS-ip  5.1.0
ipxwafs.F90
Go to the documentation of this file.
1 
4 
68 
81  SUBROUTINE ipxwafs(IDIR, NUMPTS_THIN, NUMPTS_FULL, KM, NUM_OPT, &
82  OPT_PTS, IGDTLEN, IGDTMPL_THIN, DATA_THIN, &
83  IGDTMPL_FULL, DATA_FULL, IRET)
84  IMPLICIT NONE
85 !
86  INTEGER, INTENT(IN ) :: NUM_OPT
87  INTEGER, INTENT(INOUT) :: OPT_PTS(NUM_OPT)
88  INTEGER, INTENT(IN ) :: IDIR, KM, NUMPTS_THIN, NUMPTS_FULL
89  INTEGER, INTENT(IN ) :: IGDTLEN
90  INTEGER, INTENT(INOUT) :: IGDTMPL_THIN(IGDTLEN)
91  INTEGER, INTENT(INOUT) :: IGDTMPL_FULL(IGDTLEN)
92  INTEGER, INTENT( OUT) :: IRET
93 !
94  REAL, INTENT(INOUT) :: DATA_THIN(NUMPTS_THIN,KM)
95  REAL, INTENT(INOUT) :: DATA_FULL(NUMPTS_FULL,KM)
96 !
97  INTEGER, PARAMETER :: MISSING=-1
98 !
99  INTEGER :: SCAN_MODE, I, J, K, IDLAT, IDLON
100  INTEGER :: IA, IB, IM, IM1, IM2, NPWAFS(73)
101  INTEGER :: IS1, IS2, ISCAN, ISCALE
102 !
103  LOGICAL :: TEST1, TEST2
104 !
105  REAL :: DLON, HI
106  REAL :: RAT1, RAT2, RLON1, RLON2
107  REAL :: WA, WB, X1, X2
108 !
109  DATA npwafs/ &
110  73, 73, 73, 73, 73, 73, 73, 73, 72, 72, 72, 71, 71, 71, 70,&
111  70, 69, 69, 68, 67, 67, 66, 65, 65, 64, 63, 62, 61, 60, 60,&
112  59, 58, 57, 56, 55, 54, 52, 51, 50, 49, 48, 47, 45, 44, 43,&
113  42, 40, 39, 38, 36, 35, 33, 32, 30, 29, 28, 26, 25, 23, 22,&
114  20, 19, 17, 16, 14, 12, 11, 9, 8, 6, 5, 3, 2/
115 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
116 ! TRANSFORM GDS
117  iret=0
118 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
119 ! REG LAT/LON GRIDS HAVE 19 GDT ELEMENTS.
120  IF (igdtlen /= 19 .OR. numpts_thin/=3447 .OR. numpts_full/=5329) THEN
121  iret=1
122  RETURN
123  ENDIF
124 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
125 ! EXPAND THINNED GDS TO FULL GDS
126  IF(idir.GT.0) THEN
127  scan_mode=igdtmpl_thin(19)
128  iscale=igdtmpl_thin(10)*igdtmpl_thin(11)
129  IF(iscale==0) iscale=10**6
130  idlat=nint(1.25*float(iscale))
131  test1=all(opt_pts==npwafs)
132  test2=all(opt_pts==npwafs(73:1:-1))
133 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
134 ! SOME CHECKS TO ENSURE THIS IS A WAFS GRID
135  IF(scan_mode==64 .AND. igdtmpl_thin(9)==73 .AND. &
136  idlat==igdtmpl_thin(18) .AND. (test1 .OR. test2) ) THEN
137  igdtmpl_full=igdtmpl_thin
138  im=73
139  igdtmpl_full(8)=im
140  rlon1=float(igdtmpl_full(13))/float(iscale)
141  rlon2=float(igdtmpl_full(16))/float(iscale)
142  iscan=mod(igdtmpl_full(19)/128,2)
143  hi=(-1.)**iscan
144  dlon=hi*(mod(hi*(rlon2-rlon1)-1+3600,360.)+1)/(im-1)
145  igdtmpl_full(17)=nint(dlon*float(iscale))
146  ELSE
147  iret=1
148  ENDIF
149 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
150 ! CONTRACT FULL GDS TO THINNED GDS
151  ELSEIF(idir.LT.0) THEN
152  scan_mode=igdtmpl_full(19)
153  iscale=igdtmpl_full(10)*igdtmpl_full(11)
154  IF(iscale==0) iscale=10**6
155  idlat=nint(1.25*float(iscale))
156  idlon=idlat
157 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
158 ! SOME CHECKS TO ENSURE THIS IS A WAFS GRID
159  IF(scan_mode==64 .AND. igdtmpl_full(8)==73 .AND. igdtmpl_full(9)==73 .AND. &
160  num_opt==73 .AND. idlat==igdtmpl_full(18) .AND. idlon==igdtmpl_full(17))THEN
161  igdtmpl_thin=igdtmpl_full
162  igdtmpl_thin(8)=missing
163  igdtmpl_thin(17)=missing
164  IF(igdtmpl_thin(12)==0) THEN ! IS LATITUDE OF ROW 1 THE EQUATOR?
165  opt_pts=npwafs
166  ELSE
167  opt_pts=npwafs(73:1:-1)
168  ENDIF
169  ELSE
170  iret=1
171  ENDIF
172  ENDIF
173 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
174 ! TRANSFORM FIELDS
175  IF(iret.EQ.0) THEN
176 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
177 ! EXPAND THINNED FIELDS TO FULL FIELDS
178  IF(idir.EQ.1) THEN
179  DO k=1,km
180  is1=0
181  is2=0
182  DO j=1,igdtmpl_full(9)
183  im1=opt_pts(j)
184  im2=igdtmpl_full(8)
185  rat1=float(im1-1)/float(im2-1)
186  DO i=1,im2
187  x1=(i-1)*rat1+1
188  ia=int(x1)
189  ia=min(max(ia,1),im1-1)
190  ib=ia+1
191  wa=ib-x1
192  wb=x1-ia
193  data_full(is2+i,k)=wa*data_thin(is1+ia,k)+wb*data_thin(is1+ib,k)
194  ENDDO
195  is1=is1+im1
196  is2=is2+im2
197  ENDDO
198  ENDDO
199 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
200 ! CONTRACT FULL FIELDS TO THINNED FIELDS
201  ELSEIF(idir.EQ.-1) THEN
202  DO k=1,km
203  is1=0
204  is2=0
205  DO j=1,igdtmpl_full(9)
206  im1=opt_pts(j)
207  im2=igdtmpl_full(8)
208  rat2=float(im2-1)/float(im1-1)
209  DO i=1,im1
210  x2=(i-1)*rat2+1
211  ia=int(x2)
212  ia=min(max(ia,1),im2-1)
213  ib=ia+1
214  wa=ib-x2
215  wb=x2-ia
216  data_thin(is1+i,k)=wa*data_full(is2+ia,k)+wb*data_full(is2+ib,k)
217  ENDDO
218  is1=is1+im1
219  is2=is2+im2
220  ENDDO
221  ENDDO
222  ENDIF
223  ENDIF
224 ! - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
225  END SUBROUTINE ipxwafs
subroutine ipxwafs(IDIR, NUMPTS_THIN, NUMPTS_FULL, KM, NUM_OPT, OPT_PTS, IGDTLEN, IGDTMPL_THIN, DATA_THIN, IGDTMPL_FULL, DATA_FULL, IRET)
Expand or contract wafs grids.
Definition: ipxwafs.F90:84