File: compression.rst

package info (click to toggle)
pcl 1.15.0%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 143,128 kB
  • sloc: cpp: 520,234; xml: 28,792; ansic: 8,212; python: 334; lisp: 93; sh: 49; makefile: 30
file content (268 lines) | stat: -rw-r--r-- 12,400 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
.. _octree_compression:

Point Cloud Compression
--------------------------------------------------------

Point clouds consist of huge data sets describing three dimensional points associated with
additional information such as distance, color, normals, etc. Additionally, they can be created at high rate and therefore occupy a significant amount
of memory resources. Once point clouds have to be stored or transmitted over rate-limited communication channels, 
methods for compressing this kind of data become highly interesting. The Point Cloud Library provides point cloud compression functionality. It allows for encoding all kinds of point clouds including "unorganized" point clouds that are characterized by 
non-existing point references, varying point size, resolution, density and/or point ordering. Furthermore, the underlying octree data structure 
enables to efficiently merge point cloud data from several sources. 


|octreeCompression|

     .. |octreeCompression| image:: images/compression_tutorial.png

In the following, we explain how single point clouds as well
as streams of points clouds can be efficiently compressed. 
In the presented example, we capture point clouds with the OpenNIGrabber to be compressed using the PCL point cloud compression techniques.


The code:
---------

First, create a file, let's say, ``point_cloud_compression.cpp`` and place the following inside it:

.. literalinclude:: sources/point_cloud_compression/point_cloud_compression.cpp
   :language: cpp
   :linenos:


The explanation
---------------

Now, let's discuss the code in detail. Let's start at the main() function: First we create a new SimpleOpenNIViewer instance and call its run() method. 

.. literalinclude:: sources/point_cloud_compression/point_cloud_compression.cpp
   :language: cpp
   :lines: 92-99

In the run() function, we create instances of the OctreePointCloudCompression class for encoding and decoding.
They can take compression profiles as an arguments for configuring the compression algorithm. The provided compression profiles predefine 
common parameter sets for point clouds captured by openNI devices. In this example, we use the **MED_RES_ONLINE_COMPRESSION_WITH_COLOR** profile which 
applies a coordinate encoding precision of 5 cubic millimeter and enables color component encoding. It is further optimized for fast online compression. 
A full list of compression profiles including their configuration can be found in the file 
"/io/include/pcl/compression/compression_profiles.h". 
A full parametrization of the compression algorithm is also possible in the OctreePointCloudCompression constructor using the MANUAL_CONFIGURATION profile. 
For further details on advanced parametrization, please have a look at section "Advanced Parametrization".

.. literalinclude:: sources/point_cloud_compression/point_cloud_compression.cpp
   :language: cpp
   :lines: 50-57

   
The following code instantiates a new grabber for an OpenNI device and starts the interface callback loop. 

.. literalinclude:: sources/point_cloud_compression/point_cloud_compression.cpp
   :language: cpp
   :lines: 59-77

In the callback function executed by the OpenNIGrabber capture loop, we first compress the captured point cloud into a stringstream buffer. That follows a
decompression step, which decodes the compressed binary data into a new point cloud object. The decoded point cloud is then sent to the point cloud viewer.
 
.. literalinclude:: sources/point_cloud_compression/point_cloud_compression.cpp
   :language: cpp
   :lines: 24-44


Compiling and running the program
---------------------------------

Add the following lines to your CMakeLists.txt file:

.. literalinclude:: sources/point_cloud_compression/CMakeLists.txt
   :language: cmake
   :linenos:

   
After you have made the executable, you can run it. Simply do::

  $ ./point_cloud_compression

You will see something similar to::

	[OpenNIGrabber] Number devices connected: 1
	[OpenNIGrabber] 1. device on bus 002:17 is a Xbox NUI Camera (2ae) from Microsoft (45e) with serial id 'B00364707960044B'
	[OpenNIGrabber] device_id is not set or has unknown format: ! Using first device.
	[OpenNIGrabber] Opened 'Xbox NUI Camera' on bus 2:17 with serial number 'B00364707960044B'
	streams alive:  image,  depth_image
	*** POINTCLOUD ENCODING ***
	Frame ID: 1
	Encoding Frame: Intra frame
	Number of encoded points: 192721
	XYZ compression percentage: 3.91049%
	XYZ bytes per point: 0.469259 bytes
	Color compression percentage: 15.4717%
	Color bytes per point: 0.618869 bytes
	Size of uncompressed point cloud: 3011.27 kBytes
	Size of compressed point cloud: 204 kBytes
	Total bytes per point: 1.08813 bytes
	Total compression percentage: 6.8008%
	Compression ratio: 14.7042
	
	*** POINTCLOUD ENCODING ***
	Frame ID: 2
	Encoding Frame: Prediction frame
	Number of encoded points: 192721
	XYZ compression percentage: 3.8132%
	XYZ bytes per point: 0.457584 bytes
	Color compression percentage: 15.5448%
	Color bytes per point: 0.62179 bytes
	Size of uncompressed point cloud: 3011.27 kBytes
	Size of compressed point cloud: 203 kBytes
	Total bytes per point: 1.07937 bytes
	Total compression percentage: 6.74609%
	Compression ratio: 14.8234
	
	*** POINTCLOUD ENCODING ***
	Frame ID: 3
	Encoding Frame: Prediction frame
	Number of encoded points: 192721
	XYZ compression percentage: 3.79962%
	XYZ bytes per point: 0.455954 bytes
	Color compression percentage: 15.2121%
	Color bytes per point: 0.608486 bytes
	Size of uncompressed point cloud: 3011.27 kBytes
	Size of compressed point cloud: 200 kBytes
	Total bytes per point: 1.06444 bytes
	Total compression percentage: 6.65275%
	Compression ratio: 15.0314
	
	...


Compression Profiles:
--------------------------------------------------------
Compression profiles define parameter sets for the PCL point cloud encoder. They are optimized for compression of 
common point clouds retrieved from the OpenNI grabber.
Please note, that the decoder does not need to be parametrized as it detects and adopts the configuration used during encoding.  
The following compression profiles are available:

	- **LOW_RES_ONLINE_COMPRESSION_WITHOUT_COLOR** 1 cubic centimeter resolution, no color, fast online encoding
	
	- **LOW_RES_ONLINE_COMPRESSION_WITH_COLOR** 1 cubic centimeter resolution, color, fast online encoding
	
	- **MED_RES_ONLINE_COMPRESSION_WITHOUT_COLOR** 5 cubic millimeter resolution, no color, fast online encoding
	
	- **MED_RES_ONLINE_COMPRESSION_WITH_COLOR** 5 cubic millimeter resolution, color, fast online encoding
	
	- **HIGH_RES_ONLINE_COMPRESSION_WITHOUT_COLOR** 1 cubic millimeter resolution, no color, fast online encoding
	
	- **HIGH_RES_ONLINE_COMPRESSION_WITH_COLOR** 1 cubic millimeter resolution, color, fast online encoding

	- **LOW_RES_OFFLINE_COMPRESSION_WITHOUT_COLOR** 1 cubic centimeter resolution, no color, efficient offline encoding
	
	- **LOW_RES_OFFLINE_COMPRESSION_WITH_COLOR** 1 cubic centimeter resolution, color, efficient offline encoding
	
	- **MED_RES_OFFLINE_COMPRESSION_WITHOUT_COLOR** 5 cubic millimeter resolution, no color, efficient offline encoding
	
	- **MED_RES_OFFLINE_COMPRESSION_WITH_COLOR** 5 cubic millimeter resolution, color, efficient offline encoding
	
	- **HIGH_RES_OFFLINE_COMPRESSION_WITHOUT_COLOR** 1 cubic millimeter resolution, no color, efficient offline encoding
	
	- **HIGH_RES_OFFLINE_COMPRESSION_WITH_COLOR** 1 cubic millimeter resolution, color, efficient offline encoding
	
	- **MANUAL_CONFIGURATION** enables manual configuration for advanced parametrization
 

Advanced parametrization:
--------------------------------------------------------	

In order to have full access to all compression related parameters, the constructor of the OctreePointCloudCompression class can initialized with additional 
compression parameters. Please note, that for enabling advanced parametrization, the compressionProfile_arg argument **needs** to be set to **MANUAL_CONFIGURATION**. 

.. code-block:: cpp

        OctreePointCloudCompression (compression_Profiles_e compressionProfile_arg,
                                     bool showStatistics_arg,
                                     const double pointResolution_arg,
                                     const double octreeResolution_arg,
                                     bool doVoxelGridDownDownSampling_arg,
                                     const unsigned int iFrameRate_arg,
                                     bool doColorEncoding_arg,
                                     const unsigned char colorBitResolution_arg
                                    ) 
                               

The advanced parametrization is explained in the following: 

	- **compressionProfile_arg**: This parameter should be set to **MANUAL_CONFIGURATION** for enabling advanced parametrization.
	
	- **showStatistics_arg**: Print compression related statistics to stdout.
	
	- **pointResolution_arg**: Define coding precision for point coordinates. This parameter should be set to a value below the sensor noise. 
	
	- **octreeResolution_arg**: This parameter defines the voxel size of the deployed octree. A lower voxel resolution enables faster compression at, however, 
	  decreased compression performance. This enables a trade-off between high frame/update rates and compression efficiency.
	  
	- **doVoxelGridDownDownSampling_arg**: If activated, only the hierarchical octree data structure is encoded. The decoder generated points at the voxel centers. In this
	  way, the point cloud becomes downsampled during compression while achieving high compression performance. 
	  
	- **iFrameRate_arg**: The point cloud compression scheme differentially encodes point clouds.  In this way, differences between the incoming point cloud and the previously encoded pointcloud is encoded in order to achieve maximum compression performance. The iFrameRate_arg allows to specify the rate of frames in the stream at which incoming point clouds are **not** differentially encoded (similar to I/P-frames in video coding).   
	    
	- **doColorEncoding_arg**: This option enables color component encoding.   	 
	
	- **colorBitResolution_arg**: This parameter defines the amount of bits per color component to be encoded. 

Command line tool for PCL point cloud stream compression
--------------------------------------------------------

The pcl apps component contains a command line tool for point cloud compression
and streaming: Simply execute "./pcl_openni_octree_compression -?" to see a full
list of options (note: the output on screen may differ)::


  PCL point cloud stream compression

  usage: ./pcl_openni_octree_compression [mode] [profile] [parameters]

  I/O: 
      -f file  : file name 

  file compression mode:
      -x: encode point cloud stream to file
      -d: decode from file and display point cloud stream

  network streaming mode:
      -s       : start server on localhost
      -c host  : connect to server and display decoded cloud stream

  optional compression profile: 
      -p profile : select compression profile:       
                     -"lowC"  Low resolution with color
                     -"lowNC" Low resolution without color
                     -"medC" Medium resolution with color
                     -"medNC" Medium resolution without color
                     -"highC" High resolution with color
                     -"highNC" High resolution without color

  optional compression parameters:
      -r prec  : point precision
      -o prec  : octree voxel size
      -v       : enable voxel-grid downsampling
      -a       : enable color coding
      -i rate  : i-frame rate
      -b bits  : bits/color component
      -t       : output statistics
      -e       : show input cloud during encoding

  example:
      ./pcl_openni_octree_compression -x -p highC -t -f pc_compressed.pcc

In order to stream compressed point cloud via TCP/IP, you can start the server with::

  $ ./pcl_openni_octree_compression -s
     
It will listen on port 6666 for incoming connections. Now start the client with::     

  $ ./pcl_openni_octree_compression -c SERVER_NAME
  
and remotely captured point clouds will be locally shown in the point cloud viewer.  
     
Conclusion
----------

This PCL point cloud compression enables to efficiently compress point clouds of any type and point cloud streams.