/* * Copyright 2020,2021 Free Software Foundation, Inc. * * This file is part of GNU Radio * * SPDX-License-Identifier: GPL-3.0-or-later * */ /***********************************************************************************/ /* This file is automatically generated using bindtool and can be manually edited */ /* The following lines can be configured to regenerate this file during cmake */ /* If manual edits are made, the following tags should be modified accordingly. */ /* BINDTOOL_GEN_AUTOMATIC(0) */ /* BINDTOOL_USE_PYGCCXML(0) */ /* BINDTOOL_HEADER_FILE(window.h) */ /* BINDTOOL_HEADER_FILE_HASH(a44a323c53d5dd52382d240afdd4b984) */ /***********************************************************************************/ #include <pybind11/complex.h> #include <pybind11/pybind11.h> #include <pybind11/stl.h> namespace py = pybind11; #include <gnuradio/fft/window.h> // pydoc.h is automatically generated in the build directory #include <window_pydoc.h> void bind_window(py::module& m) { using window = gr::fft::window; py::class_<window, std::shared_ptr<window>> window_class(m, "window", D(window)); py::enum_<gr::fft::window::win_type>(window_class, "win_type") .value("WIN_HAMMING", gr::fft::window::WIN_HAMMING) // 0 .value("WIN_HANN", gr::fft::window::WIN_HANN) // 1 .value("WIN_HANNING", gr::fft::window::WIN_HANNING) // 1 .value("WIN_BLACKMAN", gr::fft::window::WIN_BLACKMAN) // 2 .value("WIN_RECTANGULAR", gr::fft::window::WIN_RECTANGULAR) // 3 .value("WIN_KAISER", gr::fft::window::WIN_KAISER) // 4 .value("WIN_BLACKMAN_hARRIS", gr::fft::window::WIN_BLACKMAN_hARRIS) // 5 .value("WIN_BLACKMAN_HARRIS", gr::fft::window::WIN_BLACKMAN_HARRIS) // 5 .value("WIN_BARTLETT", gr::fft::window::WIN_BARTLETT) // 6 .value("WIN_FLATTOP", gr::fft::window::WIN_FLATTOP) // 7 .value("WIN_NUTTALL", gr::fft::window::WIN_NUTTALL) // 8 .value("WIN_BLACKMAN_NUTTALL", gr::fft::window::WIN_BLACKMAN_NUTTALL) // 8 .value("WIN_NUTTALL_CFD", gr::fft::window::WIN_NUTTALL_CFD) // 9 .value("WIN_WELCH", gr::fft::window::WIN_WELCH) // 10 .value("WIN_PARZEN", gr::fft::window::WIN_PARZEN) // 11 .value("WIN_EXPONENTIAL", gr::fft::window::WIN_EXPONENTIAL) // 12 .value("WIN_RIEMANN", gr::fft::window::WIN_RIEMANN) // 13 .value("WIN_GAUSSIAN", gr::fft::window::WIN_GAUSSIAN) // 14 .value("WIN_TUKEY", gr::fft::window::WIN_TUKEY) // 15 .export_values(); py::implicitly_convertible<int, gr::fft::window::win_type>(); window_class .def_static("max_attenuation", &window::max_attenuation, py::arg("type"), py::arg("param") = 6.7599999999999998, D(window, max_attenuation)) .def_static("coswindow", (std::vector<float>(*)(int, float, float, float)) & window::coswindow, py::arg("ntaps"), py::arg("c0"), py::arg("c1"), py::arg("c2"), D(window, coswindow, 0)) .def_static("coswindow", (std::vector<float>(*)(int, float, float, float, float)) & window::coswindow, py::arg("ntaps"), py::arg("c0"), py::arg("c1"), py::arg("c2"), py::arg("c3"), D(window, coswindow, 1)) .def_static("coswindow", (std::vector<float>(*)(int, float, float, float, float, float)) & window::coswindow, py::arg("ntaps"), py::arg("c0"), py::arg("c1"), py::arg("c2"), py::arg("c3"), py::arg("c4"), D(window, coswindow, 2)) .def_static( "rectangular", &window::rectangular, py::arg("ntaps"), D(window, rectangular)) .def_static("hamming", &window::hamming, py::arg("ntaps"), D(window, hamming)) .def_static("hann", &window::hann, py::arg("ntaps"), D(window, hann)) .def_static("hanning", &window::hanning, py::arg("ntaps"), D(window, hanning)) .def_static("blackman", &window::blackman, py::arg("ntaps"), D(window, blackman)) .def_static( "blackman2", &window::blackman2, py::arg("ntaps"), D(window, blackman2)) .def_static( "blackman3", &window::blackman3, py::arg("ntaps"), D(window, blackman3)) .def_static( "blackman4", &window::blackman4, py::arg("ntaps"), D(window, blackman4)) .def_static("blackman_harris", &window::blackman_harris, py::arg("ntaps"), py::arg("atten") = 92, D(window, blackman_harris)) .def_static("blackmanharris", &window::blackmanharris, py::arg("ntaps"), py::arg("atten") = 92, D(window, blackmanharris)) .def_static("nuttall", &window::nuttall, py::arg("ntaps"), D(window, nuttall)) .def_static("nuttal", &window::nuttal, py::arg("ntaps"), D(window, nuttal)) .def_static("blackman_nuttall", &window::blackman_nuttall, py::arg("ntaps"), D(window, blackman_nuttall)) .def_static("blackman_nuttal", &window::blackman_nuttal, py::arg("ntaps"), D(window, blackman_nuttal)) .def_static( "nuttall_cfd", &window::nuttall_cfd, py::arg("ntaps"), D(window, nuttall_cfd)) .def_static( "nuttal_cfd", &window::nuttal_cfd, py::arg("ntaps"), D(window, nuttal_cfd)) .def_static("flattop", &window::flattop, py::arg("ntaps"), D(window, flattop)) .def_static("kaiser", &window::kaiser, py::arg("ntaps"), py::arg("beta"), D(window, kaiser)) .def_static("bartlett", &window::bartlett, py::arg("ntaps"), D(window, bartlett)) .def_static("welch", &window::welch, py::arg("ntaps"), D(window, welch)) .def_static("parzen", &window::parzen, py::arg("ntaps"), D(window, parzen)) .def_static("exponential", &window::exponential, py::arg("ntaps"), py::arg("d"), D(window, exponential)) .def_static("riemann", &window::riemann, py::arg("ntaps"), D(window, riemann)) .def_static( "tukey", &window::tukey, py::arg("ntaps"), py::arg("alpha"), D(window, tukey)) .def_static("gaussian", &window::gaussian, py::arg("ntaps"), py::arg("sigma"), D(window, gaussian)) .def_static("build", &window::build, py::arg("type"), py::arg("ntaps"), py::arg("param") = 6.76, py::arg("normalize") = false, D(window, build)) ; }