Visual Servoing Platform version 3.7.0
Loading...
Searching...
No Matches
vpStatisticalTestSigma.h
1/*
2 * ViSP, open source Visual Servoing Platform software.
3 * Copyright (C) 2005 - 2025 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
35
36#ifndef VP_STATISTICAL_TEST_SIGMA_H
37#define VP_STATISTICAL_TEST_SIGMA_H
38
39#include <visp3/core/vpConfig.h>
40
41#include <visp3/core/vpStatisticalTestAbstract.h>
42
74
76{
77protected:
78 float m_h;
79 float m_signal;
80
84 virtual void computeLimits();
85
93 virtual vpMeanDriftType detectDownwardMeanDrift() VP_OVERRIDE;
94
102 virtual vpMeanDriftType detectUpwardMeanDrift() VP_OVERRIDE;
103
110 virtual bool updateStatistics(const float &signal) VP_OVERRIDE;
111
117 virtual void updateTestSignals(const float &signal) VP_OVERRIDE;
118
119public:
126 vpStatisticalTestSigma(const float &h = 3.f, const unsigned int &nbSamplesForStats = 30);
127
135 vpStatisticalTestSigma(const float &h, const float &mean, const float &stdev);
136
142 inline virtual float getSignal() const
143 {
144 return m_signal;
145 }
146
153 void init(const float &h = 3.f, const unsigned int &nbSamplesForStats = 30);
154
162 void init(const float &h, const float &mean, const float &stdev);
163};
164END_VISP_NAMESPACE
165#endif
vpMeanDriftType
Enum that indicates if a drift of the mean occurred.
void init()
(Re)Initialize the algorithm.
vpStatisticalTestAbstract()
Construct a new vpStatisticalTestAbstract object.
virtual vpMeanDriftType detectDownwardMeanDrift()=0
Detects if a downward mean drift occurred.
vpStatisticalTestSigma(const float &h=3.f, const unsigned int &nbSamplesForStats=30)
Construct a new vpStatisticalTestSigma object.
virtual float getSignal() const
Get the last value of the signal.
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.