source: LMDZ6/branches/LMDZ_ECRad/libf/phylmd/setup_aerosol_optics_lmdz_m.F90 @ 4183

Last change on this file since 4183 was 4183, checked in by lguez, 2 years ago

Bug fix: declare nf95_gw_var

File size: 4.8 KB
Line 
1module setup_aerosol_optics_lmdz_m
2
3  implicit none
4
5contains
6
7  subroutine setup_aerosol_optics_lmdz(ao, file_name)
8
9    ! Read aerosol optical properties. Note differences with
10    ! "radiation_aerosol_optics_data::setup_aerosol_optics":
11
12    ! -- The input NetCDF file is not flat, it contains NetCDF groups.
13
14    ! -- We do not define ao%ssa_mono_phobic, ao%g_mono_phobic,
15    ! ao%lidar_ratio_mono_phobic, ao%ssa_mono_philic,
16    ! ao%g_mono_philic, ao%lidar_ratio_mono_philic. They are not in
17    ! the input NetCDF file and they are not used by ECRad.
18
19    ! -- We do not define ao%description_phobic_str and
20    ! ao%description_philic_str. We just leave the initialization
21    ! value, which is a blank.
22
23    ! -- We have to cshift the shortwave fields because the the
24    ! shortwave bands are in ascending order in the NetCDF file while
25    ! they are not in ECRad.
26
27    use radiation_aerosol_optics_data, only: aerosol_optics_type, &
28         IAerosolClassUndefined
29    use netcdf95, only: nf95_open, nf95_inq_grp_full_ncid, nf95_close, &
30         nf95_inq_dimid, nf95_inq_varid, nf95_inquire_dimension, &
31         nf95_get_var, nf95_gw_var
32    use netcdf, only: nf90_nowrite
33
34    type(aerosol_optics_type), intent(out):: ao
35
36    character(len=*), intent(in):: file_name
37    ! NetCDF file containing the aerosol optics data
38
39    ! Local:
40    integer ncid, grpid, dimid, varid
41
42    !-----------------------------------------------------------------------
43
44    ao%use_hydrophilic = .true.
45    ao%use_monochromatic = .true.
46    call nf95_open(file_name, nf90_nowrite, ncid)
47    call nf95_inq_grp_full_ncid(ncid, "Hydrophilic", grpid)
48    call nf95_inq_dimid(grpid, "hur", dimid)
49    call nf95_inquire_dimension(grpid, dimid, nclen = ao%nrh)
50    allocate(ao%rh_lower(ao%nrh))
51    call nf95_inq_varid(grpid, "hur_bounds", varid)
52    call nf95_get_var(grpid, varid, ao%rh_lower, count_nc = [1, ao%nrh])
53
54    ! Hydrophilic/LW_bands:
55    call nf95_inq_grp_full_ncid(ncid, "Hydrophilic/LW_bands", grpid)
56    call nf95_inq_varid(grpid, "asymmetry", varid)
57    call nf95_gw_var(grpid, varid, ao%g_lw_philic)
58    call nf95_inq_varid(grpid, "single_scat_alb", varid)
59    call nf95_gw_var(grpid, varid, ao%ssa_lw_philic)
60    call nf95_inq_varid(grpid, "mass_ext", varid)
61    call nf95_gw_var(grpid, varid, ao%mass_ext_lw_philic)
62
63    ! Hydrophilic/SW_bands:
64    call nf95_inq_grp_full_ncid(ncid, "Hydrophilic/SW_bands", grpid)
65    call nf95_inq_varid(grpid, "asymmetry", varid)
66    call nf95_gw_var(grpid, varid, ao%g_sw_philic)
67    ao%g_sw_philic = cshift(ao%g_sw_philic, 1)
68    call nf95_inq_varid(grpid, "single_scat_alb", varid)
69    call nf95_gw_var(grpid, varid, ao%ssa_sw_philic)
70    ao%g_sw_philic = cshift(ao%ssa_sw_philic, 1)
71    call nf95_inq_varid(grpid, "mass_ext", varid)
72    call nf95_gw_var(grpid, varid, ao%mass_ext_sw_philic)
73    ao%g_sw_philic = cshift(ao%mass_ext_sw_philic, 1)
74
75    ! Hydrophilic/Monochromatic:
76    call nf95_inq_grp_full_ncid(ncid, "Hydrophilic/Monochromatic", grpid)
77    call nf95_inq_varid(grpid, "mass_ext", varid)
78    call nf95_gw_var(grpid, varid, ao%mass_ext_mono_philic)
79
80    ! Hydrophobic/LW_bands:
81    call nf95_inq_grp_full_ncid(ncid, "Hydrophobic/LW_bands", grpid)
82    call nf95_inq_varid(grpid, "asymmetry", varid)
83    call nf95_gw_var(grpid, varid, ao%g_lw_phobic)
84    call nf95_inq_varid(grpid, "single_scat_alb", varid)
85    call nf95_gw_var(grpid, varid, ao%ssa_lw_phobic)
86    call nf95_inq_varid(grpid, "mass_ext", varid)
87    call nf95_gw_var(grpid, varid, ao%mass_ext_lw_phobic)
88
89    ! Hydrophobic/SW_bands:
90    call nf95_inq_grp_full_ncid(ncid, "Hydrophobic/SW_bands", grpid)
91    call nf95_inq_varid(grpid, "asymmetry", varid)
92    call nf95_gw_var(grpid, varid, ao%g_sw_phobic)
93    ao%g_sw_phobic = cshift(ao%g_sw_phobic, 1)
94    call nf95_inq_varid(grpid, "single_scat_alb", varid)
95    call nf95_gw_var(grpid, varid, ao%ssa_sw_phobic)
96    ao%g_sw_phobic = cshift(ao%ssa_sw_phobic, 1)
97    call nf95_inq_varid(grpid, "mass_ext", varid)
98    call nf95_gw_var(grpid, varid, ao%mass_ext_sw_phobic)
99    ao%g_sw_phobic = cshift(ao%mass_ext_sw_phobic, 1)
100
101    ! Hydrophobic/Monochromatic:
102    call nf95_inq_grp_full_ncid(ncid, "Hydrophobic/Monochromatic", grpid)
103    call nf95_inq_varid(grpid, "mass_ext", varid)
104    call nf95_gw_var(grpid, varid, ao%mass_ext_mono_phobic)
105
106    call nf95_close(ncid)
107
108    ! Get array sizes
109    ao%n_bands_lw = size(ao%mass_ext_lw_phobic, 1)
110    ao%n_bands_sw = size(ao%mass_ext_sw_phobic, 1)
111    ao%n_mono_wl = size(ao%mass_ext_mono_phobic, 1)
112    ao%n_type_phobic = size(ao%mass_ext_lw_phobic, 2)
113    ao%n_type_philic = size(ao%mass_ext_lw_philic, 3)
114
115    ! Allocate memory for mapping arrays
116    ao%ntype = ao%n_type_phobic + ao%n_type_philic
117    allocate(ao%iclass(ao%ntype))
118    allocate(ao%itype(ao%ntype))
119
120    ao%iclass = IAerosolClassUndefined
121    ao%itype  = 0
122
123  end subroutine setup_aerosol_optics_lmdz
124
125end module setup_aerosol_optics_lmdz_m
Note: See TracBrowser for help on using the repository browser.