00001 /* 00002 * Fimex, CDMQualityExtractor.h 00003 * 00004 * (C) Copyright 2009, met.no 00005 * 00006 * Project Info: https://wiki.met.no/fimex/start 00007 * 00008 * This library is free software; you can redistribute it and/or modify it 00009 * under the terms of the GNU Lesser General Public License as published by 00010 * the Free Software Foundation; either version 2.1 of the License, or 00011 * (at your option) any later version. 00012 * 00013 * This library is distributed in the hope that it will be useful, but 00014 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 00015 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public 00016 * License for more details. 00017 * 00018 * You should have received a copy of the GNU Lesser General Public 00019 * License along with this library; if not, write to the Free Software 00020 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, 00021 * USA. 00022 * 00023 * Created on: May 25, 2009 00024 * Author: Heiko Klein 00025 */ 00026 00027 #ifndef CDMQUALITYEXTRACTOR_H_ 00028 #define CDMQUALITYEXTRACTOR_H_ 00029 00030 #include "CDMReader.h" 00031 #include <vector> 00032 #include <map> 00033 00034 namespace MetNoFimex 00035 { 00036 00054 class CDMQualityExtractor: public MetNoFimex::CDMReader 00055 { 00056 public: 00065 CDMQualityExtractor(boost::shared_ptr<CDMReader> dataReader, std::string autoConfString="", std::string configFile="") throw(CDMException); 00066 virtual ~CDMQualityExtractor() {}; 00070 virtual boost::shared_ptr<Data> getDataSlice(const std::string& varName, size_t unLimDimPos = 0) throw(CDMException); 00074 const std::map<std::string, std::string> getStatusVariable() const {return statusVariable;} 00078 const std::map<std::string, std::string> getVariableFlags() const {return variableFlags;} 00082 const std::map<std::string, std::vector<double> > getVariableValues() const {return variableValues;} 00083 private: 00084 const boost::shared_ptr<CDMReader> dataReader; 00085 /* map of variableName to the variable which contains the flags */ 00086 std::map<std::string, std::string> statusVariable; 00087 /* 00088 * map of the variableName to the flags, which should be valid in the statusVariable, i.e. highest,lowest,all. 00089 * statusVariable needs to be set! 00090 */ 00091 std::map<std::string, std::string> variableFlags; 00092 /* 00093 * map ofthe variableName to the valid values in the statusVariable. 00094 * statusVariable needs to be set! 00095 */ 00096 std::map<std::string, std::vector<double> > variableValues; 00097 }; 00098 00099 } 00100 00101 #endif /* CDMQUALITYEXTRACTOR_H_ */