Point Cloud Library (PCL)
1.15.1
Toggle main menu visibility
Loading...
Searching...
No Matches
containers
include
pcl
gpu
containers
impl
texture_binder.hpp
1
/*
2
* Software License Agreement (BSD License)
3
*
4
* Copyright (c) 2011, Willow Garage, Inc.
5
* All rights reserved.
6
*
7
* Redistribution and use in source and binary forms, with or without
8
* modification, are permitted provided that the following conditions
9
* are met:
10
*
11
* * Redistributions of source code must retain the above copyright
12
* notice, this list of conditions and the following disclaimer.
13
* * Redistributions in binary form must reproduce the above
14
* copyright notice, this list of conditions and the following
15
* disclaimer in the documentation and/or other materials provided
16
* with the distribution.
17
* * Neither the name of Willow Garage, Inc. nor the names of its
18
* contributors may be used to endorse or promote products derived
19
* from this software without specific prior written permission.
20
*
21
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32
* POSSIBILITY OF SUCH DAMAGE.
33
*
34
* Author: Anatoly Baskeheev, Itseez Ltd, (myname.mysurname@mycompany.com)
35
*/
36
37
#ifndef PCL_GPU_UTILS_TEXTURE_BINDER_HPP_
38
#define PCL_GPU_UTILS_TEXTURE_BINDER_HPP_
39
40
#include <pcl/gpu/containers/device_array.h>
41
#include <pcl/gpu/utils/safe_call.hpp>
42
43
namespace
pcl
{
44
namespace
gpu
{
45
class
TextureBinder
{
46
public
:
47
template
<
class
T, enum cudaTextureReadMode readMode>
48
TextureBinder
(
const
DeviceArray2D<T>
& arr,
const
struct
texture<T, 2, readMode>& tex)
49
: texref(&tex)
50
{
51
cudaChannelFormatDesc desc = cudaCreateChannelDesc<T>();
52
cudaSafeCall(
53
cudaBindTexture2D(0, tex, arr.
ptr
(), desc, arr.
cols
(), arr.
rows
(), arr.
step
()));
54
}
55
56
template
<
class
T, enum cudaTextureReadMode readMode>
57
TextureBinder
(
const
DeviceArray<T>
& arr,
const
struct
texture<T, 1, readMode>& tex)
58
: texref(&tex)
59
{
60
cudaChannelFormatDesc desc = cudaCreateChannelDesc<T>();
61
cudaSafeCall(cudaBindTexture(0, tex, arr.
ptr
(), desc, arr.
sizeBytes
()));
62
}
63
64
template
<
class
T, enum cudaTextureReadMode readMode>
65
TextureBinder
(
const
PtrStepSz<T>
& arr,
const
struct
texture<T, 2, readMode>& tex)
66
: texref(&tex)
67
{
68
cudaChannelFormatDesc desc = cudaCreateChannelDesc<T>();
69
cudaSafeCall(
70
cudaBindTexture2D(0, tex, arr.
data
, desc, arr.
cols
, arr.
rows
, arr.
step
));
71
}
72
73
template
<
class
T, enum cudaTextureReadMode readMode>
74
TextureBinder
(
const
PtrSz<T>
& arr,
const
struct
texture<T, 1, readMode>& tex)
75
: texref(&tex)
76
{
77
cudaChannelFormatDesc desc = cudaCreateChannelDesc<T>();
78
cudaSafeCall(cudaBindTexture(0, tex, arr.
data
, desc, arr.
size
* arr.
elemSize
()));
79
}
80
81
~TextureBinder
() { cudaSafeCall(cudaUnbindTexture(texref)); }
82
83
private
:
84
const
struct
textureReference* texref;
85
};
86
}
// namespace gpu
87
88
namespace
device {
89
using
pcl::gpu::TextureBinder
;
90
}
91
}
// namespace pcl
92
93
#endif
/* PCL_GPU_UTILS_TEXTURE_BINDER_HPP_*/
pcl::device::TextureBinder::TextureBinder
TextureBinder(const DeviceArray2D< T > &arr, const struct texture< T, 2, readMode > &tex)
Definition
texture_binder.hpp:48
pcl::gpu::DeviceArray2D
DeviceArray2D class
Definition
device_array.h:188
pcl::gpu::DeviceArray2D::rows
int rows() const
Returns number of rows.
Definition
device_array.hpp:317
pcl::gpu::DeviceArray2D::cols
int cols() const
Returns number of elements in each row.
Definition
device_array.hpp:310
pcl::gpu::DeviceArray2D::ptr
T * ptr(int y=0)
Returns pointer to given row in internal buffer.
Definition
device_array.hpp:284
pcl::gpu::DeviceArray
DeviceArray class
Definition
device_array.h:54
pcl::gpu::DeviceArray::ptr
T * ptr()
Returns pointer for internal buffer in GPU memory.
Definition
device_array.hpp:156
pcl::gpu::DeviceMemory2D::step
std::size_t step() const
Returns stride between two consecutive rows in bytes for internal buffer.
pcl::gpu::DeviceMemory::sizeBytes
std::size_t sizeBytes() const
pcl::gpu::TextureBinder
Definition
texture_binder.hpp:45
pcl::gpu::TextureBinder::~TextureBinder
~TextureBinder()
Definition
texture_binder.hpp:81
pcl::gpu::TextureBinder::TextureBinder
TextureBinder(const PtrStepSz< T > &arr, const struct texture< T, 2, readMode > &tex)
Definition
texture_binder.hpp:65
pcl::gpu::TextureBinder::TextureBinder
TextureBinder(const PtrSz< T > &arr, const struct texture< T, 1, readMode > &tex)
Definition
texture_binder.hpp:74
pcl::gpu::TextureBinder::TextureBinder
TextureBinder(const DeviceArray2D< T > &arr, const struct texture< T, 2, readMode > &tex)
Definition
texture_binder.hpp:48
pcl::gpu::TextureBinder::TextureBinder
TextureBinder(const DeviceArray< T > &arr, const struct texture< T, 1, readMode > &tex)
Definition
texture_binder.hpp:57
pcl::gpu
Definition
device_array.h:45
pcl
Definition
convolution.h:46
pcl::gpu::DevPtr::elemSize
__PCL_GPU_HOST_DEVICE__ std::size_t elemSize() const
Definition
kernel_containers.h:63
pcl::gpu::DevPtr::data
T * data
Definition
kernel_containers.h:54
pcl::gpu::PtrStep::step
std::size_t step
stride between two consecutive rows in bytes.
Definition
kernel_containers.h:94
pcl::gpu::PtrStepSz
Definition
kernel_containers.h:122
pcl::gpu::PtrStepSz::cols
int cols
Definition
kernel_containers.h:131
pcl::gpu::PtrStepSz::rows
int rows
Definition
kernel_containers.h:132
pcl::gpu::PtrSz
Definition
kernel_containers.h:74
pcl::gpu::PtrSz::size
std::size_t size
Definition
kernel_containers.h:81