<HTML> <BODY BGCOLOR=#ccccdd LINK=#0000aa VLINK=#0000ff ALINK=#ff0000 ><BASE TARGET="bottom_target"><PRE>
<A NAME='DA_AO_STATS_RADAR'><A href='../../html_code/radar/da_ao_stats_radar.inc.html#DA_AO_STATS_RADAR' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

subroutine da_ao_stats_radar (stats_unit, iv, re) 1,21

   !-----------------------------------------------------------------------
   ! Purpose: TBD
   !-----------------------------------------------------------------------

   implicit none

   integer,        intent (in)    :: stats_unit    ! Output unit for stats.
   type (iv_type), intent (inout) :: iv            ! iv
   type (y_type),  intent (in)    :: re            ! A - O

   type (stats_radar_type) :: stats
   integer                 :: nrv, nrf, nrrn, nrsn, nrgr,nrqv
   integer                 :: n, k

   if (trace_use) call da_trace_entry("da_ao_stats_radar")

   nrv = 0
   nrf = 0
   nrrn= 0
   nrsn= 0
   nrgr= 0
   nrqv= 0

   stats%maximum%rv = maxmin_type (missing_r, 0, 0)
   stats%maximum%rf = maxmin_type (missing_r, 0, 0)
   stats%minimum%rv = maxmin_type(-missing_r, 0, 0)
   stats%minimum%rf = maxmin_type(-missing_r, 0, 0)

   stats%maximum%rrn = maxmin_type (missing_r, 0, 0)
   stats%maximum%rsn = maxmin_type (missing_r, 0, 0)
   stats%maximum%rgr = maxmin_type (missing_r, 0, 0)
   stats%maximum%rcl = maxmin_type (missing_r, 0, 0)
   stats%maximum%rci = maxmin_type (missing_r, 0, 0)
   stats%maximum%rqv = maxmin_type (missing_r, 0, 0)

   stats%minimum%rrn = maxmin_type(-missing_r, 0, 0)
   stats%minimum%rsn = maxmin_type(-missing_r, 0, 0)
   stats%minimum%rgr = maxmin_type(-missing_r, 0, 0)
   stats%minimum%rcl = maxmin_type(-missing_r, 0, 0)
   stats%minimum%rci = maxmin_type(-missing_r, 0, 0)
   stats%minimum%rqv = maxmin_type(-missing_r, 0, 0)

   stats%average = residual_radar1_type(0.0, 0.0, 0.0, 0.0, 0.0,0.0,0.0,0.0)
   stats%rms_err = stats%average

   do n=1, iv%info(radar)%nlocal
      if (iv%info(radar)%proc_domain(1,n)) then
         do k=1, iv%info(radar)%levels(n)
            if (use_radar_rv) then
               call da_stats_calculate (n, k, iv%radar(n)%rv(k)%qc, &amp; 
                  re%radar(n)%rv(k), nrv, &amp; 
                  stats%minimum%rv, stats%maximum%rv, &amp;
                  stats%average%rv, stats%rms_err%rv)
            end if

            if (use_radar_rf) then
               call da_stats_calculate (n, k, iv%radar(n)%rf(k)%qc, &amp; 
                  re%radar(n)%rf(k), nrf, &amp; 
                  stats%minimum%rf, stats%maximum%rf, &amp;
                  stats%average%rf, stats%rms_err%rf)
            end if

            if (.not. use_radar_rf .and. use_radar_rhv) then
               call da_stats_calculate (n, k, iv%radar(n)%rrn(k)%qc, &amp;
                  re%radar(n)%rrn(k), nrrn, &amp;
                  stats%minimum%rrn, stats%maximum%rrn, &amp;
                  stats%average%rrn, stats%rms_err%rrn)
              call da_stats_calculate (n, k, iv%radar(n)%rsn(k)%qc, &amp;
                  re%radar(n)%rsn(k), nrsn, &amp;
                  stats%minimum%rsn, stats%maximum%rsn, &amp;
                  stats%average%rsn, stats%rms_err%rsn)
               call da_stats_calculate (n, k, iv%radar(n)%rgr(k)%qc, &amp;
                  re%radar(n)%rgr(k), nrgr, &amp;
                  stats%minimum%rgr, stats%maximum%rgr, &amp;
                  stats%average%rgr, stats%rms_err%rgr)
            end if

            if (use_radar_rqv) then
               call da_stats_calculate (n, k, iv%radar(n)%rqv(k)%qc, &amp;
                  re%radar(n)%rqv(k), nrqv, &amp;
                  stats%minimum%rqv, stats%maximum%rqv, &amp;
                  stats%average%rqv, stats%rms_err%rqv)
            end if
         end do
      end if    
   end do
   ! Do inter-processor communication to gather statistics.
   if (use_radar_rv) then
      call da_proc_sum_int (nrv)
      call da_proc_stats_combine(stats%average%rv, stats%rms_err%rv, &amp;
         stats%minimum%rv%value, stats%maximum%rv%value, &amp;
         stats%minimum%rv%n, stats%maximum%rv%n, &amp;
         stats%minimum%rv%l, stats%maximum%rv%l)
   end if

   if (use_radar_rf) then
      call da_proc_sum_int (nrf)
      call da_proc_stats_combine(stats%average%rf, stats%rms_err%rf, &amp;
          stats%minimum%rf%value, stats%maximum%rf%value, &amp;
          stats%minimum%rf%n, stats%maximum%rf%n, &amp;
          stats%minimum%rf%l, stats%maximum%rf%l)
   end if

   if (.not.use_radar_rf .and. use_radar_rhv) then
      call da_proc_sum_int (nrrn)
      call da_proc_stats_combine(stats%average%rrn, stats%rms_err%rrn, &amp;
          stats%minimum%rrn%value, stats%maximum%rrn%value, &amp;
          stats%minimum%rrn%n, stats%maximum%rrn%n, &amp;
          stats%minimum%rrn%l, stats%maximum%rrn%l)
      call da_proc_sum_int (nrsn)
      call da_proc_stats_combine(stats%average%rsn, stats%rms_err%rsn, &amp;
          stats%minimum%rsn%value, stats%maximum%rsn%value, &amp;
          stats%minimum%rsn%n, stats%maximum%rsn%n, &amp;
          stats%minimum%rsn%l, stats%maximum%rsn%l)
      call da_proc_sum_int (nrgr)
      call da_proc_stats_combine(stats%average%rgr, stats%rms_err%rgr, &amp;
          stats%minimum%rgr%value, stats%maximum%rgr%value, &amp;
          stats%minimum%rgr%n, stats%maximum%rgr%n, &amp;
          stats%minimum%rgr%l, stats%maximum%rgr%l)
   end if

   if (use_radar_rqv) then
      call da_proc_sum_int (nrqv)
      call da_proc_stats_combine(stats%average%rqv, stats%rms_err%rqv, &amp;
          stats%minimum%rqv%value, stats%maximum%rqv%value, &amp;
          stats%minimum%rqv%n, stats%maximum%rqv%n, &amp;
          stats%minimum%rqv%l, stats%maximum%rqv%l)
   end if
   iv%nstats(radar) = nrv + nrf + nrrn + nrsn + nrgr + nrqv

   if (rootproc) then
      if (nrv /= 0 .or. nrf /= 0 .or. nrrn /= 0 .or. nrsn /= 0 .or. nrgr /= 0 .or. nrqv /= 0) then 
         write(unit=stats_unit, fmt='(/a/)') ' Diagnostics of AO for radar'
         call da_print_stats_radar(stats_unit, nrv, nrf, nrrn, nrsn, nrgr, nrqv, stats)
      end if
   end if

   if (trace_use) call da_trace_exit("da_ao_stats_radar")

end subroutine da_ao_stats_radar