LSST Applications g0f08755f38+82efc23009,g12f32b3c4e+e7bdf1200e,g1653933729+a8ce1bb630,g1a0ca8cf93+50eff2b06f,g28da252d5a+52db39f6a5,g2bbee38e9b+37c5a29d61,g2bc492864f+37c5a29d61,g2cdde0e794+c05ff076ad,g3156d2b45e+41e33cbcdc,g347aa1857d+37c5a29d61,g35bb328faa+a8ce1bb630,g3a166c0a6a+37c5a29d61,g3e281a1b8c+fb992f5633,g414038480c+7f03dfc1b0,g41af890bb2+11b950c980,g5fbc88fb19+17cd334064,g6b1c1869cb+12dd639c9a,g781aacb6e4+a8ce1bb630,g80478fca09+72e9651da0,g82479be7b0+04c31367b4,g858d7b2824+82efc23009,g9125e01d80+a8ce1bb630,g9726552aa6+8047e3811d,ga5288a1d22+e532dc0a0b,gae0086650b+a8ce1bb630,gb58c049af0+d64f4d3760,gc28159a63d+37c5a29d61,gcf0d15dbbd+2acd6d4d48,gd7358e8bfb+778a810b6e,gda3e153d99+82efc23009,gda6a2b7d83+2acd6d4d48,gdaeeff99f8+1711a396fd,ge2409df99d+6b12de1076,ge79ae78c31+37c5a29d61,gf0baf85859+d0a5978c5a,gf3967379c6+4954f8c433,gfb92a5be7c+82efc23009,gfec2e1e490+2aaed99252,w.2024.46
LSST Data Management Base Package
Loading...
Searching...
No Matches
_chebyshevBoundedField.py
Go to the documentation of this file.
1# This file is part of afw.
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
22import numpy as np
23
24from lsst.utils import continueClass
25from ._math import ChebyshevBoundedField, ChebyshevBoundedFieldControl
26
27__all__ = [] # import this module only for its side effects
28
29
30@continueClass
31class ChebyshevBoundedField: # noqa: F811
32 @classmethod
33 def approximate(cls, boundedField,
34 orderX=3, orderY=3,
35 nStepX=100, nStepY=100):
36 """
37 Approximate a bounded field as a ChebyshevBoundedField.
38
39 Parameters
40 ----------
41 boundedField : `lsst.afw.math.BoundedField`
42 A bounded field to approximate
43 orderX : `int`, optional
44 Order of the Chebyshev polynomial in the x direction.
45 Default is 3.
46 orderY : `int`, optional
47 Order of the Chebyshev polynomial in the y direction.
48 Default is 3.
49 nStepX : `int`, optional
50 Number of x steps to approximate boundedField.
51 Default is 100.
52 nStepY : `int`, optional
53 Number of y steps to approximate boundedField.
54 Default is 100.
55
56 Returns
57 -------
58 chebyshevBoundedField : `lsst.afw.math.ChebyshevBoundedField`
59 """
60
61 ctrl = ChebyshevBoundedFieldControl()
62 ctrl.orderX = orderX
63 ctrl.orderY = orderY
64 ctrl.triangular = False
65
66 bbox = boundedField.getBBox()
67
68 xSteps = np.linspace(bbox.getMinX(), bbox.getMaxX(), nStepX)
69 ySteps = np.linspace(bbox.getMinY(), bbox.getMaxY(), nStepY)
70
71 x = np.tile(xSteps, nStepY)
72 y = np.repeat(ySteps, nStepX)
73
74 return cls.fit(bbox, x, y, boundedField.evaluate(x, y), ctrl)
approximate(cls, boundedField, orderX=3, orderY=3, nStepX=100, nStepY=100)