|  | Home | Libraries | People | FAQ | More | 
boost::accumulators::impl::weighted_p_square_quantile_impl — Single quantile estimation with the  algorithm for weighted samples.
 algorithm for weighted samples. 
// In header: <boost/accumulators/statistics_fwd.hpp> template<typename Sample, typename Weight, typename Impl> struct weighted_p_square_quantile_impl : public accumulator_base { // public member functions template<typename Args> weighted_p_square_quantile_impl(Args const &); template<typename Args> void operator()(Args const &); result_type result(dont_care) const; template<typename Archive> void serialize(Archive &, const unsigned int); };
This version of the  algorithm extends the
 algorithm extends the  algorithm to support weighted samples. The
 algorithm to support weighted samples. The  algorithm estimates a quantile dynamically without storing samples. Instead of storing the whole sample cumulative distribution, only five points (markers) are stored. The heights of these markers are the minimum and the maximum of the samples and the current estimates of the
 algorithm estimates a quantile dynamically without storing samples. Instead of storing the whole sample cumulative distribution, only five points (markers) are stored. The heights of these markers are the minimum and the maximum of the samples and the current estimates of the  -,
-,  - and
 - and  -quantiles. Their positions are equal to the number of samples that are smaller or equal to the markers. Each time a new sample is added, the positions of the markers are updated and if necessary their heights are adjusted using a piecewise- parabolic formula.
 -quantiles. Their positions are equal to the number of samples that are smaller or equal to the markers. Each time a new sample is added, the positions of the markers are updated and if necessary their heights are adjusted using a piecewise- parabolic formula.
For further details, see
R. Jain and I. Chlamtac, The P^2 algorithm for dynamic calculation of quantiles and histograms without storing observations, Communications of the ACM, Volume 28 (October), Number 10, 1985, p. 1076-1085.