Visual Servoing Platform version 3.7.0
Loading...
Searching...
No Matches
vpStatisticalTestSigma.cpp
1/*
2 * ViSP, open source Visual Servoing Platform software.
3 * Copyright (C) 2005 - 2024 by Inria. All rights reserved.
4 *
5 * This software is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 * See the file LICENSE.txt at the root directory of this source
10 * distribution for additional information about the GNU GPL.
11 *
12 * For using ViSP with software that can not be combined with the GNU
13 * GPL, please contact Inria about acquiring a ViSP Professional
14 * Edition License.
15 *
16 * See https://visp.inria.fr for more information.
17 *
18 * This software was developed at:
19 * Inria Rennes - Bretagne Atlantique
20 * Campus Universitaire de Beaulieu
21 * 35042 Rennes Cedex
22 * France
23 *
24 * If you have questions regarding the use of this file, please contact
25 * Inria at visp@inria.fr
26 *
27 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
28 * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
29 */
30
38
39#include <visp3/core/vpStatisticalTestSigma.h>
40
43{
44 float delta = m_h * m_stdev;
45 m_limitDown = m_mean - delta;
46 m_limitUp = m_mean + delta;
47}
48
58
68
70{
71 bool areStatsAvailable = vpStatisticalTestAbstract::updateStatistics(signal);
72 if (areStatsAvailable) {
74 }
75 return areStatsAvailable;
76}
77
79{
80 m_signal = signal;
81}
82
83vpStatisticalTestSigma::vpStatisticalTestSigma(const float &h, const unsigned int &nbSamplesForStats)
85 , m_h(h)
86{
87 init(h, nbSamplesForStats);
88}
89
90vpStatisticalTestSigma::vpStatisticalTestSigma(const float &h, const float &mean, const float &stdev)
92 , m_h(h)
93{
94 init(h, mean, stdev);
95}
96
97void vpStatisticalTestSigma::init(const float &h, const unsigned int &nbSamplesForStats)
98{
100 m_h = h;
101 setNbSamplesForStat(nbSamplesForStats);
102 m_signal = 0;
103}
104
105void vpStatisticalTestSigma::init(const float &h, const float &mean, const float &stdev)
106{
108 m_h = h;
109 m_mean = mean;
110 m_signal = 0;
111 m_stdev = stdev;
114}
115END_VISP_NAMESPACE
vpMeanDriftType
Enum that indicates if a drift of the mean occurred.
void init()
(Re)Initialize the algorithm.
vpStatisticalTestAbstract()
Construct a new vpStatisticalTestAbstract object.
virtual bool updateStatistics(const float &signal)
Update m_s and if enough values are available, compute the mean, the standard deviation and the limit...
void setNbSamplesForStat(const unsigned int &nbSamples)
Set the number of samples required to compute the mean and standard deviation of the signal and alloc...
vpStatisticalTestSigma(const float &h=3.f, const unsigned int &nbSamplesForStats=30)
Construct a new vpStatisticalTestSigma object.
virtual void updateTestSignals(const float &signal) VP_OVERRIDE
Update the test signals.
virtual bool updateStatistics(const float &signal) VP_OVERRIDE
Update m_s and if enough values are available, compute the mean, the standard deviation and the limit...
virtual vpMeanDriftType detectUpwardMeanDrift() VP_OVERRIDE
Detects if an upward mean drift occurred on the mean.
virtual void computeLimits()
Compute the upper and lower limits of the test signal.
virtual vpMeanDriftType detectDownwardMeanDrift() VP_OVERRIDE
Detects if a downward mean drift occurred.