00001 // Copyright 2008 Michael Marsh, University of Maryland. 00002 // 00003 // This file is part of pydtn. 00004 // 00005 // pydtn is free software: you can redistribute it and/or modify 00006 // it under the terms of the GNU General Public License as published by 00007 // the Free Software Foundation, either version 3 of the License, or 00008 // (at your option) any later version. 00009 // 00010 // pydtn is distributed in the hope that it will be useful, 00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00013 // GNU General Public License for more details. 00014 // 00015 // You should have received a copy of the GNU General Public License 00016 // along with pydtn. If not, see <http://www.gnu.org/licenses/>. 00017 // 00018 // The views and conclusions contained in the software and documentation 00019 // are those of the authors and should not be interpreted as representing 00020 // official policies, either expressed or implied, of the University 00021 // of Maryland. 00022 // 00023 // pydtn extends and embeds the Python interpreter, which is 00024 // Copyright 2001-2006 Python Software Foundation, All Rights Reserved, 00025 // and is released under the PSF License Agreement. 00026 // 00027 // RANLUX random number generation uses the Boost library, 00028 // Copyright 1994-2006 by various authors (details in individual files), 00029 // which is released under the Boost Software License, Version 1.0. 00030 00031 #ifndef __WRAPPERS_HARNESS_MEASUREMENT_H__ 00032 #define __WRAPPERS_HARNESS_MEASUREMENT_H__ 00033 00034 #include "config.h" 00035 #include <iosfwd> 00036 00039 00041 class Measurement 00042 { 00043 public : 00045 Measurement(); 00050 Measurement( double val, double var ); 00053 Measurement( unsigned long int val ); 00056 Measurement( const Measurement& m ); 00058 virtual ~Measurement(); 00059 00062 void operator=( const Measurement& m ); 00063 00065 double value() const { return m_value; } 00067 double variance() const { return m_variance; } 00069 double deviation() const { return m_sigma; } 00070 00075 00079 Measurement operator+( const Measurement& m ) const; 00084 Measurement operator-( const Measurement& m ) const; 00088 Measurement operator*( const Measurement& m ) const; 00093 Measurement operator/( const Measurement& m ) const; 00095 00100 bool operator<( const Measurement& m ) const; 00105 bool operator>( const Measurement& m ) const; 00106 00107 private : 00111 bool operator==( const Measurement& m ) const; 00112 00113 double m_value; 00114 double m_variance; 00115 double m_sigma; 00116 }; 00117 00123 std::ostream& operator<<(std::ostream& stream, const Measurement& m); 00124 00126 00127 #endif /* __WRAPPERS_HARNESS_MEASUREMENT_H__ */
1.5.4