Point Cloud Library (PCL)
1.15.1
Toggle main menu visibility
Loading...
Searching...
No Matches
kinfu
include
pcl
gpu
kinfu
color_volume.h
1
/*
2
* Software License Agreement (BSD License)
3
*
4
* Point Cloud Library (PCL) - www.pointclouds.org
5
* Copyright (c) 2011, Willow Garage, Inc.
6
*
7
* All rights reserved.
8
*
9
* Redistribution and use in source and binary forms, with or without
10
* modification, are permitted provided that the following conditions
11
* are met:
12
*
13
* * Redistributions of source code must retain the above copyright
14
* notice, this list of conditions and the following disclaimer.
15
* * Redistributions in binary form must reproduce the above
16
* copyright notice, this list of conditions and the following
17
* disclaimer in the documentation and/or other materials provided
18
* with the distribution.
19
* * Neither the name of Willow Garage, Inc. nor the names of its
20
* contributors may be used to endorse or promote products derived
21
* from this software without specific prior written permission.
22
*
23
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
26
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
27
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
28
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
29
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
30
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
31
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
33
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34
* POSSIBILITY OF SUCH DAMAGE.
35
*
36
*/
37
38
#pragma once
39
40
#include <
pcl/memory.h
>
41
#include <
pcl/pcl_macros.h
>
42
#include <pcl/gpu/containers/device_array.h>
43
#include <
pcl/point_types.h
>
44
#include <pcl/point_cloud.h>
45
#include <Eigen/Core>
46
47
namespace
pcl
48
{
49
namespace
gpu
50
{
51
class
TsdfVolume
;
52
53
/** \brief ColorVolume class
54
* \author Anatoly Baskeheev, Itseez Ltd, (myname.mysurname@mycompany.com)
55
*/
56
class
PCL_EXPORTS
ColorVolume
57
{
58
public
:
59
using
PointType
=
PointXYZ
;
60
using
Ptr
= shared_ptr<ColorVolume>;
61
using
ConstPtr
= shared_ptr<const ColorVolume>;
62
63
/** \brief Constructor
64
* \param[in] tsdf tsdf volume to get parameters from
65
* \param[in] max_weight max weight for running average. Can be less than 255. Negative means default.
66
*/
67
ColorVolume
(
const
TsdfVolume
& tsdf,
int
max_weight = -1);
68
69
/** \brief Resets color volume to uninitialized state */
70
void
71
reset
();
72
73
/** \brief Returns running average length */
74
int
75
getMaxWeight
()
const
;
76
77
/** \brief Returns container with color volume in GPU memory */
78
DeviceArray2D<int>
79
data
()
const
;
80
81
/** \brief Computes colors from color volume
82
* \param[in] cloud Points for which colors are to be computed.
83
* \param[out] colors output array for colors
84
*/
85
void
86
fetchColors
(
const
DeviceArray<PointType>
& cloud,
DeviceArray<RGB>
& colors)
const
;
87
88
private
:
89
/** \brief Volume resolution */
90
Eigen::Vector3i resolution_;
91
92
/** \brief Volume size in meters */
93
Eigen::Vector3f volume_size_;
94
95
/** \brief Length of running average */
96
int
max_weight_;
97
98
/** \brief color volume data */
99
DeviceArray2D<int>
color_volume_;
100
101
public
:
102
PCL_MAKE_ALIGNED_OPERATOR_NEW
103
104
};
105
}
106
}
pcl::gpu::ColorVolume::getMaxWeight
int getMaxWeight() const
Returns running average length.
pcl::gpu::ColorVolume::Ptr
shared_ptr< ColorVolume > Ptr
Definition
color_volume.h:60
pcl::gpu::ColorVolume::data
DeviceArray2D< int > data() const
Returns container with color volume in GPU memory.
pcl::gpu::ColorVolume::ColorVolume
ColorVolume(const TsdfVolume &tsdf, int max_weight=-1)
Constructor.
pcl::gpu::ColorVolume::fetchColors
void fetchColors(const DeviceArray< PointType > &cloud, DeviceArray< RGB > &colors) const
Computes colors from color volume.
pcl::gpu::ColorVolume::ConstPtr
shared_ptr< const ColorVolume > ConstPtr
Definition
color_volume.h:61
pcl::gpu::ColorVolume::reset
void reset()
Resets color volume to uninitialized state.
pcl::gpu::ColorVolume::PointType
PointXYZ PointType
Definition
color_volume.h:59
pcl::gpu::DeviceArray2D
DeviceArray2D class
Definition
device_array.h:188
pcl::gpu::DeviceArray
DeviceArray class
Definition
device_array.h:54
pcl::gpu::TsdfVolume
TsdfVolume class.
Definition
tsdf_volume.h:56
point_types.h
Defines all the PCL implemented PointT point type structures.
PCL_MAKE_ALIGNED_OPERATOR_NEW
#define PCL_MAKE_ALIGNED_OPERATOR_NEW
Macro to signal a class requires a custom allocator.
Definition
memory.h:86
memory.h
Defines functions, macros and traits for allocating and using memory.
pcl::gpu
Definition
device_array.h:45
pcl
Definition
convolution.h:46
pcl_macros.h
Defines all the PCL and non-PCL macros used.
pcl::PointXYZ
A point structure representing Euclidean xyz coordinates.
Definition
point_types.hpp:322