TECA
teca_vertical_coordinate_transform.h
1 #ifndef teca_vertical_coordinate_transform_h
2 #define teca_vertical_coordinate_transform_h
3 
4 #include "teca_shared_object.h"
5 #include "teca_algorithm.h"
6 #include "teca_metadata.h"
7 
8 #include <string>
9 #include <vector>
10 
11 TECA_SHARED_OBJECT_FORWARD_DECL(teca_vertical_coordinate_transform)
12 
13 
18 {
19 public:
20  TECA_ALGORITHM_STATIC_NEW(teca_vertical_coordinate_transform)
21  TECA_ALGORITHM_DELETE_COPY_ASSIGN(teca_vertical_coordinate_transform)
22  TECA_ALGORITHM_CLASS_NAME(teca_vertical_coordinate_transform)
24 
25  // report/initialize to/from Boost program options
26  // objects.
27  TECA_GET_ALGORITHM_PROPERTIES_DESCRIPTION()
28  TECA_SET_ALGORITHM_PROPERTIES()
29 
30 
31  // set the transform mode.
32  enum {
33  mode_invalid = 0,
34  mode_wrf_v3 = 1
35  };
36  TECA_ALGORITHM_PROPERTY(int, mode)
37 
38 protected:
40 
41 private:
42  teca_metadata get_output_metadata(unsigned int port,
43  const std::vector<teca_metadata> &input_md) override;
44 
45  std::vector<teca_metadata> get_upstream_request(
46  unsigned int port, const std::vector<teca_metadata> &input_md,
47  const teca_metadata &request) override;
48 
49  const_p_teca_dataset execute(unsigned int port,
50  const std::vector<const_p_teca_dataset> &input_data,
51  const teca_metadata &request) override;
52 
53 private:
54  int mode;
55 };
56 
57 #endif
teca_metadata
Definition: teca_metadata.h:17
teca_vertical_coordinate_transform
an algorithm that transforms vertical cooridinates
Definition: teca_vertical_coordinate_transform.h:18
teca_algorithm
Definition: teca_algorithm.h:25