da_print_stats_bogus.inc
References to this file elsewhere.
1 subroutine da_print_stats_bogus(stats_unit, nu, nv, nt, nq, nslp, Bogus)
2
3 !-----------------------------------------------------------------------
4 ! Purpose: TBD
5 !-----------------------------------------------------------------------
6
7 implicit none
8
9 integer, intent(in) :: stats_unit
10 integer, intent(inout) :: nu, nv, nt, nq, nslp
11 type (stats_bogus_type), intent(in) :: bogus
12
13 if (trace_use_dull) call da_trace_entry("da_print_stats_bogus")
14
15 write(unit=stats_unit, fmt='(6a/)') &
16 ' var ', &
17 'u (m/s) n k ', &
18 'v (m/s) n k ', &
19 't (K) n k ', &
20 'q (kg/kg) n k ', &
21 'slp (pa) n k'
22
23 write(unit=stats_unit, fmt='(a,i16,4i22)') &
24 ' Number: ', nu, nv, nt, nq, nslp
25
26 if (nu < 1) nu = 1
27 if (nv < 1) nv = 1
28 if (nt < 1) nt = 1
29 if (nq < 1) nq = 1
30 if (nslp < 1) nslp = 1
31
32 write(unit=stats_unit, fmt='((a,3(f12.4,2i5),e12.4,2i5,f12.4,2i5))') &
33 ' Minimum(n,k): ', Bogus%minimum%u, Bogus%minimum%v, Bogus%minimum%t, &
34 Bogus%minimum%q, Bogus%minimum%slp, &
35 ' Maximum(n,k): ', Bogus%maximum%u, Bogus%maximum%v, Bogus%maximum%t, &
36 Bogus%maximum%q, Bogus%maximum%slp
37 write(unit=stats_unit, fmt='((a,3(f12.4,10x),e12.4,10x,f12.4,10x))') &
38 ' Average : ', Bogus%average%u/real(nu), &
39 Bogus%average%v/real(nv), &
40 Bogus%average%t/real(nt), &
41 Bogus%average%q/real(nq), &
42 Bogus%average%slp/real(nslp), &
43 ' RMSE : ', sqrt(Bogus%rms_err%u/real(nu)), &
44 sqrt(Bogus%rms_err%v/real(nv)), &
45 sqrt(Bogus%rms_err%t/real(nt)), &
46 sqrt(Bogus%rms_err%q/real(nq)), &
47 sqrt(Bogus%rms_err%slp/real(nslp))
48
49 if (trace_use_dull) call da_trace_exit("da_print_stats_bogus")
50
51 end subroutine da_print_stats_bogus
52
53