PCL
NearestNeighborInterpolation.h
Go to the documentation of this file.
1
// ____ ______ __
2
// / __ \ / ____// /
3
// / /_/ // / / /
4
// / ____// /___ / /___ PixInsight Class Library
5
// /_/ \____//_____/ PCL 2.6.5
6
// ----------------------------------------------------------------------------
7
// pcl/NearestNeighborInterpolation.h - Released 2024-01-13T15:47:58Z
8
// ----------------------------------------------------------------------------
9
// This file is part of the PixInsight Class Library (PCL).
10
// PCL is a multiplatform C++ framework for development of PixInsight modules.
11
//
12
// Copyright (c) 2003-2024 Pleiades Astrophoto S.L. All Rights Reserved.
13
//
14
// Redistribution and use in both source and binary forms, with or without
15
// modification, is permitted provided that the following conditions are met:
16
//
17
// 1. All redistributions of source code must retain the above copyright
18
// notice, this list of conditions and the following disclaimer.
19
//
20
// 2. All redistributions in binary form must reproduce the above copyright
21
// notice, this list of conditions and the following disclaimer in the
22
// documentation and/or other materials provided with the distribution.
23
//
24
// 3. Neither the names "PixInsight" and "Pleiades Astrophoto", nor the names
25
// of their contributors, may be used to endorse or promote products derived
26
// from this software without specific prior written permission. For written
27
// permission, please contact info@pixinsight.com.
28
//
29
// 4. All products derived from this software, in any form whatsoever, must
30
// reproduce the following acknowledgment in the end-user documentation
31
// and/or other materials provided with the product:
32
//
33
// "This product is based on software from the PixInsight project, developed
34
// by Pleiades Astrophoto and its contributors (https://pixinsight.com/)."
35
//
36
// Alternatively, if that is where third-party acknowledgments normally
37
// appear, this acknowledgment must be reproduced in the product itself.
38
//
39
// THIS SOFTWARE IS PROVIDED BY PLEIADES ASTROPHOTO AND ITS CONTRIBUTORS
40
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
41
// TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
42
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL PLEIADES ASTROPHOTO OR ITS
43
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
44
// EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, BUSINESS
45
// INTERRUPTION; PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; AND LOSS OF USE,
46
// DATA OR PROFITS) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
47
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
48
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
49
// POSSIBILITY OF SUCH DAMAGE.
50
// ----------------------------------------------------------------------------
51
52
#ifndef __PCL_NearestNeighborInterpolation_h
53
#define __PCL_NearestNeighborInterpolation_h
54
56
57
#include <
pcl/Defs.h
>
58
#include <pcl/Diagnostics.h>
59
60
#include <
pcl/BidimensionalInterpolation.h
>
61
#include <
pcl/Utility.h
>
62
63
namespace
pcl
64
{
65
66
// ----------------------------------------------------------------------------
67
68
#define m_width this->m_width
69
#define m_height this->m_height
70
#define m_data this->m_data
71
72
// ----------------------------------------------------------------------------
73
87
template
<
typename
T>
88
class
PCL_CLASS
NearestNeighborInterpolation
:
public
BidimensionalInterpolation
<T>
89
{
90
public
:
91
95
NearestNeighborInterpolation
() =
default
;
96
100
NearestNeighborInterpolation
(
const
NearestNeighborInterpolation
& ) =
default
;
101
107
double
operator()
(
double
x,
double
y )
const override
108
{
109
PCL_PRECONDITION( m_data !=
nullptr
)
110
PCL_PRECONDITION( m_width > 0 && m_height > 0 )
111
return
double( *(m_data + (
Range
(
RoundIntArithmetic
( y ), 0, m_height-1 )*
int64
( m_width ) +
112
Range
(
RoundIntArithmetic
( x ), 0, m_width-1 ))) );
113
}
114
};
115
116
// ----------------------------------------------------------------------------
117
118
#undef m_width
119
#undef m_height
120
#undef m_data
121
122
// ----------------------------------------------------------------------------
123
124
}
// pcl
125
126
#endif // __PCL_NearestNeighborInterpolation_h
127
128
// ----------------------------------------------------------------------------
129
// EOF pcl/NearestNeighborInterpolation.h - Released 2024-01-13T15:47:58Z
pcl
PCL root namespace.
Definition:
AbstractImage.h:76
pcl::Range
constexpr const T & Range(const T &x, const T &a, const T &b) noexcept
Definition:
Utility.h:190
Utility.h
pcl::RoundIntArithmetic
int RoundIntArithmetic(T x) noexcept
Definition:
Math.h:1586
pcl::BidimensionalInterpolation
A generic interface to two-dimensional interpolation algorithms.
Definition:
BidimensionalInterpolation.h:75
pcl::NearestNeighborInterpolation
Two-dimensional nearest neighbor interpolation algorithm.
Definition:
NearestNeighborInterpolation.h:88
BidimensionalInterpolation.h
pcl::NearestNeighborInterpolation::operator()
double operator()(double x, double y) const override
Definition:
NearestNeighborInterpolation.h:107
pcl::int64
signed long long int64
Definition:
Defs.h:679
Defs.h
NearestNeighborInterpolation.h
Generated on Sun Jan 14 2024 20:52:44 for PCL by
1.8.17