<HTML> <BODY BGCOLOR=#ccccdd LINK=#0000aa VLINK=#0000ff ALINK=#ff0000 ><BASE TARGET="bottom_target"><PRE>
<A NAME='DA_MTGIRS'><A href='../../html_code/mtgirs/da_mtgirs.f90.html#DA_MTGIRS' TARGET='top_target'><IMG SRC="../../gif/bar_purple.gif" border=0></A>

module da_mtgirs 3,10

   use da_control, only : obs_qc_pointer,max_ob_levels,missing_r, &amp;
      check_max_iv_print, check_max_iv_unit, v_interp_p, v_interp_h, &amp;
      check_max_iv, missing_data, max_error_uv, max_error_t, rootproc, &amp;
      max_error_p,max_error_q, fails_error_max, &amp;
      max_stheight_diff,test_dm_exact, anal_type_verify, &amp;
      kms,kme,kts,kte, &amp;
      trace_use_dull, mtgirs, position_lev_dependant, max_ext_its, qcstat_conv_unit, ob_vars, &amp;
      convert_fd2uv, convert_uv2fd, max_error_spd, max_error_dir, max_omb_spd, max_omb_dir, pi, qc_rej_both,&amp;
      wind_sd_mtgirs, wind_stats_sd 
   use da_grid_definitions, only : da_ffdduv,da_ffdduv_model, da_ffdduv_diagnose
   use da_physics, only : da_uv_to_sd_lin, da_uv_to_sd_adj
   use da_define_structures, only : maxmin_type, iv_type, y_type, jo_type, &amp;
      bad_data_type, x_type, number_type, bad_data_type
   use module_domain, only : domain
   use da_interpolation, only : da_to_zk, da_interp_lin_3d, &amp;
      da_interp_lin_3d_adj, da_interp_lin_2d, da_interp_lin_2d_adj, da_interp_lin_2d_partial
   use da_statistics, only : da_stats_calculate
   use da_tools, only : da_max_error_qc, da_residual, da_convert_zk, da_get_print_lvl
   use da_par_util, only : da_proc_stats_combine
   use da_par_util1, only : da_proc_sum_int
   use da_tracing, only : da_trace_entry, da_trace_exit

   ! The "stats_mtgirs_type" is ONLY used locally in da_mtgirs:

   type residual_mtgirs1_type
      real          :: u                        ! u-wind.
      real          :: v                        ! v-wind.
      real          :: t                        ! temperature
      real          :: q                        ! specific humidity
   end type residual_mtgirs1_type

   type maxmin_mtgirs_stats_type
      type (maxmin_type)         :: u, v, t, q
   end type maxmin_mtgirs_stats_type

   type stats_mtgirs_type
      type (maxmin_mtgirs_stats_type)  :: maximum, minimum
      type (residual_mtgirs1_type)     :: average, rms_err
   end type stats_mtgirs_type

contains

#include "da_ao_stats_mtgirs.inc"
#include "da_jo_and_grady_mtgirs.inc"
#include "da_jo_mtgirs_uvtq.inc"
#include "da_residual_mtgirs.inc"
#include "da_oi_stats_mtgirs.inc"
#include "da_print_stats_mtgirs.inc"
#include "da_transform_xtoy_mtgirs.inc"
#include "da_transform_xtoy_mtgirs_adj.inc"
#include "da_check_max_iv_mtgirs.inc"
#include "da_get_innov_vector_mtgirs.inc"
#include "da_calculate_grady_mtgirs.inc"

end module da_mtgirs