00001 // -*- C++ -*- 00002 00003 // PLearn (A C++ Machine Learning Library) 00004 // Copyright (C) 2001 Yoshua Bengio and University of Montreal 00005 // 00006 00007 // Redistribution and use in source and binary forms, with or without 00008 // modification, are permitted provided that the following conditions are met: 00009 // 00010 // 1. Redistributions of source code must retain the above copyright 00011 // notice, this list of conditions and the following disclaimer. 00012 // 00013 // 2. Redistributions in binary form must reproduce the above copyright 00014 // notice, this list of conditions and the following disclaimer in the 00015 // documentation and/or other materials provided with the distribution. 00016 // 00017 // 3. The name of the authors may not be used to endorse or promote 00018 // products derived from this software without specific prior written 00019 // permission. 00020 // 00021 // THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR 00022 // IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 00023 // OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN 00024 // NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 00025 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED 00026 // TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00027 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00028 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00029 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00030 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00031 // 00032 // This file is part of the PLearn library. For more information on the PLearn 00033 // library, go to the PLearn Web site at www.plearn.org 00034 00035 /* ******************************************************* 00036 * $Id: Profiler.h,v 1.4 2004/07/21 16:30:54 chrish42 Exp $ 00037 * This file is part of the PLearn library. 00038 ******************************************************* */ 00039 00042 #ifndef PROFILER_INC 00043 #define PROFILER_INC 00044 00045 #define PROFILE 00046 00047 #ifdef WIN32 00048 // For the moment I put a compiler error 00049 // but I could throw a PERROR.. 00050 #error Profiler is not working on WIN32 00051 #endif 00052 00053 #include <sys/times.h> 00054 #include <plearn/base/general.h> 00055 #include <plearn/base/plerror.h> 00056 #include <plearn/base/stringutils.h> 00057 00058 namespace PLearn { 00059 using namespace std; 00060 00089 class Profiler { 00090 protected: 00091 00092 class Stats { 00093 public: 00094 int frequency_of_occurence; 00095 int total_duration; 00096 clock_t time_of_last_start; 00097 bool on_going; 00098 00099 Stats(int f=0, int d=0) : 00100 frequency_of_occurence(f), total_duration(d), 00101 time_of_last_start(0), on_going(false) {} 00102 }; 00103 00104 public: 00105 00106 static void activate() { active=true; } 00107 static void disactivate() { active=false; } 00108 00110 #ifdef PROFILE 00111 static void start(const string& name_of_piece_of_code); 00112 #else 00113 static inline void start(const string& name_of_piece_of_code) { } 00114 #endif 00115 00118 #ifdef PROFILE 00119 static void end(const string& name_of_piece_of_code); 00120 #else 00121 static inline void end(const string& name_of_piece_of_code) { } 00122 #endif 00123 00126 static void report(ostream& out); 00127 00128 protected: 00129 00130 static map<string,Stats> codes_statistics; 00131 static struct tms t; 00132 static bool active; 00133 00134 }; 00135 00136 } // end of namespace PLearn 00137 00138 #endif 00139