Measurement.h

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__ */

Generated on Mon Mar 24 11:15:46 2008 for Pydtn Simulator by  doxygen 1.5.4