00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #ifndef HDF5DATAREADER_HPP_
00029 #define HDF5DATAREADER_HPP_
00030
00031 #include <hdf5.h>
00032 #include <cassert>
00033 #include <vector>
00034 #include <map>
00035 #include <petscvec.h>
00036 #include <iostream>
00037 #include "Exception.hpp"
00038 #include "OutputFileHandler.hpp"
00039
00040 class Hdf5DataReader
00041 {
00042 private:
00043
00044 const static unsigned MAX_DATASET_RANK=3;
00045
00046 std::string mDirectory;
00047 std::string mBaseName;
00049 hid_t mFileId;
00050
00051 hid_t mVariablesDatasetId;
00052 unsigned mVariablesDatasetRank;
00053 hsize_t mVariablesDatasetSizes[MAX_DATASET_RANK];
00054
00055 bool mIsUnlimitedDimensionSet;
00056 hid_t mTimeDatasetId;
00057 hsize_t mNumberTimesteps;
00058
00059 std::map<std::string, unsigned> mVariableToColumnIndex;
00060 std::vector<std::string> mVariableNames;
00061
00062 std::map<std::string, std::string> mVariableToUnit;
00063
00064 bool mIsDataComplete;
00065 std::vector<unsigned> mIncompleteNodeIndices;
00066
00067 public:
00068
00069 Hdf5DataReader(std::string directory, std::string baseName, bool make_absolute=true);
00070
00071 std::vector<double> GetVariableOverTime(std::string variableName, unsigned nodeIndex);
00072
00073 void GetVariableOverNodes(Vec data, std::string variableName, unsigned timestep=0);
00074
00075 std::vector<double> GetUnlimitedDimensionValues();
00076
00077 unsigned GetNumberOfRows()
00078 {
00079 return mVariablesDatasetSizes[1];
00080 }
00081
00082 std::vector<std::string> GetVariableNames()
00083 {
00084 return mVariableNames;
00085 }
00086 std::string GetUnit(std::string variableName)
00087 {
00088 return mVariableToUnit[variableName];
00089 }
00090
00091 bool IsDataComplete()
00092 {
00093 return mIsDataComplete;
00094 }
00095
00096 std::vector<unsigned> GetIncompleteNodeMap()
00097 {
00098 return mIncompleteNodeIndices;
00099 }
00100
00101 void Close();
00102
00103 };
00104
00105 #endif