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
geom
ellipses
EllipticityBase.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
25
#ifndef LSST_AFW_GEOM_ELLIPSES_EllipticityBase_h_INCLUDED
26
#define LSST_AFW_GEOM_ELLIPSES_EllipticityBase_h_INCLUDED
27
28
#include "Eigen/Core"
29
#include <complex>
30
31
namespace
lsst {
namespace
afw {
namespace
geom {
namespace
ellipses {
32
33
namespace
detail {
34
42
class
EllipticityBase
{
43
public
:
44
45
typedef
Eigen::Matrix2d
Jacobian
;
46
47
enum
ParameterEnum
{
E1
=0,
E2
=1 };
48
49
std::complex<double> &
getComplex
() {
return
_complex
; }
50
51
std::complex<double>
const
&
getComplex
()
const
{
return
_complex
; }
52
53
void
setComplex
(std::complex<double>
const
& v) {
_complex
= v; }
54
55
double
getE1
()
const
{
return
_complex
.real(); }
56
void
setE1
(
double
e1) {
57
#if __cplusplus < 201103L
58
_complex
= std::complex<double>(e1,
_complex
.imag());
59
#else
60
_complex
.real(e1);
61
#endif
62
}
63
64
double
getE2
()
const
{
return
_complex
.imag(); }
65
void
setE2
(
double
e2) {
66
#if __cplusplus < 201103L
67
_complex
= std::complex<double>(
_complex
.real(), e2);
68
#else
69
_complex
.imag(e2);
70
#endif
71
}
72
73
double
getE
()
const
{
return
std::sqrt(
std::norm
(
_complex
)); }
74
void
setE
(
double
e) {
_complex
*= e /
getE
(); }
75
76
double
getTheta
()
const
{
return
0.5 * std::arg(
_complex
); }
77
78
protected
:
79
80
explicit
EllipticityBase
(std::complex<double>
const
& complex) :
_complex
(complex) {}
81
82
explicit
EllipticityBase
(
double
e1=0.0,
double
e2=0.0) :
_complex
(e1, e2) {}
83
84
std::complex<double>
_complex
;
85
};
86
87
}
// namespace detail
88
89
}}}}
// namespace lsst::afw::geom::ellipses
90
91
#endif // !LSST_AFW_GEOM_ELLIPSES_EllipticityBase_h_INCLUDED
lsst::afw::geom::ellipses::detail::EllipticityBase::setE1
void setE1(double e1)
Definition:
EllipticityBase.h:56
lsst::afw::geom::ellipses::detail::EllipticityBase::getComplex
std::complex< double > & getComplex()
Definition:
EllipticityBase.h:49
lsst::afw::geom::ellipses::detail::EllipticityBase::setE2
void setE2(double e2)
Definition:
EllipticityBase.h:65
lsst::afw::geom::ellipses::detail::EllipticityBase::EllipticityBase
EllipticityBase(double e1=0.0, double e2=0.0)
Definition:
EllipticityBase.h:82
lsst::afw::math::details::norm
T norm(const T &x)
Definition:
Integrate.h:191
lsst::afw::geom::ellipses::detail::EllipticityBase::getComplex
std::complex< double > const & getComplex() const
Definition:
EllipticityBase.h:51
lsst::afw::geom::ellipses::detail::EllipticityBase::setComplex
void setComplex(std::complex< double > const &v)
Definition:
EllipticityBase.h:53
lsst::afw::geom::ellipses::detail::EllipticityBase::ParameterEnum
ParameterEnum
Definition:
EllipticityBase.h:47
lsst::afw::geom::ellipses::detail::EllipticityBase::getTheta
double getTheta() const
Definition:
EllipticityBase.h:76
lsst::afw::geom::ellipses::detail::EllipticityBase::getE2
double getE2() const
Definition:
EllipticityBase.h:64
lsst::afw::geom::ellipses::detail::EllipticityBase::Jacobian
Eigen::Matrix2d Jacobian
Definition:
EllipticityBase.h:45
lsst::afw::geom::ellipses::detail::EllipticityBase::setE
void setE(double e)
Definition:
EllipticityBase.h:74
lsst::afw::geom::ellipses::detail::EllipticityBase::getE1
double getE1() const
Definition:
EllipticityBase.h:55
lsst::afw::geom::ellipses::detail::EllipticityBase::EllipticityBase
EllipticityBase(std::complex< double > const &complex)
Definition:
EllipticityBase.h:80
lsst::afw::geom::ellipses::detail::EllipticityBase::_complex
std::complex< double > _complex
Definition:
EllipticityBase.h:84
lsst::afw::geom::ellipses::detail::EllipticityBase
EllipticityBase is a base class for complex ellipticity types.
Definition:
EllipticityBase.h:42
lsst::afw::geom::ellipses::detail::EllipticityBase::E2
Definition:
EllipticityBase.h:47
lsst::afw::geom::ellipses::detail::EllipticityBase::E1
Definition:
EllipticityBase.h:47
lsst::afw::geom::ellipses::detail::EllipticityBase::getE
double getE() const
Definition:
EllipticityBase.h:73
Generated on Thu Sep 24 2015 02:29:14 for LSSTApplications by
1.8.5