PCL
MultiscaleLinearTransform.h
Go to the documentation of this file.
1
// ____ ______ __
2
// / __ \ / ____// /
3
// / /_/ // / / /
4
// / ____// /___ / /___ PixInsight Class Library
5
// /_/ \____//_____/ PCL 2.6.5
6
// ----------------------------------------------------------------------------
7
// pcl/MultiscaleLinearTransform.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_MultiscaleLinearTransform_h
53
#define __PCL_MultiscaleLinearTransform_h
54
56
57
#include <
pcl/Defs.h
>
58
#include <pcl/Diagnostics.h>
59
60
#include <
pcl/RedundantMultiscaleTransform.h
>
61
62
namespace
pcl
63
{
64
65
// ----------------------------------------------------------------------------
66
99
class
PCL_CLASS
MultiscaleLinearTransform
:
public
RedundantMultiscaleTransform
100
{
101
public
:
102
106
using
layer
=
RedundantMultiscaleTransform::layer
;
107
111
using
transform
=
RedundantMultiscaleTransform::transform
;
112
116
using
layer_state_set
=
RedundantMultiscaleTransform::layer_state_set
;
117
148
MultiscaleLinearTransform
(
int
n = 4,
int
d = 0,
bool
useMeanFilters =
false
)
149
:
RedundantMultiscaleTransform
( n, d )
150
, m_useMeanFilters( useMeanFilters )
151
{
152
}
153
157
MultiscaleLinearTransform
(
const
MultiscaleLinearTransform
& ) =
default
;
158
162
MultiscaleLinearTransform
(
MultiscaleLinearTransform
&& ) =
default
;
163
168
~MultiscaleLinearTransform
()
override
169
{
170
}
171
175
MultiscaleLinearTransform
& operator =(
const
MultiscaleLinearTransform
& ) =
default
;
176
180
MultiscaleLinearTransform
& operator =(
MultiscaleLinearTransform
&& ) =
default
;
181
186
bool
UsesMeanFilters
()
const
187
{
188
return
m_useMeanFilters;
189
}
190
195
bool
UsesGaussianFilters
()
const
196
{
197
return
!m_useMeanFilters;
198
}
199
200
protected
:
201
202
/*
203
* Whether we should use mean (block average) or Gaussian separable filters.
204
*/
205
bool
m_useMeanFilters =
false
;
206
207
/*
208
* Transform (decomposition)
209
*/
210
void
Transform(
const
pcl::Image
& )
override
;
211
void
Transform(
const
pcl::DImage
& )
override
;
212
void
Transform(
const
pcl::ComplexImage
& )
override
;
213
void
Transform(
const
pcl::DComplexImage
& )
override
;
214
void
Transform(
const
pcl::UInt8Image
& )
override
;
215
void
Transform(
const
pcl::UInt16Image
& )
override
;
216
void
Transform(
const
pcl::UInt32Image
& )
override
;
217
218
friend
class
MLTDecomposition;
219
};
220
221
// ----------------------------------------------------------------------------
222
223
}
// pcl
224
225
#endif // __PCL_MultiscaleLinearTransform_h
226
227
// ----------------------------------------------------------------------------
228
// EOF pcl/MultiscaleLinearTransform.h - Released 2024-01-13T15:47:58Z
pcl::RedundantMultiscaleTransform
Base class of all redundant multiscale transforms.
Definition:
RedundantMultiscaleTransform.h:102
pcl::MultiscaleLinearTransform::UsesMeanFilters
bool UsesMeanFilters() const
Definition:
MultiscaleLinearTransform.h:186
pcl
PCL root namespace.
Definition:
AbstractImage.h:76
pcl::RedundantMultiscaleTransform::transform
Array< layer > transform
Definition:
RedundantMultiscaleTransform.h:115
pcl::RedundantMultiscaleTransform::layer
Image layer
Definition:
RedundantMultiscaleTransform.h:110
pcl::MultiscaleLinearTransform::~MultiscaleLinearTransform
~MultiscaleLinearTransform() override
Definition:
MultiscaleLinearTransform.h:168
pcl::RedundantMultiscaleTransform::layer_state_set
GenericVector< bool > layer_state_set
Definition:
RedundantMultiscaleTransform.h:120
pcl::MultiscaleLinearTransform::MultiscaleLinearTransform
MultiscaleLinearTransform(int n=4, int d=0, bool useMeanFilters=false)
Definition:
MultiscaleLinearTransform.h:148
RedundantMultiscaleTransform.h
pcl::MultiscaleLinearTransform
A redundant multiscale transform using separable convolutions.
Definition:
MultiscaleLinearTransform.h:99
pcl::Array< layer >
pcl::MultiscaleLinearTransform::UsesGaussianFilters
bool UsesGaussianFilters() const
Definition:
MultiscaleLinearTransform.h:195
Defs.h
pcl::GenericVector< bool >
pcl::GenericImage
Implements a generic, two-dimensional, shared or local image.
Definition:
Image.h:277
MultiscaleLinearTransform.h
Generated on Sun Jan 14 2024 20:52:44 for PCL by
1.8.17