00001 /* ********* 00002 * 00003 * This file is part of: 00004 * NePSing, Network Protocol Simulator next generation 00005 * 00006 * Copyright (C) 2004 Tommaso Pecorella <tpecorella@mac.com> 00007 * 00008 * This library is free software; you can redistribute it and/or 00009 * modify it under the terms of the GNU Lesser General Public 00010 * License as published by the Free Software Foundation; either 00011 * version 2.1 of the License, or (at your option) any later version. 00012 * 00013 * This library 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 GNU 00016 * Lesser General Public 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00021 * 00022 ********* */ 00023 00024 #ifndef __PROBEMEAN_H__ 00025 #define __PROBEMEAN_H__ 00026 00027 #include "probe.h" 00028 00034 00041 // ************************************************************************** 00042 // 00043 // Output values: 00044 // Time Mean Quadratic_Mean Sigma^2 (Quadratic_Mean-Mean^2) 00045 // 00046 // ************************************************************************** 00047 00049 00055 class ProbeMean : public Probe 00056 { 00057 private: 00058 unsigned long int N; 00059 double Sum; 00060 double SumSq; 00061 00062 public: 00063 ProbeMean( string _theName, bool _isGlobal = false ); 00064 00065 virtual void Reset( void ); 00066 virtual void Zap( double ); 00067 00068 virtual void Observe( double value ); 00069 virtual void WriteToFile( double time ); 00070 }; 00071 00073 00074 #endif 00075