LSSTApplications  17.0+11,17.0+34,17.0+56,17.0+57,17.0+59,17.0+7,17.0-1-g377950a+33,17.0.1-1-g114240f+2,17.0.1-1-g4d4fbc4+28,17.0.1-1-g55520dc+49,17.0.1-1-g5f4ed7e+52,17.0.1-1-g6dd7d69+17,17.0.1-1-g8de6c91+11,17.0.1-1-gb9095d2+7,17.0.1-1-ge9fec5e+5,17.0.1-1-gf4e0155+55,17.0.1-1-gfc65f5f+50,17.0.1-1-gfc6fb1f+20,17.0.1-10-g87f9f3f+1,17.0.1-11-ge9de802+16,17.0.1-16-ga14f7d5c+4,17.0.1-17-gc79d625+1,17.0.1-17-gdae4c4a+8,17.0.1-2-g26618f5+29,17.0.1-2-g54f2ebc+9,17.0.1-2-gf403422+1,17.0.1-20-g2ca2f74+6,17.0.1-23-gf3eadeb7+1,17.0.1-3-g7e86b59+39,17.0.1-3-gb5ca14a,17.0.1-3-gd08d533+40,17.0.1-30-g596af8797,17.0.1-4-g59d126d+4,17.0.1-4-gc69c472+5,17.0.1-6-g5afd9b9+4,17.0.1-7-g35889ee+1,17.0.1-7-gc7c8782+18,17.0.1-9-gc4bbfb2+3,w.2019.22
LSSTDataManagementBasePackage
Functions
interpolate.cc File Reference
#include <pybind11/pybind11.h>
#include <pybind11/stl.h>
#include "ndarray/pybind11.h"
#include "lsst/afw/math/Interpolate.h"

Go to the source code of this file.

Functions

 PYBIND11_MODULE (interpolate, mod)
 

Function Documentation

◆ PYBIND11_MODULE()

PYBIND11_MODULE ( interpolate  ,
mod   
)

Definition at line 36 of file interpolate.cc.

36  {
37  py::class_<Interpolate, std::shared_ptr<Interpolate>> clsInterpolate(mod, "Interpolate");
38  py::enum_<Interpolate::Style>(clsInterpolate, "Style")
39  .value("UNKNOWN", Interpolate::Style::UNKNOWN)
40  .value("CONSTANT", Interpolate::Style::CONSTANT)
41  .value("LINEAR", Interpolate::Style::LINEAR)
42  .value("NATURAL_SPLINE", Interpolate::Style::NATURAL_SPLINE)
43  .value("CUBIC_SPLINE", Interpolate::Style::CUBIC_SPLINE)
44  .value("CUBIC_SPLINE_PERIODIC", Interpolate::Style::CUBIC_SPLINE_PERIODIC)
45  .value("AKIMA_SPLINE", Interpolate::Style::AKIMA_SPLINE)
46  .value("AKIMA_SPLINE_PERIODIC", Interpolate::Style::AKIMA_SPLINE_PERIODIC)
47  .value("NUM_STYLES", Interpolate::Style::NUM_STYLES)
48  .export_values();
49 
50  clsInterpolate.def("interpolate", [](Interpolate &t, double const x) {
51  /*
52  We use a lambda function here because interpolate (with a double) is a virtual function and therefor
53  cannot be wrapped directly.
54  */
55  return t.interpolate(x);
56  });
57 
58  clsInterpolate.def("interpolate",
60  Interpolate::interpolate);
61  clsInterpolate.def(
62  "interpolate",
63  (ndarray::Array<double, 1> (Interpolate::*)(ndarray::Array<double const, 1> const &) const) &
64  Interpolate::interpolate);
65 
66  mod.def("makeInterpolate",
69  "x"_a, "y"_a, "style"_a = Interpolate::AKIMA_SPLINE);
70  mod.def("makeInterpolate", (std::shared_ptr<Interpolate>(*)(ndarray::Array<double const, 1> const &,
71  ndarray::Array<double const, 1> const &y,
72  Interpolate::Style const))makeInterpolate,
73  "x"_a, "y"_a, "style"_a = Interpolate::AKIMA_SPLINE);
74 
75  mod.def("stringToInterpStyle", stringToInterpStyle, "style"_a);
76  mod.def("lookupMaxInterpStyle", lookupMaxInterpStyle, "n"_a);
77  mod.def("lookupMinInterpPoints", lookupMinInterpPoints, "style"_a);
78 }
Interpolate::Style stringToInterpStyle(std::string const &style)
Conversion function to switch a string to an Interpolate::Style.
Definition: Interpolate.cc:257
virtual double interpolate(double const x) const =0
std::shared_ptr< Interpolate > makeInterpolate(std::vector< double > const &x, std::vector< double > const &y, Interpolate::Style const style=Interpolate::AKIMA_SPLINE)
A factory function to make Interpolate objects.
Definition: Interpolate.cc:343
int y
Definition: SpanSet.cc:49
double x
Interpolate::Style lookupMaxInterpStyle(int const n)
Get the highest order Interpolation::Style available for &#39;n&#39; points.
Definition: Interpolate.cc:275
int lookupMinInterpPoints(Interpolate::Style const style)
Get the minimum number of points needed to use the requested interpolation style. ...
Definition: Interpolate.cc:314