tools/DistribInterp.hpp
Go to the documentation of this file.
00001 /*
00002   This file is part of OpenFLUID software
00003   Copyright (c) 2007-2010 INRA-Montpellier SupAgro
00004 
00005 
00006  == GNU General Public License Usage ==
00007 
00008   OpenFLUID is free software: you can redistribute it and/or modify
00009   it under the terms of the GNU General Public License as published by
00010   the Free Software Foundation, either version 3 of the License, or
00011   (at your option) any later version.
00012 
00013   OpenFLUID is distributed in the hope that it will be useful,
00014   but WITHOUT ANY WARRANTY; without even the implied warranty of
00015   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00016   GNU General Public License for more details.
00017 
00018   You should have received a copy of the GNU General Public License
00019   along with OpenFLUID.  If not, see <http://www.gnu.org/licenses/>.
00020 
00021   In addition, as a special exception, INRA gives You the additional right
00022   to dynamically link the code of OpenFLUID with code not covered
00023   under the GNU General Public License ("Non-GPL Code") and to distribute
00024   linked combinations including the two, subject to the limitations in this
00025   paragraph. Non-GPL Code permitted under this exception must only link to
00026   the code of OpenFLUID dynamically through the OpenFLUID libraries
00027   interfaces, and only for building OpenFLUID plugins. The files of
00028   Non-GPL Code may be link to the OpenFLUID libraries without causing the
00029   resulting work to be covered by the GNU General Public License. You must
00030   obey the GNU General Public License in all respects for all of the
00031   OpenFLUID code and other code used in conjunction with OpenFLUID
00032   except the Non-GPL Code covered by this exception. If you modify
00033   this OpenFLUID, you may extend this exception to your version of the file,
00034   but you are not obligated to do so. If you do not wish to provide this
00035   exception without modification, you must delete this exception statement
00036   from your version and license this OpenFLUID solely under the GPL without
00037   exception.
00038 
00039 
00040  == Other Usage ==
00041 
00042   Other Usage means a use of OpenFLUID that is inconsistent with the GPL
00043   license, and requires a written agreement between You and INRA.
00044   Licensees for Other Usage of OpenFLUID may use this file in accordance
00045   with the terms contained in the written agreement between You and INRA.
00046 */
00047 
00048 
00056 #ifndef __DISTRIBINTERP_HPP__
00057 #define __DISTRIBINTERP_HPP__
00058 
00059 #include <map>
00060 #include <openfluid/dllexport.hpp>
00061 #include <openfluid/core/DateTime.hpp>
00062 
00063 namespace openfluid {
00064 namespace core {
00065 class DoubleValue;
00066 }
00067 }
00068 
00069 namespace openfluid { namespace tools {
00070 
00071 class DateTimeSerie;
00072 class IndexedSerie;
00073 
00074 typedef std::map<int,DateTimeSerie*> DTSeriesMap;
00075 typedef std::map<int,DateTimeSerie*> UnitsDTSeriesMap;
00076 typedef std::map<int,IndexedSerie*> IndexedSeriesMap;
00077 typedef std::map<int,IndexedSerie*> UnitsIndexedSeriesMap;
00078 
00079 
00080 
00081 enum SeriePreprocess
00082 {
00083   SERIEPREPCS_NONE,
00084   SERIEPREPCS_CUMULATE
00085 };
00086 
00090 class DLLEXPORT DistributeInterpolate
00091 {
00092 
00093   private:
00094 
00095     DTSeriesMap m_InterpData;
00096     IndexedSeriesMap m_InterpIndexedData;
00097     UnitsDTSeriesMap m_UnitsData;
00098     UnitsIndexedSeriesMap m_UnitsIndexedData;
00099 
00100 
00101     std::string m_DataSourcesFilename;
00102     std::string m_DataDir;
00103     std::string m_DistributionFilename;
00104     SeriePreprocess m_SPpcs;
00105     openfluid::core::DateTime m_Begin;
00106     openfluid::core::DateTime m_End;
00107     int m_TimeStep;
00108 
00109     bool m_Configured;
00110 
00111     bool loadDataAsSerie(std::string FilePath, SeriePreprocess SPpcs, DateTimeSerie *Serie);
00112 
00113     bool loadDistributionAndDistribute(std::string FilePath);
00114 
00115   public:
00116     DistributeInterpolate();
00117 
00118     void setConfig(std::string DataDir, std::string DataSourcesFilename, std::string DistributionFilename, SeriePreprocess SPpcs,
00119                    openfluid::core::DateTime Begin,openfluid::core::DateTime End, int TimeStep);
00120 
00121     bool loadAndPrepareData();
00122 
00123     bool getValue(int ID, openfluid::core::DateTime DT, openfluid::core::DoubleValue *Value);
00124 
00125     bool getValue(int ID, int Index, openfluid::core::DoubleValue *Value);
00126 
00127     virtual ~DistributeInterpolate();
00128 };
00129 
00130 } }
00131 
00132 
00133 #endif /*__DISTRIBINTERP_H__*/
00134 

Generated using Doxygen 1.7.6.1
Creative Commons License Creative Commons By-NC-ND license