LSSTApplications  16.0-10-g0ee56ad+5,16.0-11-ga33d1f2+5,16.0-12-g3ef5c14+3,16.0-12-g71e5ef5+18,16.0-12-gbdf3636+3,16.0-13-g118c103+3,16.0-13-g8f68b0a+3,16.0-15-gbf5c1cb+4,16.0-16-gfd17674+3,16.0-17-g7c01f5c+3,16.0-18-g0a50484+1,16.0-20-ga20f992+8,16.0-21-g0e05fd4+6,16.0-21-g15e2d33+4,16.0-22-g62d8060+4,16.0-22-g847a80f+4,16.0-25-gf00d9b8+1,16.0-28-g3990c221+4,16.0-3-gf928089+3,16.0-32-g88a4f23+5,16.0-34-gd7987ad+3,16.0-37-gc7333cb+2,16.0-4-g10fc685+2,16.0-4-g18f3627+26,16.0-4-g5f3a788+26,16.0-5-gaf5c3d7+4,16.0-5-gcc1f4bb+1,16.0-6-g3b92700+4,16.0-6-g4412fcd+3,16.0-6-g7235603+4,16.0-69-g2562ce1b+2,16.0-8-g14ebd58+4,16.0-8-g2df868b+1,16.0-8-g4cec79c+6,16.0-8-gadf6c7a+1,16.0-8-gfc7ad86,16.0-82-g59ec2a54a+1,16.0-9-g5400cdc+2,16.0-9-ge6233d7+5,master-g2880f2d8cf+3,v17.0.rc1
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