11 use atlas_module,
only: atlas_fieldset
13 use fckit_configuration_module,
only: fckit_configuration
29 subroutine qg_fields_create_c(c_key_self,c_key_geom,c_vars,c_lbc) bind(c,name='qg_fields_create_f90')
34 integer(c_int),
intent(inout) :: c_key_self
35 integer(c_int),
intent(in) :: c_key_geom
36 type(c_ptr),
value,
intent(in) :: c_vars
37 logical(c_bool),
intent(in) :: c_lbc
64 integer(c_int),
intent(inout) :: c_key_self
65 integer(c_int),
intent(in) :: c_key_other
66 integer(c_int),
intent(in) :: c_key_geom
91 integer(c_int),
intent(inout) :: c_key_self
113 integer(c_int),
intent(in) :: c_key_self
132 integer(c_int),
intent(in) :: c_key_self
151 integer(c_int),
intent(in) :: c_key_self
152 type(c_ptr),
value,
intent(in) :: c_conf
155 type(fckit_configuration) :: f_conf
159 f_conf = fckit_configuration(c_conf)
173 integer(c_int),
intent(in) :: c_key_self
174 type(c_ptr),
value,
intent(in) :: c_vars
185 if (vars%has(
'x'))
then
187 elseif (vars%has(
'q'))
then
190 call abor1_ftn(
'qg_fields_random_c: x or q required in output field')
201 integer(c_int),
intent(in) :: c_key_self
202 integer(c_int),
intent(in) :: c_key_other
223 integer(c_int),
intent(in) :: c_key_self
224 integer(c_int),
intent(in) :: c_key_rhs
245 integer(c_int),
intent(in) :: c_key_self
246 integer(c_int),
intent(in) :: c_key_rhs
267 integer(c_int),
intent(in) :: c_key_self
268 real(c_double),
intent(in) :: c_zz
287 integer(c_int),
intent(in) :: c_key_self
288 real(c_double),
intent(in) :: c_zz
289 integer(c_int),
intent(in) :: c_key_rhs
310 integer(c_int),
intent(in) :: c_key_self
311 integer(c_int),
intent(in) :: c_key_rhs
332 integer(c_int),
intent(in) :: c_key_fld1
333 integer(c_int),
intent(in) :: c_key_fld2
334 real(c_double),
intent(inout) :: c_prod
354 integer(c_int),
intent(in) :: c_key_self
355 integer(c_int),
intent(in) :: c_key_rhs
376 integer(c_int),
intent(in) :: c_key_lhs
377 integer(c_int),
intent(in) :: c_key_fld1
378 integer(c_int),
intent(in) :: c_key_fld2
401 integer(c_int),
intent(in) :: c_key_fld
402 integer(c_int),
intent(in) :: c_key_rhs
422 integer(c_int),
intent(in) :: c_key_fld
423 type(c_ptr),
value,
intent(in) :: c_conf
424 type(c_ptr),
value,
intent(in) :: c_dt
427 type(fckit_configuration) :: f_conf
429 type(datetime) :: fdate
432 f_conf = fckit_configuration(c_conf)
434 call c_f_datetime(c_dt,fdate)
447 integer(c_int),
intent(in) :: c_key_fld
448 type(c_ptr),
value,
intent(in) :: c_conf
449 type(c_ptr),
value,
intent(in) :: c_dt
452 type(fckit_configuration) :: f_conf
454 type(datetime) :: fdate
457 f_conf = fckit_configuration(c_conf)
459 call c_f_datetime(c_dt,fdate)
472 integer(c_int),
intent(in) :: c_key_fld
473 type(c_ptr),
value,
intent(in) :: c_conf
474 type(c_ptr),
value,
intent(in) :: c_dt
477 type(fckit_configuration) :: f_conf
479 type(datetime) :: fdate
482 f_conf = fckit_configuration(c_conf)
484 call c_f_datetime(c_dt,fdate)
497 integer(c_int),
intent(in) :: c_key_fld
498 integer(c_int),
intent(inout) :: vpresent(6)
499 real(c_double),
intent(inout) :: vmin(6)
500 real(c_double),
intent(inout) :: vmax(6)
501 real(c_double),
intent(inout) :: vrms(6)
520 integer(c_int),
intent(in) :: c_key_fld
521 real(c_double),
intent(inout) :: prms
540 integer(c_int),
intent(in) :: c_key_fld
541 integer(c_int),
intent(inout) :: c_nx
542 integer(c_int),
intent(inout) :: c_ny
543 integer(c_int),
intent(inout) :: c_nz
562 integer(c_int),
intent(in) :: c_key_fld
563 integer(c_int),
intent(inout) :: c_lbc
582 integer(c_int),
intent(in) :: c_key_fld
583 type(c_ptr),
value,
intent(in) :: c_vars
584 type(c_ptr),
intent(in),
value :: c_afieldset
589 type(atlas_fieldset) :: afieldset
594 afieldset = atlas_fieldset(c_afieldset)
607 integer(c_int),
intent(in) :: c_key_fld
608 type(c_ptr),
value,
intent(in) :: c_vars
609 type(c_ptr),
intent(in),
value :: c_afieldset
614 type(atlas_fieldset) :: afieldset
619 afieldset = atlas_fieldset(c_afieldset)
632 integer(c_int),
intent(in) :: c_key_fld
633 type(c_ptr),
value,
intent(in) :: c_vars
634 type(c_ptr),
intent(in),
value :: c_afieldset
639 type(atlas_fieldset) :: afieldset
644 afieldset = atlas_fieldset(c_afieldset)
657 integer(c_int),
intent(in) :: c_key_fld
658 integer(c_int),
intent(in) :: c_key_iter
659 integer(c_int),
intent(in) :: c_nval
660 real(c_double),
intent(inout) :: c_vals(c_nval)
681 integer(c_int),
intent(in) :: c_key_fld
682 integer(c_int),
intent(in) :: c_key_iter
683 integer(c_int),
intent(in) :: c_nval
684 real(c_double),
intent(in) :: c_vals(c_nval)
705 integer(c_int),
intent(in) :: c_key_fld
706 integer(c_int),
intent(in) :: c_vsize
707 real(c_double),
intent(out) :: c_vect_fld(c_vsize)
726 integer(c_int),
intent(in) :: c_key_self
727 integer(c_int),
intent(in) :: c_vsize
728 real(c_double),
intent(in) :: c_vect_fld(c_vsize)
729 integer(c_int),
intent(inout):: c_index
Fortran interface to Variables.
subroutine qg_fields_copy_c(c_key_self, c_key_other)
Copy fields.
subroutine qg_fields_from_atlas_c(c_key_fld, c_vars, c_afieldset)
Get fields from ATLAS.
subroutine qg_fields_create_c(c_key_self, c_key_geom, c_vars, c_lbc)
Create fields from geometry and variables.
subroutine qg_fields_dirac_c(c_key_self, c_conf)
Set fields to Diracs.
subroutine qg_fields_delete_c(c_key_self)
Delete fields.
subroutine qg_fields_analytic_init_c(c_key_fld, c_conf, c_dt)
Analytic initialization of fields.
subroutine qg_fields_self_add_c(c_key_self, c_key_rhs)
Add fields.
subroutine qg_fields_self_schur_c(c_key_self, c_key_rhs)
Schur product of fields.
subroutine qg_fields_write_file_c(c_key_fld, c_conf, c_dt)
Write fields to file.
subroutine qg_fields_create_from_other_c(c_key_self, c_key_other, c_key_geom)
Create fields from another one.
subroutine qg_fields_lbc_c(c_key_fld, c_lbc)
Get fields geometry.
subroutine qg_fields_read_file_c(c_key_fld, c_conf, c_dt)
Read fields from file.
subroutine qg_fields_axpy_c(c_key_self, c_zz, c_key_rhs)
Apply axpy operator to fields.
subroutine qg_fields_getpoint_c(c_key_fld, c_key_iter, c_nval, c_vals)
Get points from fields.
subroutine qg_fields_serialize_c(c_key_fld, c_vsize, c_vect_fld)
Serialize fields.
subroutine qg_fields_rms_c(c_key_fld, prms)
Fields RMS.
subroutine qg_fields_gpnorm_c(c_key_fld, vpresent, vmin, vmax, vrms)
Fields statistics.
subroutine qg_fields_to_atlas_c(c_key_fld, c_vars, c_afieldset)
Convert fields to ATLAS.
subroutine qg_fields_change_resol_c(c_key_fld, c_key_rhs)
Change fields resolution.
subroutine qg_fields_setpoint_c(c_key_fld, c_key_iter, c_nval, c_vals)
Set points for the fields.
subroutine qg_fields_diff_incr_c(c_key_lhs, c_key_fld1, c_key_fld2)
Compute increment from the difference of two fields.
subroutine qg_fields_self_mul_c(c_key_self, c_zz)
Multiply fields by a scalar.
subroutine qg_fields_add_incr_c(c_key_self, c_key_rhs)
Add increment to fields.
subroutine qg_fields_ones_c(c_key_self)
Set fields to ones.
subroutine qg_fields_dot_prod_c(c_key_fld1, c_key_fld2, c_prod)
Compute dot product for fields.
subroutine qg_fields_self_sub_c(c_key_self, c_key_rhs)
Subtract fields.
subroutine qg_fields_sizes_c(c_key_fld, c_nx, c_ny, c_nz)
Get fields geometry.
subroutine qg_fields_set_atlas_c(c_key_fld, c_vars, c_afieldset)
Create ATLAS fields.
subroutine qg_fields_zero_c(c_key_self)
Set fields to zero.
subroutine qg_fields_random_c(c_key_self, c_vars)
Generate random fields.
subroutine qg_fields_deserialize_c(c_key_self, c_vsize, c_vect_fld, c_index)
Deserialize fields.
subroutine, public qg_fields_set_atlas(self, vars, afieldset)
Set ATLAS field.
subroutine, public qg_fields_deserialize(self, vsize, vect_fld, index)
Deserialize fields.
subroutine, public qg_fields_zero(self)
Set fields to zero.
subroutine, public qg_fields_axpy(self, zz, rhs)
Apply axpy operator to fields.
subroutine, public qg_fields_to_atlas(self, vars, afieldset)
Convert fields to ATLAS.
subroutine, public qg_fields_delete(self)
Delete fields.
subroutine, public qg_fields_dirac(self, f_conf)
Set fields to Diracs.
subroutine, public qg_fields_getpoint(fld, iter, nval, vals)
Get points from fields.
subroutine, public qg_fields_gpnorm(fld, vpresent, vmin, vmax, vrms)
Fields statistics.
subroutine, public qg_fields_rms(fld, prms)
Fields RMS.
subroutine, public qg_fields_self_schur(self, rhs)
Schur product of fields.
subroutine, public qg_fields_self_mul(self, zz)
Multiply fields by a scalar.
type(registry_t), public qg_fields_registry
Linked list interface - defines registry_t type.
subroutine, public qg_fields_create(self, geom, vars, lbc)
Linked list implementation.
subroutine, public qg_fields_from_atlas(self, vars, afieldset)
Get fields from ATLAS.
subroutine, public qg_fields_analytic_init(fld, f_conf, vdate)
Analytic initialization of fields.
subroutine, public qg_fields_self_sub(self, rhs)
Subtract fields.
subroutine, public qg_fields_copy(self, other)
Copy fields.
subroutine, public qg_fields_dot_prod(fld1, fld2, zprod)
Compute dot product for fields.
subroutine, public qg_fields_write_file(fld, f_conf, vdate)
Write fields to file.
subroutine, public qg_fields_add_incr(self, rhs)
Add increment to fields.
subroutine, public qg_fields_self_add(self, rhs)
Add fields.
subroutine, public qg_fields_serialize(fld, vsize, vect_fld)
Serialize fields.
subroutine, public qg_fields_read_file(fld, f_conf, vdate)
Read fields from file.
subroutine, public qg_fields_sizes(fld, nx, ny, nz)
Get fields geometry.
subroutine, public qg_fields_setpoint(fld, iter, nval, vals)
Set fields values at a specified gridpoint.
subroutine, public qg_fields_lbc(fld, lbc)
Get LBC presence.
subroutine, public qg_fields_random(self, var)
Generate random fields.
subroutine, public qg_fields_ones(self)
Set fields to ones.
subroutine, public qg_fields_diff_incr(lhs, fld1, fld2)
Compute increment from the difference of two fields.
subroutine, public qg_fields_create_from_other(self, other, geom)
Create fields from another one.
subroutine, public qg_fields_change_resol(fld, rhs)
Change fields resolution.
type(registry_t), public qg_geom_iter_registry
Linked list interface - defines registry_t type.
type(registry_t), public qg_geom_registry
Linked list interface - defines registry_t type.