7 use fruit
, only : assert_false
17 integer,
allocatable,
dimension(:) :: data
62 integer function nf90_open(path, mode, ncid)
63 character(len=*),
intent(in) :: path
64 integer,
intent(in) :: mode
65 integer,
intent(out) :: ncid
73 integer function nf90_create(path, mode, ncid, comm, info)
74 character(len=*),
intent(in) :: path
75 integer,
intent(in) :: mode
76 integer,
intent(in),
optional :: comm, info
77 integer,
intent(out) :: ncid
85 integer function nf90_put_att(ncid, attribute, key, value)
86 integer,
intent(in) :: ncid, attribute
87 character(len=*),
intent(in) :: key, value
88 class(*),
pointer :: raw_data
101 integer,
intent(in) :: ncid
109 integer,
intent(in) :: ncid
116 integer,
intent(in) :: ncid, attributeid
117 character(len=*),
intent(in) :: key
118 integer,
intent(out) :: len
125 integer function nf90_get_att(ncid, attributeid, key, value)
126 integer,
intent(in) :: ncid, attributeid
127 character(len=*),
intent(in) :: key
128 character(len=100),
intent(out) :: value
130 class(*),
pointer :: raw_data
141 character(len=*),
intent(in) :: key
142 integer,
intent(in) :: ncid
143 integer,
intent(out) :: varid
145 class(*),
pointer :: raw_data
149 if (
associated(raw_data))
then 161 integer function nf90_get_var_char(ncid, varid, target, indexes, start, count, map)
162 integer,
intent(in) :: ncid, varid
163 character(len=100),
intent(out) :: target
164 integer,
dimension(:),
optional,
intent(in) :: indexes, start, count, map
171 integer,
intent(in) :: ncid, varid
172 integer,
dimension(*),
intent(out) :: target
173 integer,
dimension(:),
optional,
intent(in) :: indexes, start, count, map
175 class(*),
pointer :: raw_data
183 integer function nf90_get_var_real(ncid, varid, target, indexes, start, count, map)
184 integer,
intent(in) :: ncid, varid
185 real(kind=SINGLE_PRECISION),
dimension(*),
intent(out) :: target
186 integer,
dimension(:),
optional,
intent(in) :: indexes, start, count, map
193 integer,
intent(in) :: ncid, varid
194 real(kind=SINGLE_PRECISION),
intent(out) :: target
195 integer,
dimension(:),
optional,
intent(in) :: indexes, start, count, map
202 integer,
intent(in) :: ncid, varid
203 real(kind=SINGLE_PRECISION),
dimension(:,:,:),
intent(out) :: target
204 integer,
dimension(:),
optional,
intent(in) :: indexes, start, count, map
211 integer,
intent(in) :: ncid, varid
212 real(kind=DOUBLE_PRECISION),
dimension(*),
intent(out) :: target
213 integer,
dimension(:),
optional,
intent(in) :: indexes, start, count, map
220 integer,
intent(in) :: ncid, varid
221 real(kind=DOUBLE_PRECISION),
intent(out) :: target
222 integer,
dimension(:),
optional,
intent(in) :: indexes, start, count, map
229 integer,
intent(in) :: ncid, varid
230 real(kind=DOUBLE_PRECISION),
dimension(:,:,:),
intent(out) :: target
231 integer,
dimension(:),
optional,
intent(in) :: indexes, start, count, map
237 integer function nf90_put_var_char(ncid, varid, source, indexes, start, count, map)
238 integer,
intent(in) :: ncid, varid
239 character(len=*),
intent(in) :: source
240 integer,
dimension(:),
optional ,
intent(in) :: indexes, start, count, map
242 class(*),
pointer :: raw_data
244 call assert_false(
define_mode,
"Switched from define mode")
253 integer,
intent(in) :: ncid, varid
254 integer,
intent(in) :: source
255 integer,
dimension(:),
optional ,
intent(in) :: indexes, start, count, map
257 class(*),
pointer :: raw_data
259 call assert_false(
define_mode,
"Switched from define mode")
266 integer function nf90_put_var_real(ncid, varid, source, indexes, start, count, map)
267 integer,
intent(in) :: ncid, varid
268 real(kind=SINGLE_PRECISION),
dimension(*),
intent(in) :: source
269 integer,
dimension(:),
optional ,
intent(in) :: indexes, start, count, map
271 call assert_false(
define_mode,
"Switched from define mode")
277 integer,
intent(in) :: ncid, varid
278 real(kind=SINGLE_PRECISION),
intent(in) :: source
279 integer,
dimension(:),
optional ,
intent(in) :: indexes, start, count, map
281 call assert_false(
define_mode,
"Switched from define mode")
287 integer,
intent(in) :: ncid, varid
288 real(kind=SINGLE_PRECISION),
dimension(:,:,:),
intent(in) :: source
289 integer,
dimension(:),
optional ,
intent(in) :: indexes, start, count, map
291 call assert_false(
define_mode,
"Switched from define mode")
297 integer,
intent(in) :: ncid, varid
298 real(kind=DOUBLE_PRECISION),
dimension(*),
intent(in) :: source
299 integer,
dimension(:),
optional ,
intent(in) :: indexes, start, count, map
301 call assert_false(
define_mode,
"Switched from define mode")
307 integer,
intent(in) :: ncid, varid
308 real(kind=DOUBLE_PRECISION),
intent(in) :: source
309 integer,
dimension(:),
optional ,
intent(in) :: indexes, start, count, map
311 call assert_false(
define_mode,
"Switched from define mode")
317 integer,
intent(in) :: ncid, varid
318 real(kind=DOUBLE_PRECISION),
dimension(:,:,:),
intent(in) :: source
319 integer,
dimension(:),
optional ,
intent(in) :: indexes, start, count, map
321 call assert_false(
define_mode,
"Switched from define mode")
327 integer,
intent(in) :: ncid
328 character(len=*),
intent(in) :: key
329 integer,
intent(out) :: dim_id
331 class(*),
pointer :: raw_data
344 integer,
intent(in) :: ncid, id
345 integer,
intent(out) :: len
347 class(*),
pointer :: raw_data
360 integer,
intent(in) :: status
366 integer function nf90_def_dim(ncid, key, length, dimension_id)
367 integer,
intent(in) :: ncid, length
368 character(len=*),
intent(in) :: key
369 integer,
intent(out) :: dimension_id
371 class(*),
pointer :: raw_data
382 integer,
intent(in) :: ncid,
type, dim_id
383 character(len=*),
intent(in) :: key
384 integer,
intent(out) :: varid
386 class(*),
pointer :: raw_data
399 integer,
intent(in) :: ncid, type
400 character(len=*),
intent(in) :: key
401 integer,
intent(out) :: varid
403 class(*),
pointer :: raw_data
416 integer,
intent(in) :: ncid, type
417 integer,
dimension(:) :: dim_ids
418 character(len=*),
intent(in) :: key
419 integer,
intent(out) :: varid
423 class(*),
pointer :: raw_data, raw_id_data
426 wrapper%size=
size(dim_ids)
427 allocate(wrapper%data(wrapper%size))
430 wrapper%data(i) = dim_ids(i)
integer function nf90_get_var_real_scalar(ncid, varid, target, indexes, start, count, map)
integer, parameter dummy_error
integer function nf90_inquire_attribute(ncid, attributeid, key, len)
integer, parameter nf90_int
integer function nf90_put_var_real_scalar(ncid, varid, source, indexes, start, count, map)
integer function nf90_get_att(ncid, attributeid, key, value)
integer, parameter nf90_noerr
integer, parameter nf90_double
integer function nf90_get_var_double_scalar(ncid, varid, target, indexes, start, count, map)
type(map_type), save variable_ids
integer, parameter nf90_real
integer function nf90_put_var_real_3d(ncid, varid, source, indexes, start, count, map)
integer function nf90_get_var_real3d(ncid, varid, target, indexes, start, count, map)
integer function nf90_put_var_double_scalar(ncid, varid, source, indexes, start, count, map)
type(map_type), save dimension_lengths
integer function nf90_put_var_integer(ncid, varid, source, indexes, start, count, map)
integer function nf90_inq_dimid(ncid, key, dim_id)
integer, parameter nf90_global
integer function nf90_def_var_single(ncid, key, type, dim_id, varid)
Converts a data type into the generic (class *) form.
Contains common definitions for the data and datatypes used by MONC.
integer, parameter nf90_enotatt
integer, parameter nf90_nowrite
Conversion between common inbuilt FORTRAN data types.
integer function nf90_inq_varid(ncid, key, varid)
Converts data types to strings.
integer, parameter, public single_precision
Single precision (32 bit) kind.
integer function nf90_enddef(ncid)
integer function nf90_get_var_integer(ncid, varid, target, indexes, start, count, map)
integer, parameter, public double_precision
Double precision (64 bit) kind.
integer function nf90_get_var_double3d(ncid, varid, target, indexes, start, count, map)
Map data structure that holds string (length 20 maximum) key value pairs.
integer, parameter nf90_clobber
integer function nf90_put_att(ncid, attribute, key, value)
integer function nf90_put_var_double(ncid, varid, source, indexes, start, count, map)
integer function nf90_def_var_multiple(ncid, key, type, dim_ids, varid)
integer function nf90_def_var_atomic(ncid, key, type, varid)
Collection data structures.
integer function nf90_create(path, mode, ncid, comm, info)
type(map_type), save global_attributes
integer function nf90_close(ncid)
integer, parameter nf90_enotvar
type(map_type), save dimension_ids
integer function nf90_def_dim(ncid, key, length, dimension_id)
subroutine dummy_netcdf_reset()
integer function nf90_get_var_real(ncid, varid, target, indexes, start, count, map)
integer function nf90_put_var_real(ncid, varid, source, indexes, start, count, map)
integer, parameter nf90_netcdf4
Frees up all the allocatable, heap, memory associated with a list, stack, queue or map...
integer function nf90_get_var_double(ncid, varid, target, indexes, start, count, map)
character(len=10) function nf90_strerror(status)
integer, parameter nf90_mpiio
type(map_type), save variable_data
Converts data types to integers.
integer function nf90_get_var_char(ncid, varid, target, indexes, start, count, map)
Determines whether or not a map contains a specific key.
integer function nf90_put_var_char(ncid, varid, source, indexes, start, count, map)
integer, parameter nf90_char
integer, parameter nf90_ebaddim
type(map_type), save var_data
integer function nf90_open(path, mode, ncid)
integer function nf90_inquire_dimension(ncid, id, len)
integer function nf90_put_var_double_3d(ncid, varid, source, indexes, start, count, map)