13 use fckit_configuration_module,
only: fckit_configuration
21 #define LISTED_TYPE ufo_atmvertinterplay
24 #include "oops/util/linkedList_i.f"
35 #include "oops/util/linkedList_c.f"
40 use oops_variables_mod
42 integer(c_int),
intent(inout) :: c_key_self
43 type(c_ptr),
value,
intent(in) :: c_conf
44 type(c_ptr),
value,
intent(in) :: c_obsvars
45 type(c_ptr),
value,
intent(in) :: c_geovars
48 type(fckit_configuration) :: f_conf
52 f_conf = fckit_configuration(c_conf)
54 self%obsvars = oops_variables(c_obsvars)
55 self%geovars = oops_variables(c_geovars)
57 call self%setup(f_conf)
65 integer(c_int),
intent(inout) :: c_key_self
76 c_hofx) bind(c,name='ufo_atmvertinterplay_simobs_f90')
79 integer(c_int),
intent(in) :: c_key_self
80 integer(c_int),
intent(in) :: c_key_geovals
81 type(c_ptr),
value,
intent(in) :: c_obsspace
82 integer(c_int),
intent(in) :: c_nvars, c_nlocs
83 real(c_double),
intent(inout) :: c_hofx(c_nvars, c_nlocs)
87 character(len=*),
parameter :: myname_=
"ufo_atmvertinterplay_simobs_c"
91 call self%simobs(geovals, c_obsspace, c_nvars, c_nlocs, c_hofx)
Fortran atmvertinterplay module for functions on the interface between C++ and Fortran.
type(registry_t) ufo_atmvertinterplay_registry
Linked list interface - defines registry_t type.
subroutine ufo_atmvertinterplay_simobs_c(c_key_self, c_key_geovals, c_obsspace, c_nvars, c_nlocs, c_hofx)
subroutine ufo_atmvertinterplay_setup_c(c_key_self, c_conf, c_obsvars, c_geovars)
Linked list implementation.
subroutine ufo_atmvertinterplay_delete_c(c_key_self)
Fortran module for atmvertinterplay observation operator.
type(registry_t), public ufo_geovals_registry
Linked list interface - defines registry_t type.
Fortran derived type for the observation type.
type to hold interpolated fields required by the obs operators