Point Cloud Library (PCL)
1.15.1
Toggle main menu visibility
Loading...
Searching...
No Matches
kinfu_large_scale
include
pcl
gpu
kinfu_large_scale
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
48
namespace
pcl
49
{
50
namespace
gpu
51
{
52
namespace
kinfuLS
53
{
54
class
TsdfVolume
;
55
56
/**
57
* \brief ColorVolume class
58
* \author Anatoly Baskeheev, Itseez Ltd, (myname.mysurname@mycompany.com)
59
*/
60
class
PCL_EXPORTS
ColorVolume
61
{
62
public
:
63
using
PointType
=
PointXYZ
;
64
using
Ptr
= shared_ptr<ColorVolume>;
65
using
ConstPtr
= shared_ptr<const ColorVolume>;
66
67
/**
68
* \brief Constructor
69
* \param[in] tsdf tsdf volume to get parameters from
70
* \param[in] max_weight max weight for running average. Can be less than 255. Negative means default.
71
*/
72
ColorVolume
(
const
TsdfVolume
& tsdf,
int
max_weight = -1);
73
74
/** \brief Resets color volume to uninitialized state */
75
void
76
reset
();
77
78
/** \brief Returns running average length */
79
int
80
getMaxWeight
()
const
;
81
82
/** \brief Returns container with color volume in GPU memory */
83
DeviceArray2D<int>
84
data
()
const
;
85
86
/**
87
* \brief Computes colors from color volume
88
* \param[in] cloud Points for which colors are to be computed.
89
* \param[out] colors output array for colors
90
*/
91
void
92
fetchColors
(
const
DeviceArray<PointType>
& cloud,
DeviceArray<RGB>
& colors)
const
;
93
94
private
:
95
/** \brief Volume resolution */
96
Eigen::Vector3i resolution_;
97
98
/** \brief Volume size in meters */
99
Eigen::Vector3f volume_size_;
100
101
/** \brief Length of running average */
102
int
max_weight_;
103
104
/** \brief color volume data */
105
DeviceArray2D<int>
color_volume_;
106
107
public
:
108
PCL_MAKE_ALIGNED_OPERATOR_NEW
109
};
110
}
111
}
112
}
pcl::gpu::DeviceArray2D
DeviceArray2D class
Definition
device_array.h:188
pcl::gpu::DeviceArray
DeviceArray class
Definition
device_array.h:54
pcl::gpu::kinfuLS::ColorVolume::reset
void reset()
Resets color volume to uninitialized state.
pcl::gpu::kinfuLS::ColorVolume::Ptr
shared_ptr< ColorVolume > Ptr
Definition
color_volume.h:64
pcl::gpu::kinfuLS::ColorVolume::ConstPtr
shared_ptr< const ColorVolume > ConstPtr
Definition
color_volume.h:65
pcl::gpu::kinfuLS::ColorVolume::data
DeviceArray2D< int > data() const
Returns container with color volume in GPU memory.
pcl::gpu::kinfuLS::ColorVolume::fetchColors
void fetchColors(const DeviceArray< PointType > &cloud, DeviceArray< RGB > &colors) const
Computes colors from color volume.
pcl::gpu::kinfuLS::ColorVolume::ColorVolume
ColorVolume(const TsdfVolume &tsdf, int max_weight=-1)
Constructor.
pcl::gpu::kinfuLS::ColorVolume::getMaxWeight
int getMaxWeight() const
Returns running average length.
pcl::gpu::kinfuLS::ColorVolume::PointType
PointXYZ PointType
Definition
color_volume.h:63
pcl::gpu::kinfuLS::TsdfVolume
TsdfVolume class.
Definition
tsdf_volume.h:63
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::kinfuLS
Definition
color_volume.h:53
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