LSSTApplications  18.0.0+106,18.0.0+50,19.0.0,19.0.0+1,19.0.0+10,19.0.0+11,19.0.0+13,19.0.0+17,19.0.0+2,19.0.0-1-g20d9b18+6,19.0.0-1-g425ff20,19.0.0-1-g5549ca4,19.0.0-1-g580fafe+6,19.0.0-1-g6fe20d0+1,19.0.0-1-g7011481+9,19.0.0-1-g8c57eb9+6,19.0.0-1-gb5175dc+11,19.0.0-1-gdc0e4a7+9,19.0.0-1-ge272bc4+6,19.0.0-1-ge3aa853,19.0.0-10-g448f008b,19.0.0-12-g6990b2c,19.0.0-2-g0d9f9cd+11,19.0.0-2-g3d9e4fb2+11,19.0.0-2-g5037de4,19.0.0-2-gb96a1c4+3,19.0.0-2-gd955cfd+15,19.0.0-3-g2d13df8,19.0.0-3-g6f3c7dc,19.0.0-4-g725f80e+11,19.0.0-4-ga671dab3b+1,19.0.0-4-gad373c5+3,19.0.0-5-ga2acb9c+2,19.0.0-5-gfe96e6c+2,w.2020.01
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