machine/SimulationProfiler.hpp
Go to the documentation of this file.
00001 /*
00002 
00003   This file is part of OpenFLUID software
00004   Copyright(c) 2007, INRA - Montpellier SupAgro
00005 
00006 
00007  == GNU General Public License Usage ==
00008 
00009   OpenFLUID is free software: you can redistribute it and/or modify
00010   it under the terms of the GNU General Public License as published by
00011   the Free Software Foundation, either version 3 of the License, or
00012   (at your option) any later version.
00013 
00014   OpenFLUID is distributed in the hope that it will be useful,
00015   but WITHOUT ANY WARRANTY; without even the implied warranty of
00016   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00017   GNU General Public License for more details.
00018 
00019   You should have received a copy of the GNU General Public License
00020   along with OpenFLUID. If not, see <http://www.gnu.org/licenses/>.
00021 
00022 
00023  == Other Usage ==
00024 
00025   Other Usage means a use of OpenFLUID that is inconsistent with the GPL
00026   license, and requires a written agreement between You and INRA.
00027   Licensees for Other Usage of OpenFLUID may use this file in accordance
00028   with the terms contained in the written agreement between You and INRA.
00029   
00030 */
00031 
00032 
00033 
00034 /**
00035   \file SimulationProfiler.hpp
00036   \brief Header of ...
00037 
00038   \author Jean-Christophe FABRE <fabrejc@supagro.inra.fr>
00039  */
00040 
00041 
00042 #ifndef __SIMULATIONPROFILER_HPP___
00043 #define __SIMULATIONPROFILER_HPP___
00044 
00045 #include <openfluid/ware/PluggableSimulator.hpp>
00046 #include <openfluid/base/SimulationStatus.hpp>
00047 #include <openfluid/dllexport.hpp>
00048 
00049 #include <boost/date_time/posix_time/posix_time.hpp>
00050 
00051 #include <map>
00052 #include <list>
00053 
00054 
00055 namespace openfluid { namespace machine {
00056 
00057 
00058 // =====================================================================
00059 // =====================================================================
00060 
00061 
00062 
00063 class DLLEXPORT SimulationProfiler
00064 {
00065   public:
00066 
00067     typedef std::list<openfluid::ware::WareID_t> WareIDSequence_t;
00068 
00069   private:
00070 
00071     typedef std::map<openfluid::base::SimulationStatus::SimulationStage,boost::posix_time::time_duration> CumulativeSimulatorProfile_t;
00072 
00073     typedef std::map<openfluid::ware::WareID_t,CumulativeSimulatorProfile_t> CumulativeModelProfile_t;
00074 
00075     typedef std::map<openfluid::ware::WareID_t,boost::posix_time::time_duration> CurrentTimeIndexModelProfile_t;
00076 
00077     typedef WareIDSequence_t CurrentTimeIndexModelSequence_t;
00078 
00079     CumulativeModelProfile_t m_CumulativeModelProfile;
00080 
00081     CurrentTimeIndexModelProfile_t m_CurrentTimeIndexModelProfile;
00082     CurrentTimeIndexModelSequence_t m_CurrentTimeIndexModelSequence;
00083 
00084 
00085     const openfluid::base::SimulationStatus* mp_SimStatus;
00086 
00087     const WareIDSequence_t m_OriginalModelSequence;
00088 
00089     openfluid::core::TimeIndex_t m_CurrentTimeIndex;
00090 
00091     std::ofstream m_CurrentSequenceFile;
00092 
00093     std::ofstream m_CurrentProfileFile;
00094 
00095     static double getDurationInDecimalSeconds(const boost::posix_time::time_duration& Duration);
00096 
00097     void flushCurrentProfileToFiles();
00098 
00099   public:
00100 
00101     SimulationProfiler(const openfluid::base::SimulationStatus* SimStatus, const WareIDSequence_t& OrigModelSequence);
00102 
00103     ~SimulationProfiler();
00104 
00105     void addDuration(const openfluid::ware::WareID_t& SimID,
00106                      openfluid::base::SimulationStatus::SimulationStage ProfilePart,
00107                      const boost::posix_time::time_duration& Duration);
00108 
00109 };
00110 
00111 
00112 
00113 } } //namespaces
00114 
00115 
00116 #endif /* __SIMULATIONPROFILER_HPP___ */
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines