Visual Servoing Platform version 3.7.0
Loading...
Searching...
No Matches
vpDepthMask.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#ifndef VP_DEPTH_MASK_H
36#define VP_DEPTH_MASK_H
37
38#include <visp3/core/vpConfig.h>
39#include <visp3/core/vpException.h>
40#include <visp3/rbt/vpObjectMask.h>
41#include <visp3/core/vpDisplay.h>
42#include <visp3/core/vpImage.h>
43
44#ifdef VISP_HAVE_NLOHMANN_JSON
45#include VISP_NLOHMANN_JSON(json_fwd.hpp)
46#endif
47
49
51
56class VISP_EXPORT vpDepthMask : public vpObjectMask
57{
58public:
59 vpDepthMask() : m_minRadiusFactor(0.0), m_falloffSmoothingFactor(0.5), m_computeOnBBOnly(false) { }
60 virtual ~vpDepthMask() = default;
61
62 void updateMask(const vpRBFeatureTrackerInput &frame,
63 const vpRBFeatureTrackerInput &previousFrame,
64 vpImage<float> &mask) VP_OVERRIDE;
65
66 virtual void reset() VP_OVERRIDE
67 { }
68
79 double getMinRadiusFactor() const { return m_minRadiusFactor; }
80 void setMinRadiusMeters(double minRadius) { m_minRadiusFactor = minRadius; }
81
90 double getFalloffRadiusFactor() const { return m_falloffSmoothingFactor; }
91 void setFalloffRadiusFactor(double factor) { m_falloffSmoothingFactor = factor; }
92
93 bool isComputedOnlyOnBoundingBox() const { return m_computeOnBBOnly; }
95 {
96 m_computeOnBBOnly = bbOnly;
97 }
98
99
100#if defined(VISP_HAVE_NLOHMANN_JSON)
101 void loadJsonConfiguration(const nlohmann::json &json) VP_OVERRIDE;
102#endif
103
104private:
105 double m_minRadiusFactor;
106 double m_falloffSmoothingFactor;
107 bool m_computeOnBBOnly;
108};
109
110END_VISP_NAMESPACE
111
112#endif
void setComputeOnlyOnBoundingBox(bool bbOnly)
Definition vpDepthMask.h:94
double getFalloffRadiusFactor() const
Get the Falloff smoothing factor (of the depth range) strength of the depth probability distribution....
Definition vpDepthMask.h:90
void setMinRadiusMeters(double minRadius)
Definition vpDepthMask.h:80
virtual void reset() VP_OVERRIDE
Definition vpDepthMask.h:66
double getMinRadiusFactor() const
Retrieve the value of the minimum depth tolerated error. It is expressed as a factor of the object's ...
Definition vpDepthMask.h:79
virtual ~vpDepthMask()=default
void setFalloffRadiusFactor(double factor)
Definition vpDepthMask.h:91
bool isComputedOnlyOnBoundingBox() const
Definition vpDepthMask.h:93
Definition of the vpImage class member functions.
Definition vpImage.h:131
virtual void loadJsonConfiguration(const nlohmann::json &j)=0
virtual void updateMask(const vpRBFeatureTrackerInput &frame, const vpRBFeatureTrackerInput &previousFrame, vpImage< float > &mask)=0
All the data related to a single tracking frame. This contains both the input data (from a real camer...