uvgVPCCenc
1.0.0
uvgVPCCenc is an open-source real-time V-PCC encoder library written in C++ from scratch.
Loading...
Searching...
No Matches
src
lib
patchGeneration
kdTree.hpp
Go to the documentation of this file.
1
/*****************************************************************************
2
* This file is part of uvgVPCCenc V-PCC encoder.
3
*
4
* Copyright (c) 2024, Tampere University, ITU/ISO/IEC, project contributors
5
* All rights reserved.
6
*
7
* Redistribution and use in source and binary forms, with or without modification,
8
* are permitted provided that the following conditions are met:
9
*
10
* * Redistributions of source code must retain the above copyright notice, this
11
* list of conditions and the following disclaimer.
12
*
13
* * Redistributions in binary form must reproduce the above copyright notice, this
14
* list of conditions and the following disclaimer in the documentation and/or
15
* other materials provided with the distribution.
16
*
17
* * Neither the name of the Tampere University or ITU/ISO/IEC nor the names of its
18
* contributors may be used to endorse or promote products derived from
19
* this software without specific prior written permission.
20
*
21
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
22
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
23
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
24
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
25
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26
* INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
27
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION HOWEVER CAUSED AND ON
28
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
* INCLUDING NEGLIGENCE OR OTHERWISE ARISING IN ANY WAY OUT OF THE USE OF THIS
31
****************************************************************************/
32
34
35
36
#pragma once
37
38
#include "
nanoflann.hpp
"
39
#include "
utils/utils.hpp
"
40
41
using namespace
uvgvpcc_enc
;
42
43
using
nanoflannAdaptorType
=
44
KDTreeVectorOfVectorsAdaptor<std::vector<uvgvpcc_enc::Vector3<typeGeometryInput>
>, double, 3,
nanoflann::metric_L2_Simple
,
size_t
>;
45
46
class
KdTree
{
47
public
:
48
KdTree
(
const
size_t
& kdTreeMaxLeafSize,
const
std::vector<
uvgvpcc_enc::Vector3<typeGeometryInput>
>& pointsGeometry);
49
void
knn
(
const
uvgvpcc_enc::Vector3<typeGeometryInput>
& queryPoint,
const
size_t
nnCount, std::vector<size_t>& nnIndices)
const
;
50
void
knnDist
(
const
uvgvpcc_enc::Vector3<typeGeometryInput>
& queryPoint,
const
size_t
nnCount,
51
std::vector<int16_t>& out_dists_sqr)
const
;
52
53
/*void knnRadius(const uvgvpcc_enc::Vector3<typeGeometryInput>& queryPoint, const int16_t maxNNCount, const uint16_t radius,
54
std::vector<size_t>& nnIndices) const;*/
55
56
private
:
57
std::unique_ptr<nanoflannAdaptorType>
const
index_;
58
};
KdTree
Definition
kdTree.hpp:46
KdTree::knnDist
void knnDist(const uvgvpcc_enc::Vector3< typeGeometryInput > &queryPoint, const size_t nnCount, std::vector< int16_t > &out_dists_sqr) const
Definition
kdTree.cpp:57
KdTree::knn
void knn(const uvgvpcc_enc::Vector3< typeGeometryInput > &queryPoint, const size_t nnCount, std::vector< size_t > &nnIndices) const
Definition
kdTree.cpp:45
uvgvpcc_enc::Vector3
Definition
utils.hpp:59
uvgvpcc_enc
Definition
log.hpp:43
nanoflann.hpp
KDTreeVectorOfVectorsAdaptor
Definition
nanoflann.hpp:2315
nanoflann::metric_L2_Simple
Definition
nanoflann.hpp:607
utils.hpp
Generated by
1.9.8