X-Git-Url: https://www.fleuret.org/cgi-bin/gitweb/gitweb.cgi?a=blobdiff_plain;f=gaussian.cc;fp=gaussian.cc;h=3278377aa0433157d71646893fabd3a78c081324;hb=d922ad61d35e9a6996730bec24b16f8bf7bc426c;hp=0000000000000000000000000000000000000000;hpb=3bb118f5a9462d02ff7d99ef28ecc0d7e23529f9;p=folded-ctf.git diff --git a/gaussian.cc b/gaussian.cc new file mode 100644 index 0000000..3278377 --- /dev/null +++ b/gaussian.cc @@ -0,0 +1,45 @@ + +/////////////////////////////////////////////////////////////////////////// +// This program is free software: you can redistribute it and/or modify // +// it under the terms of the version 3 of the GNU General Public License // +// as published by the Free Software Foundation. // +// // +// 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 for more details. // +// // +// You should have received a copy of the GNU General Public License // +// along with this program. If not, see . // +// // +// Written by Francois Fleuret, (C) IDIAP // +// Contact for comments & bug reports // +/////////////////////////////////////////////////////////////////////////// + +#include "gaussian.h" + +Gaussian::Gaussian() { + _nb_samples = 0; + _sum = 0.0; + _sum_sq = 0.0; +} + +void Gaussian::add_sample(scalar_t x) { + _nb_samples++; + _sum += x; + _sum_sq += x * x; +} + +scalar_t Gaussian::expectation() { + return _sum / scalar_t(_nb_samples); +} + +scalar_t Gaussian::variance() { + scalar_t e = _sum / scalar_t(_nb_samples); + return (_sum_sq - _sum * e) / scalar_t(_nb_samples - 1); +} + +scalar_t Gaussian::standard_deviation() { + return sqrt(variance()); +} +