New URL for NEMO forge!   http://forge.nemo-ocean.eu

Since March 2022 along with NEMO 4.2 release, the code development moved to a self-hosted GitLab.
This present forge is now archived and remained online for history.
obs_read_vel.F90 in branches/nemo_v3_3_beta/NEMOGCM/NEMO/OPA_SRC/OBS – NEMO

source: branches/nemo_v3_3_beta/NEMOGCM/NEMO/OPA_SRC/OBS/obs_read_vel.F90 @ 2513

Last change on this file since 2513 was 2287, checked in by smasson, 14 years ago

update licence of all NEMO files...

  • Property svn:keywords set to Id
File size: 24.9 KB
Line 
1MODULE obs_read_vel
2   !!======================================================================
3   !!                       ***  MODULE obs_read_vel  ***
4   !! Observation diagnostics: Read the velocity profile observations
5   !!======================================================================
6
7   !!----------------------------------------------------------------------
8   !!   obs_rea_vel_dri : Driver for reading profile obs
9   !!----------------------------------------------------------------------
10
11   !! * Modules used   
12   USE par_kind                 ! Precision variables
13   USE par_oce                  ! Ocean parameters
14   USE in_out_manager           ! I/O manager
15   USE dom_oce                  ! Ocean space and time domain variables
16   USE obs_mpp                  ! MPP support routines for observation diagnostics
17   USE julian                   ! Julian date routines
18   USE obs_utils                ! Observation operator utility functions
19   USE obs_prep                 ! Prepare observation arrays
20   USE obs_grid                 ! Grid search
21   USE obs_sort                 ! Sorting observation arrays
22   USE obs_profiles_def         ! Profile definitions
23   USE obs_conv                 ! Various conversion routines
24   USE obs_types                ! Observation type definitions
25   USE netcdf                   ! NetCDF library
26   USE obs_oper                 ! Observation operators
27   USE obs_vel_io               ! Velocity profile files I/O (non-FB files)
28
29   IMPLICIT NONE
30
31   !! * Routine accessibility
32   PRIVATE
33
34   PUBLIC obs_rea_vel_dri  ! Read the profile observations
35
36   !!----------------------------------------------------------------------
37   !! NEMO/OPA 3.3 , NEMO Consortium (2010)
38   !! $Id$
39   !! Software governed by the CeCILL licence (NEMOGCM/NEMO_CeCILL.txt)
40   !!----------------------------------------------------------------------
41
42CONTAINS
43 
44   SUBROUTINE obs_rea_vel_dri( kformat, &
45      &                        profdata, knumfiles, cfilenames, &
46      &                        kvars, kextr, kstp, ddobsini, ddobsend, &
47      &                        ldignmis, ldavtimset, ldmod )
48      !!---------------------------------------------------------------------
49      !!
50      !!                   *** ROUTINE obs_rea_pro_dri ***
51      !!
52      !! ** Purpose : Read from file the profile observations
53      !!
54      !! ** Method  : Depending on kformat either ENACT, CORIOLIS or
55      !!              feedback data files are read
56      !!
57      !! ** Action  :
58      !!
59      !! References :
60      !!
61      !! History : 
62      !!      ! :  2009-01 (K. Mogensen) : New merged version of old routines
63      !!----------------------------------------------------------------------
64      !! * Modules used
65   
66      !! * Arguments
67      INTEGER :: kformat   ! Format of input data
68      !                    ! 1: ENACT
69      !                    ! 2: Coriolis
70      TYPE(obs_prof), INTENT(OUT) :: profdata    ! Profile data to be read
71      INTEGER, INTENT(IN) :: knumfiles           ! Number of files to read in
72      CHARACTER(LEN=128), INTENT(IN) ::  cfilenames(knumfiles) ! File names to read in
73      INTEGER, INTENT(IN) :: kvars       ! Number of variables in profdata
74      INTEGER, INTENT(IN) :: kextr       ! Number of extra fields for each var in profdata
75      INTEGER, INTENT(IN) :: kstp        !  Ocean time-step index
76      LOGICAL, INTENT(IN) :: ldignmis    ! Ignore missing files
77      LOGICAL, INTENT(IN) :: ldavtimset  ! Set time to be equal to the end of the day
78      LOGICAL, INTENT(IN) :: ldmod       ! Initialize model from input data
79      REAL(KIND=dp), INTENT(IN) :: ddobsini   ! Obs. ini time in YYYYMMDD.HHMMSS
80      REAL(KIND=dp), INTENT(IN) :: ddobsend   ! Obs. end time in YYYYMMDD.HHMMSS
81
82      !! * Local declarations
83      CHARACTER(LEN=15), PARAMETER :: cpname='obs_rea_vel_dri'
84      INTEGER :: jvar
85      INTEGER :: ji
86      INTEGER :: jj
87      INTEGER :: jk
88      INTEGER :: ij
89      INTEGER :: iflag
90      INTEGER :: inobf
91      INTEGER :: i_file_id
92      INTEGER :: inowin
93      INTEGER :: iyea
94      INTEGER :: imon
95      INTEGER :: iday
96      INTEGER :: ihou
97      INTEGER :: imin
98      INTEGER :: isec
99      INTEGER, DIMENSION(knumfiles) :: &
100         & irefdate
101      INTEGER, DIMENSION(ntyp1770+1) :: &
102         & itypuv,    &
103         & itypuvmpp 
104      INTEGER :: iuv3dtmpp
105      INTEGER, DIMENSION(:), ALLOCATABLE :: &
106         & iobsiu,   &
107         & iobsju,   &
108         & iprocu,   &
109         & iobsiv,   &
110         & iobsjv,   &
111         & iprocv,   &
112         & iindx,    &
113         & ifileidx, &
114         & iprofidx
115      INTEGER :: itype
116      REAL(wp), DIMENSION(:), ALLOCATABLE :: &
117         & zphi, &
118         & zlam
119      REAL(dp), DIMENSION(:), ALLOCATABLE :: &
120         & zdat
121      LOGICAL :: &
122         & llvalprof
123      TYPE(obfbdata), POINTER, DIMENSION(:) :: &
124         & inpfiles
125      REAL(dp), DIMENSION(knumfiles) :: &
126         & djulini, &
127         & djulend
128      INTEGER :: iprof
129      INTEGER :: iproftot
130      INTEGER :: iuv3dt
131      INTEGER, DIMENSION(kvars) :: iv3dt
132      CHARACTER(len=8) :: cl_refdate
133   
134      ! Local initialization
135      iprof = 0
136      iuv3dt = 0
137
138      !-----------------------------------------------------------------------
139      ! Check data the model part is just with feedback data files
140      !-----------------------------------------------------------------------
141      IF ( ldmod .AND. ( kformat /= 0 ) ) THEN
142         CALL ctl_stop( 'Model can only be read from feedback data' )
143         RETURN
144      ENDIF
145
146      !-----------------------------------------------------------------------
147      ! Count the number of files needed and allocate the obfbdata type
148      !-----------------------------------------------------------------------
149     
150      inobf = knumfiles
151
152      ALLOCATE( inpfiles(inobf) )
153
154      prof_files : DO jj = 1, inobf
155         
156         !---------------------------------------------------------------------
157         ! Prints
158         !---------------------------------------------------------------------
159         IF(lwp) THEN
160            WRITE(numout,*)
161            WRITE(numout,*) ' obs_rea_vel_dri : Reading from file = ', &
162               & TRIM( TRIM( cfilenames(jj) ) )
163            WRITE(numout,*) ' ~~~~~~~~~~~~~~~'
164            WRITE(numout,*)
165         ENDIF
166
167         !---------------------------------------------------------------------
168         !  Initialization: Open file and get dimensions only
169         !---------------------------------------------------------------------
170         
171         iflag = nf90_open( TRIM( TRIM( cfilenames(jj) ) ), nf90_nowrite, &
172            &                      i_file_id )
173         
174         IF ( iflag /= nf90_noerr ) THEN
175
176            IF ( ldignmis ) THEN
177               inpfiles(jj)%nobs = 0
178               CALL ctl_warn( 'File ' // TRIM( TRIM( cfilenames(jj) ) ) // &
179                  &           ' not found' )
180            ELSE
181               CALL ctl_stop( 'File ' // TRIM( TRIM( cfilenames(jj) ) ) // &
182                  &           ' not found' )
183            ENDIF
184
185         ELSE 
186           
187            !------------------------------------------------------------------
188            !  Close the file since it is opened in read_proffile
189            !------------------------------------------------------------------
190           
191            iflag = nf90_close( i_file_id )
192
193            !------------------------------------------------------------------
194            !  Read the profile file into inpfiles
195            !------------------------------------------------------------------
196            IF ( kformat == 0 ) THEN
197               CALL init_obfbdata( inpfiles(jj) )
198               IF(lwp) THEN
199                  WRITE(numout,*)
200                  WRITE(numout,*)'Reading from feedback file :', &
201                     &           TRIM( cfilenames(jj) )
202               ENDIF
203               CALL read_obfbdata( TRIM( cfilenames(jj) ), inpfiles(jj), &
204                  &                ldgrid = .TRUE. )
205               IF ( ldmod .AND. ( inpfiles(jj)%nadd == 0 ) ) THEN
206                  CALL ctl_stop( 'Model not in input data' )
207                  RETURN
208               ENDIF
209            ELSEIF ( kformat == 1 ) THEN
210               CALL read_taondbc( TRIM( cfilenames(jj) ), inpfiles(jj), &
211                  &               numout, lwp, .TRUE. )
212            ELSE
213               CALL ctl_stop( 'File format unknown' )
214            ENDIF
215           
216            !------------------------------------------------------------------
217            !  Change longitude (-180,180)
218            !------------------------------------------------------------------
219
220            DO ji = 1, inpfiles(jj)%nobs 
221
222               IF ( inpfiles(jj)%plam(ji) < -180. ) &
223                  &   inpfiles(jj)%plam(ji) = inpfiles(jj)%plam(ji) + 360.
224
225               IF ( inpfiles(jj)%plam(ji) >  180. ) &
226                  &   inpfiles(jj)%plam(ji) = inpfiles(jj)%plam(ji) - 360.
227
228            END DO
229
230            !------------------------------------------------------------------
231            !  Calculate the date  (change eventually)
232            !------------------------------------------------------------------
233            cl_refdate=inpfiles(jj)%cdjuldref(1:8)
234            READ(cl_refdate,'(I8)') irefdate(jj)
235           
236            CALL ddatetoymdhms( ddobsini, iyea, imon, iday, ihou, imin, isec )
237            CALL greg2jul( isec, imin, ihou, iday, imon, iyea, djulini(jj), &
238               &           krefdate = irefdate(jj) )
239            CALL ddatetoymdhms( ddobsend, iyea, imon, iday, ihou, imin, isec )
240            CALL greg2jul( isec, imin, ihou, iday, imon, iyea, djulend(jj), &
241               &           krefdate = irefdate(jj) )
242
243            IF ( ldavtimset ) THEN
244               DO ji = 1, inpfiles(jj)%nobs
245                  !
246                  !  for daily averaged data force the time
247                  !  to be the  end of the day
248                  !
249                  inpfiles(jj)%ptim(ji) = &
250                     & INT(inpfiles(jj)%ptim(ji)) + 1
251               END DO
252            ENDIF
253           
254            IF ( inpfiles(jj)%nobs > 0 ) THEN
255               inpfiles(jj)%iproc = -1
256               inpfiles(jj)%iobsi = -1
257               inpfiles(jj)%iobsj = -1
258            ENDIF
259            inowin = 0
260            DO ji = 1, inpfiles(jj)%nobs
261               IF ( ( inpfiles(jj)%ptim(ji) >  djulini(jj) ) .AND. &
262                  & ( inpfiles(jj)%ptim(ji) <= djulend(jj) )       ) THEN
263                  inowin = inowin + 1
264               ENDIF
265            END DO
266            ALLOCATE( zlam(inowin)  )
267            ALLOCATE( zphi(inowin)  )
268            ALLOCATE( iobsiu(inowin) )
269            ALLOCATE( iobsju(inowin) )
270            ALLOCATE( iprocu(inowin) )
271            ALLOCATE( iobsiv(inowin) )
272            ALLOCATE( iobsjv(inowin) )
273            ALLOCATE( iprocv(inowin) )
274            inowin = 0
275            DO ji = 1, inpfiles(jj)%nobs
276               IF ( ( inpfiles(jj)%ptim(ji) >  djulini(jj) ) .AND. &
277                  & ( inpfiles(jj)%ptim(ji) <= djulend(jj) )       ) THEN
278                  inowin = inowin + 1
279                  zlam(inowin) = inpfiles(jj)%plam(ji)
280                  zphi(inowin) = inpfiles(jj)%pphi(ji)
281               ENDIF
282            END DO
283
284            CALL obs_grid_search( inowin, zlam, zphi, iobsiu, iobsju, iprocu, &
285               & 'U' )
286            CALL obs_grid_search( inowin, zlam, zphi, iobsiv, iobsjv, iprocv, &
287               & 'V' )
288
289            inowin = 0
290            DO ji = 1, inpfiles(jj)%nobs
291               IF ( ( inpfiles(jj)%ptim(ji) >  djulini(jj) ) .AND. &
292                  & ( inpfiles(jj)%ptim(ji) <= djulend(jj) )       ) THEN
293                  inowin = inowin + 1
294                  inpfiles(jj)%iproc(ji,1) = iprocu(inowin)
295                  inpfiles(jj)%iobsi(ji,1) = iobsiu(inowin)
296                  inpfiles(jj)%iobsj(ji,1) = iobsju(inowin)
297                  inpfiles(jj)%iproc(ji,2) = iprocv(inowin)
298                  inpfiles(jj)%iobsi(ji,2) = iobsiv(inowin)
299                  inpfiles(jj)%iobsj(ji,2) = iobsjv(inowin)
300                  IF ( inpfiles(jj)%iproc(ji,1) /= &
301                     & inpfiles(jj)%iproc(ji,2) ) THEN
302                     CALL ctl_stop( 'Error in obs_read_vel:', &
303                        & 'U and V observation on different processors')
304                  ENDIF
305               ENDIF
306            END DO
307            DEALLOCATE( zlam, zphi, iobsiu, iobsju, iprocu,  &
308               & iobsiv, iobsjv, iprocv )
309
310            DO ji = 1, inpfiles(jj)%nobs
311               IF ( ( inpfiles(jj)%ptim(ji) >  djulini(jj) ) .AND. &
312                  & ( inpfiles(jj)%ptim(ji) <= djulend(jj) )       ) THEN
313                  IF ( nproc == 0 ) THEN
314                     IF ( inpfiles(jj)%iproc(ji,1) >  nproc ) CYCLE
315                  ELSE
316                     IF ( inpfiles(jj)%iproc(ji,1) /=  nproc ) CYCLE
317                  ENDIF
318                  llvalprof = .FALSE.
319                  IF ( ( ( nproc == 0 ) .AND. &
320                     & ( inpfiles(jj)%iproc(ji,1) <=  nproc ) ) .OR. &
321                     & ( inpfiles(jj)%iproc(ji,1) ==  nproc ) ) THEN
322                     loop_uv_count : DO ij = 1,inpfiles(jj)%nlev
323                        IF ( inpfiles(jj)%pdep(ij,ji) >= 6000. ) &
324                           & CYCLE
325                        IF ( ( inpfiles(jj)%ivlqc(ij,ji,1) <= 2 ) .AND. &
326                           & ( inpfiles(jj)%ivlqc(ij,ji,2) <= 2 ) .AND. &
327                           & ( inpfiles(jj)%idqc(ij,ji) <= 2 ) ) THEN
328                           iuv3dt = iuv3dt + 1
329                           llvalprof = .TRUE.
330                        ENDIF
331                     END DO loop_uv_count
332                  ENDIF
333                  IF ( llvalprof ) iprof = iprof + 1
334               ENDIF
335            END DO
336
337         ENDIF
338         
339      END DO prof_files
340
341      !-----------------------------------------------------------------------
342      ! Get the time ordered indices of the input data
343      !-----------------------------------------------------------------------
344
345      !---------------------------------------------------------------------
346      !  Loop over input data files to count total number of profiles
347      !---------------------------------------------------------------------
348      iproftot = 0
349      DO jj = 1, inobf
350         DO ji = 1, inpfiles(jj)%nobs
351            IF ( ( inpfiles(jj)%ptim(ji) >  djulini(jj) ) .AND. &
352               & ( inpfiles(jj)%ptim(ji) <= djulend(jj) )       ) THEN
353               iproftot = iproftot + 1
354            ENDIF
355         END DO
356      END DO
357
358      ALLOCATE( iindx(iproftot), ifileidx(iproftot), &
359         &      iprofidx(iproftot), zdat(iproftot) )
360      jk = 0
361      DO jj = 1, inobf
362         DO ji = 1, inpfiles(jj)%nobs
363            IF ( ( inpfiles(jj)%ptim(ji) >  djulini(jj) ) .AND. &
364               & ( inpfiles(jj)%ptim(ji) <= djulend(jj) )       ) THEN
365               jk = jk + 1
366               ifileidx(jk) = jj
367               iprofidx(jk) = ji
368               zdat(jk)     = inpfiles(jj)%ptim(ji)
369            ENDIF
370         END DO
371      END DO
372      CALL sort_dp_indx( iproftot, &
373         &               zdat,     &
374         &               iindx   )
375     
376      iv3dt(:) = -1
377      iv3dt(1:2) = iuv3dt
378      CALL obs_prof_alloc( profdata, kvars, kextr, iprof, iv3dt, &
379         &                 kstp, jpi, jpj, jpk )
380     
381      ! * Read obs/positions, QC, all variable and assign to profdata
382
383      profdata%nprof     = 0
384      profdata%nvprot(:) = 0
385
386      iprof = 0
387
388      iuv3dt = 0
389      itypuv   (:) = 0
390      itypuvmpp(:) = 0
391     
392      DO jk = 1, iproftot
393         
394         jj = ifileidx(iindx(jk))
395         ji = iprofidx(iindx(jk))
396         IF ( ( inpfiles(jj)%ptim(ji) >  djulini(jj) ) .AND.  &
397            & ( inpfiles(jj)%ptim(ji) <= djulend(jj) ) ) THEN
398           
399            IF ( nproc == 0 ) THEN
400               IF ( inpfiles(jj)%iproc(ji,1) >  nproc ) CYCLE
401            ELSE
402               IF ( inpfiles(jj)%iproc(ji,1) /= nproc ) CYCLE
403            ENDIF
404           
405            llvalprof = .FALSE.
406
407            loop_prof : DO ij = 1, inpfiles(jj)%nlev
408               
409               IF ( inpfiles(jj)%pdep(ij,ji) >= 6000. ) &
410                  & CYCLE
411               
412               IF ( ( inpfiles(jj)%ivlqc(ij,ji,1) <= 2 ) .AND. &
413                  & ( inpfiles(jj)%ivlqc(ij,ji,2) <= 2 ) .AND. &
414                  & ( inpfiles(jj)%idqc(ij,ji) <= 2 ) ) THEN
415
416                  llvalprof = .TRUE.
417                  EXIT loop_prof
418
419               ENDIF
420
421            END DO loop_prof
422           
423            ! Set profile information
424           
425            IF ( llvalprof ) THEN
426               
427               iprof = iprof + 1
428
429               CALL jul2greg( isec,                   &
430                  &           imin,                   &
431                  &           ihou,                   &
432                  &           iday,                   &
433                  &           imon,                   &
434                  &           iyea,                   &
435                  &           inpfiles(jj)%ptim(ji), &
436                  &           irefdate(jj) )
437
438
439               ! Profile time coordinates
440               profdata%nyea(iprof) = iyea
441               profdata%nmon(iprof) = imon
442               profdata%nday(iprof) = iday
443               profdata%nhou(iprof) = ihou
444               profdata%nmin(iprof) = imin
445               
446               ! Profile space coordinates
447               profdata%rlam(iprof) = inpfiles(jj)%plam(ji)
448               profdata%rphi(iprof) = inpfiles(jj)%pphi(ji)
449
450               ! Coordinate search parameters
451               profdata%mi  (iprof,1) = inpfiles(jj)%iobsi(ji,1)
452               profdata%mj  (iprof,1) = inpfiles(jj)%iobsj(ji,1)
453               profdata%mi  (iprof,2) = inpfiles(jj)%iobsi(ji,2)
454               profdata%mj  (iprof,2) = inpfiles(jj)%iobsj(ji,2)
455               
456               ! Profile WMO number
457               profdata%cwmo(iprof) = inpfiles(jj)%cdwmo(ji)
458               
459               ! Instrument type
460               READ( inpfiles(jj)%cdtyp(ji), '(I4)' ) itype
461               profdata%ntyp(iprof) = itype
462               
463               ! QC stuff
464
465               profdata%nqc(iprof)     = inpfiles(jj)%ioqc(ji)
466               profdata%nqcf(:,iprof)  = inpfiles(jj)%ioqcf(:,ji)
467               profdata%ipqc(iprof)    = inpfiles(jj)%ipqc(ji)
468               profdata%ipqcf(:,iprof) = inpfiles(jj)%ipqcf(:,ji)
469               profdata%itqc(iprof)    = inpfiles(jj)%itqc(ji)
470               profdata%itqcf(:,iprof) = inpfiles(jj)%itqcf(:,ji)
471               profdata%ivqc(iprof,:)  = inpfiles(jj)%ivqc(ji,:)
472               profdata%ivqcf(:,iprof,:) = inpfiles(jj)%ivqcf(:,ji,:)
473
474               ! Bookkeeping data to match profiles
475               profdata%npidx(iprof) = iprof
476               profdata%npfil(iprof) = iindx(jk)
477
478               ! Observation QC flag (whole profile)
479               profdata%nqc(iprof)  = 0 !TODO
480
481               loop_uv : DO ij = 1, inpfiles(jj)%nlev           
482                   
483                  IF ( inpfiles(jj)%pdep(ij,ji) >= 6000. ) &
484                     & CYCLE
485
486                  IF ( ( inpfiles(jj)%ivlqc(ij,ji,1) <= 2 ) .AND. &
487                     & ( inpfiles(jj)%ivlqc(ij,ji,2) <= 2 ) .AND. &
488                     & ( inpfiles(jj)%idqc(ij,ji) <= 2 ) ) THEN
489                     iuv3dt = iuv3dt + 1
490                  ELSE
491                     CYCLE
492                  ENDIF
493
494                  ! Depth of U observation
495                  profdata%var(1)%vdep(iuv3dt) = &
496                     &                inpfiles(jj)%pdep(ij,ji)
497                 
498                  ! Depth of U observation QC
499                  profdata%var(1)%idqc(iuv3dt) = &
500                     &                inpfiles(jj)%idqc(ij,ji)
501                 
502                  ! Depth of U observation QC flags
503                  profdata%var(1)%idqcf(:,iuv3dt) = &
504                     &                inpfiles(jj)%idqcf(:,ij,ji)
505                 
506                  ! Profile index
507                  profdata%var(1)%nvpidx(iuv3dt) = iprof
508                 
509                  ! Vertical index in original profile
510                  profdata%var(1)%nvlidx(iuv3dt) = ij
511
512                  ! Profile U value
513
514                  profdata%var(1)%vobs(iuv3dt) = &
515                     &                inpfiles(jj)%pob(ij,ji,1)
516                  IF ( ldmod ) THEN
517                     profdata%var(1)%vmod(iuv3dt) = &
518                        &                inpfiles(jj)%padd(ij,ji,1,1)
519                  ENDIF
520                 
521                  ! Profile U qc
522                  profdata%var(1)%nvqc(iuv3dt) = &
523                     & inpfiles(jj)%ivlqc(ij,ji,1)
524                 
525                  ! Profile U qc flags
526                  profdata%var(1)%nvqcf(:,iuv3dt) = &
527                     & inpfiles(jj)%ivlqcf(:,ij,ji,1)
528                 
529                 
530                  ! Depth of V observation
531                  profdata%var(2)%vdep(iuv3dt) = &
532                     &                inpfiles(jj)%pdep(ij,ji)
533                 
534                  ! Depth of V observation QC
535                  profdata%var(2)%idqc(iuv3dt) = &
536                     &                inpfiles(jj)%idqc(ij,ji)
537                 
538                  ! Depth of V observation QC flags
539                  profdata%var(2)%idqcf(:,iuv3dt) = &
540                     &                inpfiles(jj)%idqcf(:,ij,ji)
541                 
542                  ! Profile index
543                  profdata%var(2)%nvpidx(iuv3dt) = iprof
544                 
545                  ! Vertical index in original profile
546                  profdata%var(2)%nvlidx(iuv3dt) = ij
547                 
548                  ! Profile V value
549                  profdata%var(2)%vobs(iuv3dt) = &
550                     &                inpfiles(jj)%pob(ij,ji,2)
551                  IF ( ldmod ) THEN
552                     profdata%var(2)%vmod(iuv3dt) = &
553                        &                inpfiles(jj)%padd(ij,ji,1,2)
554                  ENDIF
555                     
556                  ! Profile V qc
557                  profdata%var(2)%nvqc(iuv3dt) = &
558                     & inpfiles(jj)%ivlqc(ij,ji,2)
559                 
560                  ! Profile V qc flags
561                  profdata%var(2)%nvqcf(:,iuv3dt) = &
562                        & inpfiles(jj)%ivlqcf(:,ij,ji,2)
563                 
564                  ! Observation type
565                  itypuv( profdata%ntyp(iprof) + 1 ) = &
566                     & itypuv( profdata%ntyp(iprof) + 1 ) + 1
567
568
569               END DO loop_uv
570
571            ENDIF
572
573         ENDIF
574
575      END DO
576
577      !-----------------------------------------------------------------------
578      ! Sum up over processors
579      !-----------------------------------------------------------------------
580     
581      CALL obs_mpp_sum_integer ( iuv3dt, iuv3dtmpp )
582     
583      CALL obs_mpp_sum_integers( itypuv, itypuvmpp, ntyp1770 + 1 )
584     
585      !-----------------------------------------------------------------------
586      ! Output number of observations.
587      !-----------------------------------------------------------------------
588      IF(lwp) THEN
589         WRITE(numout,*) 
590         WRITE(numout,'(1X,A)') 'Profile U,V velocity data'
591         WRITE(numout,'(1X,A)') '-------------------------'
592         WRITE(numout,*) 
593         DO ji = 0, ntyp1770
594            IF ( itypuvmpp(ji+1) > 0 ) THEN
595               WRITE(numout,'(1X,A3,A3,I8)') ctypshort(ji), ' = ', &
596                  & itypuvmpp(ji+1)
597            ENDIF
598         END DO
599         WRITE(numout,'(1X,A)') '--------------'
600         WRITE(numout,'(1X,A6,I8)') &
601            & 'Total profile UV data                                 = ',&
602            & iuv3dtmpp
603         WRITE(numout,'(1X,A)') '--------------'
604      ENDIF
605     
606      profdata%nvprot(1)    = iuv3dt
607      profdata%nvprot(2)    = iuv3dt
608      profdata%nvprotmpp(1) = iuv3dtmpp
609      profdata%nvprotmpp(2) = iuv3dtmpp
610      profdata%nprof        = iprof
611
612      !-----------------------------------------------------------------------
613      ! Model level search
614      !-----------------------------------------------------------------------
615      CALL obs_level_search( jpk, gdept_0, &
616         & profdata%nvprot(1), profdata%var(1)%vdep, &
617         & profdata%var(1)%mvk )
618      CALL obs_level_search( jpk, gdept_0, &
619         & profdata%nvprot(2), profdata%var(2)%vdep, &
620         & profdata%var(2)%mvk )
621     
622      !-----------------------------------------------------------------------
623      ! Set model equivalent to 99999
624      !-----------------------------------------------------------------------
625      IF ( .NOT. ldmod ) THEN
626         DO jvar = 1, kvars
627            profdata%var(jvar)%vmod(:) = fbrmdi
628         END DO
629      ENDIF
630      !-----------------------------------------------------------------------
631      ! Deallocate temporary data
632      !-----------------------------------------------------------------------
633      DEALLOCATE( ifileidx, iprofidx, zdat )
634
635      !-----------------------------------------------------------------------
636      ! Deallocate input data
637      !-----------------------------------------------------------------------
638      DO jj = 1, inobf
639         CALL dealloc_obfbdata( inpfiles(jj) )
640      END DO
641      DEALLOCATE( inpfiles )
642
643   END SUBROUTINE obs_rea_vel_dri
644   
645END MODULE obs_read_vel
Note: See TracBrowser for help on using the repository browser.