LSST Applications g1653933729+34a971ddd9,g1a997c3884+34a971ddd9,g28da252d5a+e9c12036e6,g2bbee38e9b+387d105147,g2bc492864f+387d105147,g2ca4be77d2+2af33ed832,g2cdde0e794+704103fe75,g3156d2b45e+6e87dc994a,g347aa1857d+387d105147,g35bb328faa+34a971ddd9,g3a166c0a6a+387d105147,g3bc1096a96+da0d0eec6b,g3e281a1b8c+8ec26ec694,g4005a62e65+ba0306790b,g414038480c+9f5be647b3,g41af890bb2+260fbe2614,g5065538af8+ba676e4b71,g5a0bb5165c+019e928339,g717e5f8c0f+90540262f6,g80478fca09+bbe9b7c29a,g8204df1d8d+90540262f6,g82479be7b0+c8d705dbd9,g858d7b2824+90540262f6,g9125e01d80+34a971ddd9,g91f4dbe722+fd1343598d,ga5288a1d22+cbf2f5b209,gae0086650b+34a971ddd9,gb58c049af0+ace264a4f2,gc28159a63d+387d105147,gcf0d15dbbd+c403bb023e,gd6b7c0dfd1+f7139e6704,gda6a2b7d83+c403bb023e,gdaeeff99f8+7774323b41,ge2409df99d+d3bbf40f76,ge33fd446bb+90540262f6,ge79ae78c31+387d105147,gf0baf85859+890af219f9,gf5289d68f6+d7e5a322af,w.2024.37
LSST Data Management Base Package
Loading...
Searching...
No Matches
sersicmix.cc
Go to the documentation of this file.
1/*
2 * This file is part of gauss2d_fit.
3 *
4 * Developed for the LSST Source Management System.
5 * This product includes software developed by the LSST Project
6 * (https://www.lsst.org).
7 * See the COPYRIGHT file at the top-level directory of this distribution
8 * for details of code ownership.
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 GNU General Public License
21 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 */
23
24#include <pybind11/attr.h>
25#include <pybind11/pybind11.h>
26#include <pybind11/stl.h>
27
28#include <memory>
29
31
32#include "pybind11.h"
33
34namespace py = pybind11;
35using namespace pybind11::literals;
36
37namespace g2f = lsst::gauss2d::fit;
38
39void bind_sersicmix(py::module &m) {
40 auto _is = py::class_<g2f::IntegralSize, std::shared_ptr<g2f::IntegralSize>, lsst::gauss2d::Object>(
41 m, "IntegralSize")
42 .def(py::init<const double, const double>(), "integral"_a = 0, "sigma"_a = 0)
43 .def_readonly("integral", &g2f::IntegralSize::integral)
44 .def_readonly("sigma", &g2f::IntegralSize::sigma)
45 .def("__repr__", [](const g2f::IntegralSize &self) { return self.repr(true); })
46 .def("__str__", &g2f::IntegralSize::str);
47
48 auto _smi = py::class_<g2f::SersicMixInterpolator, std::shared_ptr<g2f::SersicMixInterpolator>>(
49 m, "SersicMixInterpolator");
50
51 auto _smv
52 = py::class_<g2f::SersicMixValues, std::shared_ptr<g2f::SersicMixValues>, lsst::gauss2d::Object>(
53 m, "SersicMixValues")
54 .def(py::init<double, std::vector<g2f::IntegralSize>>(), "sersicindex"_a, "values"_a)
55 .def_readonly("sersicindex", &g2f::SersicMixValues::sersicindex)
56 .def_readonly("values", &g2f::SersicMixValues::values)
57 .def("__repr__", [](const g2f::SersicMixValues &self) { return self.repr(true); })
58 .def("__str__", &g2f::SersicMixValues::str);
59
60 m.def("sersic_mix_knots", &g2f::get_sersic_mix_knots_copy, "order"_a = g2f::SERSICMIX_ORDER_DEFAULT,
61 py::return_value_policy::copy);
62}
int m
Definition SpanSet.cc:48
A generic object from the gauss2d library.
Definition object.h:40
A pair of integral - size values for a Gaussian (sub)Component.
Definition sersicmix.h:19
A vector of IntegralSize values for a given Sersic index.
Definition sersicmix.h:55
std::vector< SersicMixValues > get_sersic_mix_knots_copy(unsigned short order)
Definition sersicmix.cc:68
void bind_sersicmix(py::module &m)
Definition sersicmix.cc:39