00001 // Copyright (C) 2004 EPITA Research and Development Laboratory 00002 // 00003 // This file is part of the Olena Library. This library is free 00004 // software; you can redistribute it and/or modify it under the terms 00005 // of the GNU General Public License version 2 as published by the 00006 // Free Software Foundation. 00007 // 00008 // This library is distributed in the hope that it will be useful, 00009 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00010 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00011 // General Public License for more details. 00012 // 00013 // You should have received a copy of the GNU General Public License 00014 // along with this library; see the file COPYING. If not, write to 00015 // the Free Software Foundation, 59 Temple Place - Suite 330, Boston, 00016 // MA 02111-1307, USA. 00017 // 00018 // As a special exception, you may use this file as part of a free 00019 // software library without restriction. Specifically, if other files 00020 // instantiate templates or use macros or inline functions from this 00021 // file, or you compile this file and link it with other files to 00022 // produce an executable, this file does not by itself cause the 00023 // resulting executable to be covered by the GNU General Public 00024 // License. This exception does not however invalidate any other 00025 // reasons why the executable file might be covered by the GNU General 00026 // Public License. 00027 00028 00029 #ifndef OLN_UTILS_SE_STAT_HXX 00030 # define OLN_UTILS_SE_STAT_HXX 00031 00032 namespace oln { 00033 namespace utils { 00034 00036 template <typename Sum, typename Var> 00037 template <class I, class S> 00038 inline se_stat<Sum, Var> & 00039 se_stat<Sum, Var>::compute(const oln::abstract::image<I> &im, 00040 const oln_point_type(I) &p, 00041 const oln::abstract::struct_elt<S> &s) 00042 { 00043 sum_ = ntg_zero_val(Sum); 00044 card_ = s.card(); 00045 // Compute the mean 00046 oln_iter_type(S) it(s); 00047 { 00048 for_all(it) 00049 sum_ += internal::f_to_float_<Sum, 00050 oln_value_type(I)>::doit(im[p + it]); 00051 mean_ = sum_ / card_; 00052 } 00053 // Compute the variance 00054 { 00055 Var sum_2(ntg_zero_val(Var)); 00056 for_all(it) 00057 { 00058 Sum tmp = mean_; 00059 tmp -= im[p + it]; 00060 sum_2 += oln::math::dot_product<Var>(tmp, tmp); 00061 } 00062 variance_ = sum_2 / card_; 00063 } 00064 return *this; 00065 } 00066 } // end namespace utils 00067 00068 } // end namespace oln 00069 00070 #endif