bes Updated for version 3.21.1
The Backend Server (BES) is the lower two tiers of the Hyrax data server
HDF5GMCFMissLLArray.h
Go to the documentation of this file.
1// This file is part of the hdf5_handler implementing for the CF-compliant
2// Copyright (c) 2011-2023 The HDF Group, Inc. and OPeNDAP, Inc.
3//
4// This is free software; you can redistribute it and/or modify it under the
5// terms of the GNU Lesser General Public License as published by the Free
6// Software Foundation; either version 2.1 of the License, or (at your
7// option) any later version.
8//
9// This software is distributed in the hope that it will be useful, but
10// WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
11// or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
12// License for more details.
13//
14// You should have received a copy of the GNU Lesser General Public
15// License along with this library; if not, write to the Free Software
16// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17//
18// You can contact OPeNDAP, Inc. at PO Box 112, Saunderstown, RI. 02874-0112.
19// You can contact The HDF Group, Inc. at 410 E University Ave,
20// Suite 200, Champaign, IL 61820
21
31
32#ifndef _HDF5GMCFMissLLARRAY_H
33#define _HDF5GMCFMissLLARRAY_H
34
35// STL includes
36#include <string>
37#include <vector>
38
39// DODS includes
40#include "HDF5CF.h"
41#include "HDF5BaseArray.h"
42
43
44class HDF5GMCFMissLLArray:public HDF5BaseArray {
45 public:
46 HDF5GMCFMissLLArray(int h5_rank, const string & h5_filename, const hid_t h5_fileid, H5DataType h5_dtype, const string &varfullpath, H5GCFProduct h5_product_type, CVType h5_cvartype, const string & n="", libdap::BaseType * v = nullptr):
47 HDF5BaseArray(n,v),
48 rank(h5_rank),
49 filename(h5_filename),
50 fileid(h5_fileid),
51 dtype(h5_dtype),
52 varname(varfullpath),
53 product_type(h5_product_type),
54 cvartype(h5_cvartype)
55 {
56 }
57
58 ~ HDF5GMCFMissLLArray() override = default;
59
60 libdap::BaseType *ptr_duplicate() override;
61 bool read() override;
62
63
64 private:
65 int rank;
66 string filename;
67 hid_t fileid;
68 H5DataType dtype;
69 string varname;
70 H5GCFProduct product_type;
71 CVType cvartype;
72
73 //template<class T>
74 template<typename T>
75 void obtain_ll_attr_value(hid_t file_id, hid_t s_root_id,const std::string& s_attr_name, T& attr_value,std::vector<char> & str_attr_value ) const;
76 void read_data_NOT_from_mem_cache(bool add_cache,void*buf) override;
77 void obtain_aqu_obpg_l3_ll(const int64_t* offset,const int64_t* step,int64_t nelms,bool add_cache, void*buf);
78
79 void obtain_gpm_l3_ll(const int64_t* offset,const int64_t* step,int64_t nelms,bool add_cache, void*buf);
80 void obtain_gpm_l3_new_grid_info(hid_t fileid,vector<char>& grid_info_value1, vector<char>& grid_info_value2) const;
81 void obtain_lat_lon_info(const vector<char>& grid_info_value1,
82 const vector<char>& grid_info_value2,int& latsize,int& lonsize,
83 float& lat_start,float& lon_start,float& lat_res,float& lon_res) const;
84#if 0
85 //void send_gpm_l3_ll_to_dap(const vector<char>& grid_info_value,int* offset,int* step,int nelms,bool add_cache, void*buf);
86#endif
87 void send_gpm_l3_ll_to_dap(const int latsize,const int lonsize,float lat_start,float lon_start,float lat_res, float lon_res,
88 const int64_t* offset, const int64_t* step, const int64_t nelms, const bool add_cache, void*buf);
89};
90
91
92#endif // _HDF5GMCFMissLLARRAY_H
93
A helper class that aims to reduce code redundence for different special CF derived array class For e...
This class specifies the core engineering of mapping HDF5 to DAP by following CF.
STL class.