LSSTApplications  11.0-13-gbb96280,12.1.rc1,12.1.rc1+1,12.1.rc1+2,12.1.rc1+5,12.1.rc1+8,12.1.rc1-1-g06d7636+1,12.1.rc1-1-g253890b+5,12.1.rc1-1-g3d31b68+7,12.1.rc1-1-g3db6b75+1,12.1.rc1-1-g5c1385a+3,12.1.rc1-1-g83b2247,12.1.rc1-1-g90cb4cf+6,12.1.rc1-1-g91da24b+3,12.1.rc1-2-g3521f8a,12.1.rc1-2-g39433dd+4,12.1.rc1-2-g486411b+2,12.1.rc1-2-g4c2be76,12.1.rc1-2-gc9c0491,12.1.rc1-2-gda2cd4f+6,12.1.rc1-3-g3391c73+2,12.1.rc1-3-g8c1bd6c+1,12.1.rc1-3-gcf4b6cb+2,12.1.rc1-4-g057223e+1,12.1.rc1-4-g19ed13b+2,12.1.rc1-4-g30492a7
LSSTDataManagementBasePackage
Function.cc
Go to the documentation of this file.
1 /*
2  * LSST Data Management System
3  * Copyright 2008, 2009, 2010 LSST Corporation.
4  *
5  * This product includes software developed by the
6  * LSST Project (http://www.lsst.org/).
7  *
8  * This program is free software: you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation, either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the LSST License Statement and
19  * the GNU General Public License along with this program. If not,
20  * see <http://www.lsstcorp.org/LegalNotices/>.
21  */
22 
28 
29 namespace afwMath = lsst::afw::math;
30 
35 template<typename ReturnT>
36 std::vector<double> afwMath::PolynomialFunction2<ReturnT>::getDFuncDParameters(double x, double y) const {
37  std::vector<double> coeffs(this->getNParameters());
38 
39  //
40  // Go through params order by order, evaluating x^r y^s; we do this by first evaluating
41  // y^s for a complete order, then going through again multiplying by x^r
42  //
43  int i0 = 0; // starting index for this order's coefficients
44  for (int order = 0; order <= this->_order; ++order) {
45  coeffs[i0] = 1;
46  double zn = y; // y^s
47  for (int i = 1; i <= order; ++i) {
48  coeffs[i0 + i] = zn;
49  zn *= y;
50  }
51 
52  zn = x; // x^r
53  for (int i = order - 1; i >= 0; --i) {
54  coeffs[i0 + i] *= zn;
55  zn *= x;
56  }
57 
58 
59  i0 += order + 1;
60  }
61 
62  assert (i0 == static_cast<int>(coeffs.size()));
63 
64  return coeffs;
65 }
66 
67 /************************************************************************************************************/
69 #define INSTANTIATE(TYPE) \
70  template std::vector<double> \
71  afwMath::PolynomialFunction2<TYPE>::getDFuncDParameters(double x, double y) const
72 
73 INSTANTIATE(double);
74 INSTANTIATE(float);
int y
Define a collection of useful Functions.
virtual std::vector< double > getDFuncDParameters(double x, double y) const
Definition: Function.cc:36
#define INSTANTIATE(T)
double x