/**************************************************************************** * VCGLib o o * * Visual and Computer Graphics Library o o * * _ O _ * * Copyright(C) 2004 \/)\/ * * Visual Computing Lab /\/| * * ISTI - Italian National Research Council | * * \ * * All rights reserved. * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License (http://www.gnu.org/licenses/gpl.txt) * * for more details. * * * ****************************************************************************/ /**************************************************************************** History $Log: not supported by cvs2svn $ Revision 1.3 2005/03/14 09:23:40 cignoni Added missing include Revision 1.2 2004/08/25 15:15:26 ganovelli minor changes to comply gcc compiler (typename's and stuff) Revision 1.1 2004/06/24 09:12:28 cignoni Initial Release ****************************************************************************/ #ifndef __VCG_HISTOGRAM #define __VCG_HISTOGRAM #include namespace vcg { /** */ template class Histogram { public: std::vector H; /// counters for bins std::vector R; /// Range for bins ( ScalarType minv; ScalarType maxv; int n; // numero di intervalli int cnt; // numero di campioni accumulati ScalarType avg; ScalarType rms; void SetRange(ScalarType _minv, ScalarType _maxv, int _n); void SetRange(ScalarType _minv, ScalarType _maxv, int _n, ScalarType gamma); int Interize(ScalarType val); void Add(ScalarType v); ScalarType Percentile(ScalarType frac) const; ScalarType Avg() { return avg/cnt; } ScalarType RMS() { return sqrt(rms/double(cnt));} ScalarType Variance() { return rms/cnt-Avg()*Avg(); } ScalarType StandardDeviation() { return sqrt(Variance()); } void FileWrite(const std::string &filename); void Clear(); }; template void Histogram ::Clear() { H.clear(); R.clear(); cnt=0; avg=0; rms=0; n=0; minv=0; maxv=1; } template void Histogram::SetRange(ScalarType _minv, ScalarType _maxv, int _n) { Clear(); minv=_minv;maxv=_maxv;n=_n; H.resize(n+1); fill(H.begin(),H.end(),0); R.resize(n+1); ScalarType dlt=(maxv-minv)/n; for(int i=0;i void Histogram::SetRange(ScalarType _minv, ScalarType _maxv, int _n, ScalarType gamma) { Clear(); minv=_minv;maxv=_maxv;n=_n; H.resize(n); fill(H.begin(),H.end(),0); R.resize(n+1); double dlt=(maxv-minv); for(int i=0;i int Histogram::Interize(ScalarType val) { int pos = lower_bound(R.begin(),R.end(),val) - R.begin() - 1; if(pos>n) pos=n; return pos; } template void Histogram::Add(ScalarType v){ int pos= lower_bound(R.begin(),R.end(),v)-R.begin()-1; if(pos<=n){ ++H[pos]; ++cnt; avg+=v; rms += v*v; } } template void Histogram::FileWrite(const std::string &filename){ FILE *fp; fp=fopen(filename.c_str(),"w"); for(int i=0;i