Zivid C++ API 2.18.0+1b44dbef-1
UnorganizedPointCloud.h
Go to the documentation of this file.
1/*******************************************************************************
2 * This file is part of the Zivid API
3 *
4 * Copyright 2015-2026 (C) Zivid AS
5 * All rights reserved.
6 *
7 * Zivid Software License, v1.0
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions are met:
11 *
12 * 1. Redistributions of source code must retain the above copyright notice,
13 * this list of conditions and the following disclaimer.
14 *
15 * 2. Redistributions in binary form must reproduce the above copyright notice,
16 * this list of conditions and the following disclaimer in the documentation
17 * and/or other materials provided with the distribution.
18 *
19 * 3. Neither the name of Zivid AS nor the names of its contributors may be used
20 * to endorse or promote products derived from this software without specific
21 * prior written permission.
22 *
23 * 4. This software, with or without modification, must not be used with any
24 * other 3D camera than from Zivid AS.
25 *
26 * 5. Any software provided in binary form under this license must not be
27 * reverse engineered, decompiled, modified and/or disassembled.
28 *
29 * THIS SOFTWARE IS PROVIDED BY ZIVID AS "AS IS" AND ANY EXPRESS OR IMPLIED
30 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
31 * MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
32 * DISCLAIMED. IN NO EVENT SHALL ZIVID AS OR CONTRIBUTORS BE LIABLE FOR ANY
33 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
34 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
35 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
36 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
38 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 *
40 * Contact: Zivid Customer Success Team <customersuccess@zivid.com>
41 * Info: http://www.zivid.com
42 ******************************************************************************/
43
44#pragma once
45
46#include "Zivid/Array1D.h"
47#include "Zivid/Color.h"
50#include "Zivid/DeviceArray.h"
51#include "Zivid/Image.h"
52#include "Zivid/Matrix.h"
53#include "Zivid/Point.h"
54#include "Zivid/SNR.h"
55
56#include <iosfwd>
57#include <memory>
58#include <optional>
59#include <string>
60
61namespace Zivid
62{
75 {
76 public:
83
85 ZIVID_CORE_EXPORT size_t size() const;
86
91
95
124 ZIVID_CORE_EXPORT UnorganizedPointCloud voxelDownsampled(float voxelSize, int minPointsPerVoxel) const;
125
131
139
143
147 ZIVID_CORE_EXPORT std::optional<PointXYZ> centroid() const;
148
152
156
169
189
202
215
227
239
252
255
258
261
263 template<
264 typename ColorFormat,
265 typename = std::enable_if_t<Detail::SupportedImageDeviceArrayColorFormat<ColorFormat>::value>>
267
279 template<typename DataFormat>
281 {
282 static_assert(
283 HasCopyDataImplReturnArray1DTag<DataFormat>::value,
284 "The provided DataFormat is unsupported. Please refer to the documentation for "
285 "this method for the supported DataFormats.");
286 return copyDataImpl(ReturnArray1DTag<DataFormat>{});
287 }
288
338 template<typename DataFormat>
339 void copyData(DataFormat *destination) const
340 {
341 static_assert(
342 HasCopyDataImpl<DataFormat *>::value,
343 "The provided DataFormat is unsupported. Please refer to the documentation for "
344 "this method for the supported data formats.");
345 return copyDataImpl(destination);
346 }
347
359
362 ZIVID_CORE_EXPORT std::string toString() const;
363
364#ifndef NO_DOC
365 ZIVID_CORE_EXPORT class UnorganizedPointCloudImpl &getImpl();
366 ZIVID_CORE_EXPORT const class UnorganizedPointCloudImpl &getImpl() const;
367 ZIVID_CORE_EXPORT explicit UnorganizedPointCloud(std::shared_ptr<class UnorganizedPointCloudImpl> other);
368#endif
369
370 private:
371 template<class T>
372 struct ReturnArray1DTag
373 {};
374
375 template<typename... Args>
376 class HasCopyDataImplReturnArray1DTag
377 {
378 template<
379 typename C,
380 typename = decltype(std::declval<C>().copyDataImpl(std::declval<ReturnArray1DTag<Args>>()...))>
381 static std::true_type test(int);
382 template<typename C>
383 static std::false_type test(...);
384
385 public:
386 static constexpr bool value = decltype(test<UnorganizedPointCloud>(0))::value;
387 };
388
389 template<typename... Args>
390 class HasCopyDataImpl
391 {
392 template<typename C, typename = decltype(std::declval<C>().copyDataImpl(std::declval<Args>()...))>
393 static std::true_type test(int);
394 template<typename C>
395 static std::false_type test(...);
396
397 public:
398 static constexpr bool value = decltype(test<UnorganizedPointCloud>(0))::value;
399 };
400
401 ZIVID_CORE_EXPORT Array1D<PointXYZ> copyDataImpl(ReturnArray1DTag<PointXYZ> /*tag*/) const;
402 ZIVID_CORE_EXPORT Array1D<PointXYZW> copyDataImpl(ReturnArray1DTag<PointXYZW> /*tag*/) const;
403 ZIVID_CORE_EXPORT Array1D<ColorRGBA> copyDataImpl(ReturnArray1DTag<ColorRGBA> /*tag*/) const;
404 ZIVID_CORE_EXPORT Array1D<ColorBGRA> copyDataImpl(ReturnArray1DTag<ColorBGRA> /*tag*/) const;
405 ZIVID_CORE_EXPORT Array1D<ColorRGBA_SRGB> copyDataImpl(ReturnArray1DTag<ColorRGBA_SRGB> /*tag*/) const;
406 ZIVID_CORE_EXPORT Array1D<ColorBGRA_SRGB> copyDataImpl(ReturnArray1DTag<ColorBGRA_SRGB> /*tag*/) const;
407 ZIVID_CORE_EXPORT Array1D<SNR> copyDataImpl(ReturnArray1DTag<SNR> /*tag*/) const;
408
409 ZIVID_CORE_EXPORT void copyDataImpl(PointXYZ *destination) const;
410 ZIVID_CORE_EXPORT void copyDataImpl(PointXYZW *destination) const;
411 ZIVID_CORE_EXPORT void copyDataImpl(ColorRGBA *destination) const;
412 ZIVID_CORE_EXPORT void copyDataImpl(ColorBGRA *destination) const;
413 ZIVID_CORE_EXPORT void copyDataImpl(ColorRGBA_SRGB *destination) const;
414 ZIVID_CORE_EXPORT void copyDataImpl(ColorBGRA_SRGB *destination) const;
415 ZIVID_CORE_EXPORT void copyDataImpl(SNR *destination) const;
416
417 std::shared_ptr<class UnorganizedPointCloudImpl> m_impl;
418 };
419
422 std::ostream &stream,
423 const UnorganizedPointCloud &unorganizedPointCloud);
424
425#ifndef NO_DOC
427 namespace Detail
428 {
429 ZIVID_CORE_EXPORT void waitUntilProcessingIsComplete(const UnorganizedPointCloud &unorganizedPointCloud);
430 } // namespace Detail
431#endif
432
433#ifndef NO_DOC
434# define ZIVID_UNORGANIZED_PC_EXTERN(Format) \
435 extern template ZIVID_CORE_EXPORT DeviceArray<Format> UnorganizedPointCloud::deviceColors<Format>( \
436 StreamOrQueue) const
437
438 ZIVID_UNORGANIZED_PC_EXTERN(ColorRGBA);
439 ZIVID_UNORGANIZED_PC_EXTERN(ColorRGBA_SRGB);
440 ZIVID_UNORGANIZED_PC_EXTERN(ColorBGRA);
441 ZIVID_UNORGANIZED_PC_EXTERN(ColorBGRA_SRGB);
442 ZIVID_UNORGANIZED_PC_EXTERN(ColorRGBAf);
443# undef ZIVID_UNORGANIZED_PC_EXTERN
444#endif
445} // namespace Zivid
#define ZIVID_CORE_EXPORT
Definition CoreExport.h:56
One-dimensional container of data.
Definition Array1D.h:72
Reference-counted handle to data on a GPU device.
Definition DeviceArray.h:94
Point cloud with x, y, z, RGB color and SNR laid out as a linear list of only valid points.
Definition UnorganizedPointCloud.h:75
ZIVID_CORE_EXPORT Array1D< PointXYZW > copyPointsXYZW() const
Array1D of point coordinates in 4D.
ZIVID_CORE_EXPORT UnorganizedPointCloud paintedUniformColor(const Zivid::ColorRGBA &color) const
Create a clone of this point cloud with all points colored according to the given value.
ZIVID_CORE_EXPORT std::optional< PointXYZ > centroid() const
Get the centroid of the point cloud, i.e. average of all XYZ point positions.
ZIVID_CORE_EXPORT Array1D< SNR > copySNRs() const
Get the SNR data of every point.
ZIVID_CORE_EXPORT Array1D< ColorRGBA > copyColorsRGBA() const
Get the color data of every point on 8-bit RGBA format.
ZIVID_CORE_EXPORT std::string toString() const
Get string representation of the point cloud.
ZIVID_CORE_EXPORT UnorganizedPointCloud clone() const
Returns a clone of the point cloud. The clone will include a copy of all of the point cloud data on t...
ZIVID_CORE_EXPORT UnorganizedPointCloud extended(const UnorganizedPointCloud &other) const
Create a new point cloud containing the combined data of this point cloud and another.
ZIVID_CORE_EXPORT UnorganizedPointCloud & center()
Translate the point cloud in-place so that its centroid lands at the origin (0,0,0)
ZIVID_CORE_EXPORT Array1D< ColorRGBA_SRGB > copyColorsRGBA_SRGB() const
Get the color data of every point on 8-bit RGBA format in the sRGB color space.
Array1D< DataFormat > copyData() const
Array1D with point cloud data using specified DataFormat.
Definition UnorganizedPointCloud.h:280
ZIVID_CORE_EXPORT UnorganizedPointCloud & transform(const Zivid::Matrix4x4 &matrix)
Transform the point cloud in-place by the given 4x4 transformation matrix.
ZIVID_CORE_EXPORT UnorganizedPointCloud voxelDownsampled(float voxelSize, int minPointsPerVoxel) const
Create a new point cloud that is a voxel downsampling of this point cloud.
void copyData(DataFormat *destination) const
Copy data in the specified DataFormat to a destination buffer.
Definition UnorganizedPointCloud.h:339
ZIVID_CORE_EXPORT DeviceArray< PointXYZ > devicePointsXYZ(StreamOrQueue streamOrQueue) const
Get a device buffer containing XYZ point coordinates, synced to the user's stream/queue.
ZIVID_CORE_EXPORT size_t size() const
Get the size of the point cloud (total number of points)
ZIVID_CORE_EXPORT UnorganizedPointCloud transformed(const Zivid::Matrix4x4 &matrix) const
Transform the point cloud by the given 4x4 transformation matrix.
ZIVID_CORE_EXPORT DeviceArray< PointXYZW > devicePointsXYZW(StreamOrQueue streamOrQueue) const
Get a device buffer containing XYZW point coordinates, synced to the user's stream/queue.
ZIVID_CORE_EXPORT UnorganizedPointCloud & paintUniformColor(const Zivid::ColorRGBA &color)
Set point cloud colors in-place according to the given value.
ZIVID_CORE_EXPORT UnorganizedPointCloud & extend(const UnorganizedPointCloud &other)
Extend this point cloud in-place by adding the points from another point cloud.
ZIVID_CORE_EXPORT DeviceArray< SNR > deviceSNRs(StreamOrQueue streamOrQueue) const
Get a device buffer containing SNR values, synced to the user's stream/queue.
ZIVID_CORE_EXPORT Array1D< ColorBGRA > copyColorsBGRA() const
Get the color data of every point on 8-bit BGRA format.
ZIVID_CORE_EXPORT Array1D< PointXYZ > copyPointsXYZ() const
Get the XYZ data of every point.
ZIVID_CORE_EXPORT Array1D< ColorBGRA_SRGB > copyColorsBGRA_SRGB() const
Get the color data of every point on 8-bit BGRA format in the sRGB color space.
ZIVID_CORE_EXPORT UnorganizedPointCloud()
Create an empty point cloud.
DeviceArray< ColorFormat > deviceColors(StreamOrQueue streamOrQueue) const
Get a device buffer containing color data in the specified format, synced to the user's stream/queue.
Definition EnvironmentInfo.h:74
The main Zivid namespace. All Zivid code is found here.
Definition Application.h:85
ColorSRGB ColorRGBA_SRGB
Color with 8-bit red, green, blue and alpha channels in the sRGB color space.
Definition Color.h:93
Matrix< float, 4, 4 > Matrix4x4
Matrix of size 4x4 containing floats.
Definition Matrix.h:329
std::ostream & operator<<(std::ostream &stream, const Array1D< T > &array)
Serialize array information to a stream.
Definition Array1D.h:183
Color with 8-bit red, green, blue and alpha channels.
Definition Color.h:189
A user CUDA stream or OpenCL command queue, selected by which member is populated.
Definition ComputeWrappers.h:106