MPAS-JEDI
Fortran.h
Go to the documentation of this file.
1 /*
2  * (C) Copyright 2017 UCAR
3  *
4  * This software is licensed under the terms of the Apache Licence Version 2.0
5  * which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
6  */
7 
8 #ifndef MPASJEDI_FORTRAN_H_
9 #define MPASJEDI_FORTRAN_H_
10 
11 #include <atlas/field.h>
12 #include <atlas/functionspace.h>
13 
14 #include "oops/base/Variables.h"
15 
16 // Forward declarations
17 namespace eckit {
18  class Configuration;
19  namespace mpi {
20  class Comm;
21  }
22 }
23 
24 namespace util {
25  class DateTime;
26  class Duration;
27 }
28 
29 namespace mpas {
30 
31 // Geometry key type
32 typedef int F90geom;
33 // Model key type
34 typedef int F90model;
35 // Variables key type
36 typedef int F90vars;
37 // Locations key type
38 typedef int F90locs;
39 // Goms key type
40 typedef int F90goms;
41 // State key type
42 typedef int F90state;
43 // Increment key type
44 typedef int F90inc;
45 // Trajectory key type
46 typedef int F90traj;
47 // Background error covariance key type
48 typedef int F90bmat;
49 // Observation vector key type
50 typedef int F90ovec;
51 // Obs operator key type
52 typedef int F90hop;
53 // Observation data base type
54 typedef int F90odb;
55 // GetValues key
56 typedef int F90getvalues;
57 // LinearGetValues key
58 typedef int F90lineargetvalues;
59 
60 /// Interface to Fortran MPAS model
61 /*!
62  * The core of the MPAS model is coded in Fortran.
63  * Here we define the interfaces to the Fortran code.
64  */
65 
66 extern "C" {
67 // -----------------------------------------------------------------------------
68 // Geometry
69 // -----------------------------------------------------------------------------
71  const eckit::Configuration &,
72  const eckit::mpi::Comm *);
74  atlas::field::FieldSetImpl *);
76  atlas::functionspace::FunctionSpaceImpl *);
78  atlas::field::FieldSetImpl *);
80  void mpas_geo_is_equal_f90(bool &, const F90geom &, const F90geom &);
81  void mpas_geo_vars_nlevels_f90(const F90geom &, const oops::Variables &,
82  const std::size_t &, std::size_t &);
83  void mpas_geo_info_f90(const F90geom &, int &, int &, int &, int &, int &,
84  int &, int &, int &);
86 
87 // -----------------------------------------------------------------------------
88 // Model
89 // -----------------------------------------------------------------------------
90  void mpas_model_setup_f90(const eckit::Configuration &,
91  const F90geom &, F90model &);
93 
97 
98  void mpas_model_propagate_f90(const F90model &, const F90state &);
101  const F90traj &);
103  const F90traj &);
104 
106  void mpas_traj_minmaxrms_f90(const F90traj &, double &);
107 
108 // -----------------------------------------------------------------------------
109 // ErrorCovariance (Background error)
110 // -----------------------------------------------------------------------------
111  void mpas_b_setup_f90(F90bmat &, const eckit::Configuration &,
112  const F90geom &);
114 
116  const eckit::Configuration &);
117 
118  void mpas_b_mult_f90(const F90bmat &, const F90inc &, const F90inc &);
119  void mpas_b_invmult_f90(const F90bmat &, const F90inc &, const F90inc &);
120 
121  void mpas_b_randomize_f90(const F90bmat &, const F90inc &);
122 
123 }
124 // -----------------------------------------------------------------------------
125 
126 } // namespace mpas
127 #endif // MPASJEDI_FORTRAN_H_
Definition: Fortran.h:17
void mpas_b_randomize_f90(const F90bmat &, const F90inc &)
void mpas_model_setup_f90(const eckit::Configuration &, const F90geom &, F90model &)
void mpas_model_delete_f90(F90model &)
int F90traj
Definition: Fortran.h:46
int F90bmat
Definition: Fortran.h:48
void mpas_geo_clone_f90(F90geom &, const F90geom &)
void mpas_model_prepare_integration_f90(const F90model &, const F90state &)
int F90ovec
Definition: Fortran.h:50
void mpas_model_prepare_integration_tl_f90(const F90model &, const F90inc &)
void mpas_model_prop_traj_f90(const F90model &, const F90state &, F90traj &)
void mpas_geo_fill_atlas_fieldset_f90(const F90geom &, atlas::field::FieldSetImpl *)
int F90locs
Definition: Fortran.h:38
void mpas_geo_set_atlas_lonlat_f90(const F90geom &, atlas::field::FieldSetImpl *)
void mpas_model_propagate_f90(const F90model &, const F90state &)
void mpas_b_invmult_f90(const F90bmat &, const F90inc &, const F90inc &)
int F90model
Definition: Fortran.h:34
void mpas_traj_minmaxrms_f90(const F90traj &, double &)
int F90state
Definition: Fortran.h:42
int F90vars
Definition: Fortran.h:36
int F90goms
Definition: Fortran.h:40
void mpas_model_propagate_tl_f90(const F90model &, const F90inc &, const F90traj &)
void mpas_model_propagate_ad_f90(const F90model &, const F90inc &, const F90traj &)
void mpas_geo_is_equal_f90(bool &, const F90geom &, const F90geom &)
int F90hop
Definition: Fortran.h:52
void mpas_geo_vars_nlevels_f90(const F90geom &, const oops::Variables &, const std::size_t &, std::size_t &)
void mpas_geo_setup_f90(F90geom &, const eckit::Configuration &, const eckit::mpi::Comm *)
Interface to Fortran MPAS model.
void mpas_b_linearize_f90(const F90bmat &, const eckit::Configuration &)
int F90lineargetvalues
Definition: Fortran.h:58
void mpas_geo_delete_f90(F90geom &)
void mpas_geo_set_atlas_functionspace_pointer_f90(const F90geom &, atlas::functionspace::FunctionSpaceImpl *)
int F90odb
Definition: Fortran.h:54
int F90getvalues
Definition: Fortran.h:56
void mpas_model_wipe_traj_f90(F90traj &)
void mpas_geo_info_f90(const F90geom &, int &, int &, int &, int &, int &, int &, int &, int &)
void mpas_b_delete_f90(F90bmat &)
int F90geom
Definition: Fortran.h:32
int F90inc
Definition: Fortran.h:44
void mpas_b_mult_f90(const F90bmat &, const F90inc &, const F90inc &)
void mpas_b_setup_f90(F90bmat &, const eckit::Configuration &, const F90geom &)
void mpas_model_prepare_integration_ad_f90(const F90model &, const F90inc &)
Definition: Fortran.h:24