LSSTApplications
10.0+286,10.0+36,10.0+46,10.0-2-g4f67435,10.1+152,10.1+37,11.0,11.0+1,11.0-1-g47edd16,11.0-1-g60db491,11.0-1-g7418c06,11.0-2-g04d2804,11.0-2-g68503cd,11.0-2-g818369d,11.0-2-gb8b8ce7
LSSTDataManagementBasePackage
Main Page
Related Pages
Modules
Namespaces
Classes
Files
Examples
File List
File Members
home
lsstsw
stack
Linux64
afw
11.0-2-g04d2804
include
lsst
afw
image
ImageUtils.h
Go to the documentation of this file.
1
// -*- lsst-c++ -*-
2
3
/*
4
* LSST Data Management System
5
* Copyright 2008, 2009, 2010 LSST Corporation.
6
*
7
* This product includes software developed by the
8
* LSST Project (http://www.lsst.org/).
9
*
10
* This program is free software: you can redistribute it and/or modify
11
* it under the terms of the GNU General Public License as published by
12
* the Free Software Foundation, either version 3 of the License, or
13
* (at your option) any later version.
14
*
15
* This program is distributed in the hope that it will be useful,
16
* but WITHOUT ANY WARRANTY; without even the implied warranty of
17
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18
* GNU General Public License for more details.
19
*
20
* You should have received a copy of the LSST License Statement and
21
* the GNU General Public License along with this program. If not,
22
* see <http://www.lsstcorp.org/LegalNotices/>.
23
*/
24
32
#ifndef LSST_AFW_IMAGE_IMAGEUTILS_H
33
#define LSST_AFW_IMAGE_IMAGEUTILS_H
34
35
#include <cmath>
36
37
namespace
lsst {
38
namespace
afw {
39
namespace
image
{
40
enum
xOrY
{
X
,
Y
};
41
42
const
double
PixelZeroPos
= 0.0;
43
54
inline
double
indexToPosition
(
55
double
ind
56
) {
57
return
ind +
PixelZeroPos
;
58
}
59
69
inline
int
positionToIndex
(
70
double
pos
71
) {
72
return
static_cast<
int
>
(
std::floor
(pos + 0.5 -
PixelZeroPos
));
73
}
74
86
inline
int
positionToIndex
(
87
double
&residual,
88
double
pos
89
) {
90
double
fullIndex = pos -
PixelZeroPos
;
91
double
roundedIndex =
std::floor
(fullIndex + 0.5);
92
residual = fullIndex - roundedIndex;
93
return
static_cast<
int
>
(roundedIndex);
94
}
100
inline
std::pair<int, double>
positionToIndex
(
double
const
pos,
101
bool
102
) {
103
double
residual;
// fractional part of index
104
int
const
ind =
positionToIndex
(residual, pos);
// integral part
105
106
return
std::pair<int, double>(ind, residual);
107
}
108
109
}}}
// lsst::afw::image
110
111
#endif // LSST_AFW_IMAGE_IMAGEUTILS_H
112
lsst::afw::image::indexToPosition
double indexToPosition(double ind)
Convert image index to image position.
Definition:
ImageUtils.h:54
lsst::afw::image::positionToIndex
int positionToIndex(double pos)
Convert image position to nearest integer index.
Definition:
ImageUtils.h:69
lsst::afw::image::xOrY
xOrY
Definition:
ImageUtils.h:40
lsst::afw::image::X
Definition:
ImageUtils.h:40
lsst::afw::image::Y
Definition:
ImageUtils.h:40
image
table::Key< table::Array< Kernel::Pixel > > image
Definition:
FixedKernel.cc:117
lsst::afw::geom::floor
Extent< int, N > floor(Extent< double, N > const &input)
lsst::afw::image::PixelZeroPos
const double PixelZeroPos
FITS uses 1.0, SDSS uses 0.5, LSST uses 0.0 (http://dev.lsstcorp.org/trac/wiki/BottomLeftPixelProposa...
Definition:
ImageUtils.h:42
Generated on Thu Sep 24 2015 02:29:15 for LSSTApplications by
1.8.5