LSSTApplications
20.0.0
LSSTDataManagementBasePackage
stack
1a1d771
Linux64
geom
20.0.0
src
polynomials
PolynomialFunction1d.cc
Go to the documentation of this file.
1
// -*- LSST-C++ -*-
2
/*
3
* Developed for the LSST Data Management System.
4
* This product includes software developed by the LSST Project
5
* (https://www.lsst.org).
6
* See the COPYRIGHT file at the top-level directory of this distribution
7
* for details of code ownership.
8
*
9
* This program is free software: you can redistribute it and/or modify
10
* it under the terms of the GNU General Public License as published by
11
* the Free Software Foundation, either version 3 of the License, or
12
* (at your option) any later version.
13
*
14
* This program is distributed in the hope that it will be useful,
15
* but WITHOUT ANY WARRANTY; without even the implied warranty of
16
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17
* GNU General Public License for more details.
18
*
19
* You should have received a copy of the GNU General Public License
20
* along with this program. If not, see <https://www.gnu.org/licenses/>.
21
*/
22
23
#include <vector>
24
25
#include "
lsst/geom/polynomials/PolynomialFunction1d.h
"
26
#include "
lsst/geom/polynomials/BinomialMatrix.h
"
27
#include "
lsst/geom/polynomials/SafeSum.h
"
28
29
30
namespace
lsst
{
namespace
geom
{
namespace
polynomials {
31
32
PolynomialFunction1d
simplified
(
ScaledPolynomialFunction1d
const
& f) {
33
auto
const
&
basis
= f.
getBasis
();
34
std::vector<SafeSum<double>
> sums(
basis
.size());
35
double
const
s =
basis
.getScaling().getScale();
36
double
const
v =
basis
.getScaling().getShift();
37
double
sn = 1;
// s^n
38
BinomialMatrix
binomial(
basis
.getNested().getOrder());
39
for
(
std::size_t
n = 0; n <
basis
.size(); ++n, sn *= s) {
40
double
vk = 1;
// v^k
41
for
(
std::size_t
k = 0; k <= n; ++k, vk *= v) {
42
sums[n - k] += sn*binomial(n, k)*f[n]*vk;
43
}
44
}
45
Eigen::VectorXd
result
= Eigen::VectorXd::Zero(
basis
.size());
46
for
(
std::size_t
n = 0; n <
basis
.size(); ++n) {
47
result
[n] =
static_cast<
double
>
(sums[n]);
48
}
49
return
makeFunction1d
(
basis
.getNested(),
result
);
50
}
51
52
}}}
// namespace lsst::geom::polynomials
lsst::geom::polynomials::BinomialMatrix
A class that computes binomial coefficients up to a certain power.
Definition:
BinomialMatrix.h:45
SafeSum.h
std::vector
STL class.
PolynomialFunction1d.h
lsst::geom::polynomials::simplified
PolynomialFunction1d simplified(ScaledPolynomialFunction1d const &f)
Calculate the standard polynomial function that is equivalent to a scaled standard polynomial functio...
Definition:
PolynomialFunction1d.cc:32
basis
table::Key< table::Array< double > > basis
Definition:
PsfexPsf.cc:361
lsst::geom::polynomials::Function1d
A 1-d function defined by a series expansion and its coefficients.
Definition:
Function1d.h:42
result
py::object result
Definition:
_schema.cc:429
lsst
A base class for image defects.
Definition:
imageAlgorithm.dox:1
lsst::geom
Definition:
geomOperators.dox:4
std::size_t
lsst::geom::polynomials::Function1d::getBasis
Basis const & getBasis() const
Return the associated Basis1d object.
Definition:
Function1d.h:98
lsst::geom::polynomials::makeFunction1d
Function1d< Basis > makeFunction1d(Basis const &basis, Eigen::VectorXd const &coefficients)
Create a Function1d of the appropriate type from a Basis1d and an Eigen object containing coefficient...
Definition:
Function1d.h:144
BinomialMatrix.h
Generated on Wed Jun 24 2020 18:10:06 for LSSTApplications by
1.8.18