# pm-remez: Parks-McClellan Remez FIR design algorithm
[![Crates.io][crates-badge]][crates-url]
[![Rust](https://github.com/maia-sdr/pm-remez/actions/workflows/rust.yml/badge.svg)](https://github.com/maia-sdr/pm-remez/actions/workflows/rust.yml)
[![Rust Docs][docs-badge]][docs-url]
[![Python](https://github.com/maia-sdr/pm-remez/actions/workflows/maturin.yml/badge.svg)](https://github.com/maia-sdr/pm-remez/actions/workflows/maturin.yml)
[![Python Docs](https://readthedocs.org/projects/pm-remez/badge/?version=latest)](https://pm-remez.readthedocs.io/en/latest/?badge=latest)
[![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[crates-badge]: https://img.shields.io/crates/v/pm-remez
[crates-url]: https://crates.io/crates/pm-remez
[docs-badge]: https://docs.rs/pm-remez/badge.svg
[docs-url]: https://docs.rs/pm-remez
pm-remez is a modern Rust implementation of the Parks-McClellan Remez exchange
algorithm. It can be used as a Rust library and as a Python package via its
Python bindings.
pm-remez supports the design of FIR filters with even symmetry and odd symmetry,
and with an even number of taps and an odd number of taps, by reducing all these
cases to the even symmetry odd number of taps case. The desired frequency
response in each band, as well as the weights, can be defined as arbitrary
functions. The library can use double-precision IEEE 754 floating-point numbers
for calculations, as well as other higher precision floating-point
implementations, such as
[num-bigfloat](https://docs.rs/num-bigfloat/latest/num_bigfloat/). This can be
used to solve numerically challenging problems that are difficult to solve using
double-precision arithmetic.
The implementation draws ideas from
[a paper by S.I. Filip](https://dl.acm.org/doi/10.1145/2904902)
to make the algorithm robust against numerical errors. These ideas include the
use of Chebyshev proxy root finding to find the extrema of the weighted error
function in the Remez exchange step.
## Documentation
The documentation for the Rust crate is hosted in
[docs.rs/pm-remez](https://docs.rs/pm-remez).
The documentation for the Python package is hosted in
[pm-remez.readthedocs.io](https://pm-remez.readthedocs.io/).
The Python package documentation contains a series of examples that show how to
use pm-remez to design commonly used types of FIR filters. These illustrate the
capabilities of pm-remez and also serve as a filter design guide. The
documentation of the Rust crate contains a few examples of the Rust API. The
Python examples can also be written in Rust (and in fact this is done
[as part of integration testing](tests/filter_designs.rs)).
## Python package
The pm-remez Python package is [published in
PyPI](https://pypi.org/project/pm-remez/). There are pre-built binary packages
for common architectures and operating systems. For these, the package can be
installed by doing
```
pip install pm-remez
```
## Building
The pm-remez crate uses [ndarray-linalg](https://docs.rs/ndarray-linalg/) to
solve eigenvalue problems. This in turn depends on LAPACK. The pm-remez crate
has several feature flags that are used to select the LAPACK backend. Exactly
one of these features needs to be enabled to build pm-remez. The feature flags
are `openblas-static`, `openblas-system`, `netlib-static`, `netlib-system`,
`intel-mkl-static` and `intel-mkl-system`. The `-static` versions of each flag
build the LAPACK backend and link statically against it. The `-system` versions
link against a system-installed library (linking can be dynamic or static
depending on which type of library is installed). For example,
```
cargo build --release --features openblas-system
```
will build against a system-installed OpenBLAS library.
The Python package is built using [maturin](https://docs.rs/ndarray-linalg/).
It can be built with
```
maturin build --release
```
or
```
python -mbuild
```
## License
Licensed under either of
* Apache License, Version 2.0
([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license
([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)
at your option.
## Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.
Raw data
{
"_id": null,
"home_page": "https://maia-sdr.org/",
"name": "pm-remez",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": "Daniel Estevez <daniel@destevez.net>",
"keywords": "FIR, remez, DSP",
"author": "Daniel Estevez <daniel@destevez.net>",
"author_email": "Daniel Estevez <daniel@destevez.net>",
"download_url": "https://files.pythonhosted.org/packages/81/d6/ffef3fc3b817da8ba3c498de9005c74dd934a4b44d23cb41dbd8457e157e/pm_remez-0.1.3.tar.gz",
"platform": null,
"description": "# pm-remez: Parks-McClellan Remez FIR design algorithm\n\n[![Crates.io][crates-badge]][crates-url]\n[![Rust](https://github.com/maia-sdr/pm-remez/actions/workflows/rust.yml/badge.svg)](https://github.com/maia-sdr/pm-remez/actions/workflows/rust.yml)\n[![Rust Docs][docs-badge]][docs-url]\n[![Python](https://github.com/maia-sdr/pm-remez/actions/workflows/maturin.yml/badge.svg)](https://github.com/maia-sdr/pm-remez/actions/workflows/maturin.yml)\n[![Python Docs](https://readthedocs.org/projects/pm-remez/badge/?version=latest)](https://pm-remez.readthedocs.io/en/latest/?badge=latest)\n[![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n\n[crates-badge]: https://img.shields.io/crates/v/pm-remez\n[crates-url]: https://crates.io/crates/pm-remez\n[docs-badge]: https://docs.rs/pm-remez/badge.svg\n[docs-url]: https://docs.rs/pm-remez\n\npm-remez is a modern Rust implementation of the Parks-McClellan Remez exchange\nalgorithm. It can be used as a Rust library and as a Python package via its\nPython bindings.\n\npm-remez supports the design of FIR filters with even symmetry and odd symmetry,\nand with an even number of taps and an odd number of taps, by reducing all these\ncases to the even symmetry odd number of taps case. The desired frequency\nresponse in each band, as well as the weights, can be defined as arbitrary\nfunctions. The library can use double-precision IEEE 754 floating-point numbers\nfor calculations, as well as other higher precision floating-point\nimplementations, such as\n[num-bigfloat](https://docs.rs/num-bigfloat/latest/num_bigfloat/). This can be\nused to solve numerically challenging problems that are difficult to solve using\ndouble-precision arithmetic.\n\nThe implementation draws ideas from\n[a paper by S.I. Filip](https://dl.acm.org/doi/10.1145/2904902)\nto make the algorithm robust against numerical errors. These ideas include the\nuse of Chebyshev proxy root finding to find the extrema of the weighted error\nfunction in the Remez exchange step.\n\n## Documentation\n\nThe documentation for the Rust crate is hosted in\n[docs.rs/pm-remez](https://docs.rs/pm-remez).\n\nThe documentation for the Python package is hosted in\n[pm-remez.readthedocs.io](https://pm-remez.readthedocs.io/).\n\nThe Python package documentation contains a series of examples that show how to\nuse pm-remez to design commonly used types of FIR filters. These illustrate the\ncapabilities of pm-remez and also serve as a filter design guide. The\ndocumentation of the Rust crate contains a few examples of the Rust API. The\nPython examples can also be written in Rust (and in fact this is done\n[as part of integration testing](tests/filter_designs.rs)).\n\n## Python package\n\nThe pm-remez Python package is [published in\nPyPI](https://pypi.org/project/pm-remez/). There are pre-built binary packages\nfor common architectures and operating systems. For these, the package can be\ninstalled by doing\n\n```\npip install pm-remez\n```\n\n## Building\n\nThe pm-remez crate uses [ndarray-linalg](https://docs.rs/ndarray-linalg/) to\nsolve eigenvalue problems. This in turn depends on LAPACK. The pm-remez crate\nhas several feature flags that are used to select the LAPACK backend. Exactly\none of these features needs to be enabled to build pm-remez. The feature flags\nare `openblas-static`, `openblas-system`, `netlib-static`, `netlib-system`,\n`intel-mkl-static` and `intel-mkl-system`. The `-static` versions of each flag\nbuild the LAPACK backend and link statically against it. The `-system` versions\nlink against a system-installed library (linking can be dynamic or static\ndepending on which type of library is installed). For example,\n```\ncargo build --release --features openblas-system\n```\nwill build against a system-installed OpenBLAS library.\n\nThe Python package is built using [maturin](https://docs.rs/ndarray-linalg/).\nIt can be built with\n```\nmaturin build --release\n```\nor\n```\npython -mbuild\n```\n\n## License\n\nLicensed under either of\n\n * Apache License, Version 2.0\n ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)\n * MIT license\n ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)\n\nat your option.\n\n## Contribution\n\nUnless you explicitly state otherwise, any contribution intentionally submitted\nfor inclusion in the work by you, as defined in the Apache-2.0 license, shall be\ndual licensed as above, without any additional terms or conditions.\n\n",
"bugtrack_url": null,
"license": "MIT OR Apache-2.0",
"summary": "Parks-McClellan Remez FIR design algorithm",
"version": "0.1.3",
"project_urls": {
"Homepage": "https://maia-sdr.org/",
"Source Code": "https://github.com/maia-sdr/pm-remez/"
},
"split_keywords": [
"fir",
" remez",
" dsp"
],
"urls": [
{
"comment_text": null,
"digests": {
"blake2b_256": "e204054ebb75751eb2b65b8059d38ba4c9489e661e7eb7463f6f8be24393cbcb",
"md5": "04575e3590513faf4df53f7e2f065cf1",
"sha256": "7823f65f735d1f2161ae5e8496c1f94564382502832bd7769ca5eea05c9a546f"
},
"downloads": -1,
"filename": "pm_remez-0.1.3-cp38-abi3-macosx_10_12_x86_64.whl",
"has_sig": false,
"md5_digest": "04575e3590513faf4df53f7e2f065cf1",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": null,
"size": 822212,
"upload_time": "2024-10-09T21:30:48",
"upload_time_iso_8601": "2024-10-09T21:30:48.684670Z",
"url": "https://files.pythonhosted.org/packages/e2/04/054ebb75751eb2b65b8059d38ba4c9489e661e7eb7463f6f8be24393cbcb/pm_remez-0.1.3-cp38-abi3-macosx_10_12_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "328657d24e7385a14046ae31c77f4b3d4b753721729a7c8b022b1778b2697e70",
"md5": "c740bcfdd6bb70c509398fd03030cd63",
"sha256": "746adbf7460bf56ee01ea5ae6f9ad6f5e35b479fc0adaa992550c1cdab8d63b0"
},
"downloads": -1,
"filename": "pm_remez-0.1.3-cp38-abi3-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "c740bcfdd6bb70c509398fd03030cd63",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": null,
"size": 829449,
"upload_time": "2024-10-09T21:30:46",
"upload_time_iso_8601": "2024-10-09T21:30:46.314194Z",
"url": "https://files.pythonhosted.org/packages/32/86/57d24e7385a14046ae31c77f4b3d4b753721729a7c8b022b1778b2697e70/pm_remez-0.1.3-cp38-abi3-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "f807f05b3b887de93c7982933faa122bd884512c524fd765e0572ad0e4ba2275",
"md5": "6f2b7e4252e8e5f70729851204704ac6",
"sha256": "a264cf602085d118aef5fd1d71b1d100b60050056830a936a8fd11dfbd038d0e"
},
"downloads": -1,
"filename": "pm_remez-0.1.3-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "6f2b7e4252e8e5f70729851204704ac6",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": null,
"size": 1864991,
"upload_time": "2024-10-09T21:30:44",
"upload_time_iso_8601": "2024-10-09T21:30:44.385509Z",
"url": "https://files.pythonhosted.org/packages/f8/07/f05b3b887de93c7982933faa122bd884512c524fd765e0572ad0e4ba2275/pm_remez-0.1.3-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "6b1ca5db19c77648029cd86104655bbf5de640993e9ddcf2361693f3192124f8",
"md5": "a0560435fa3f89abd23a0cd156f5e2d9",
"sha256": "8f76f944cdb840736eb9c23abb9de43195cb65a189000c7802a37f9e0db57788"
},
"downloads": -1,
"filename": "pm_remez-0.1.3-cp38-abi3-win_amd64.whl",
"has_sig": false,
"md5_digest": "a0560435fa3f89abd23a0cd156f5e2d9",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": null,
"size": 16599066,
"upload_time": "2024-10-09T21:30:52",
"upload_time_iso_8601": "2024-10-09T21:30:52.798366Z",
"url": "https://files.pythonhosted.org/packages/6b/1c/a5db19c77648029cd86104655bbf5de640993e9ddcf2361693f3192124f8/pm_remez-0.1.3-cp38-abi3-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "81d6ffef3fc3b817da8ba3c498de9005c74dd934a4b44d23cb41dbd8457e157e",
"md5": "065de2155ed260154f954070ace3ed53",
"sha256": "66f22e18fc2a6902fc7bcbb2432d13842c930eab916a681c085209ecda583dab"
},
"downloads": -1,
"filename": "pm_remez-0.1.3.tar.gz",
"has_sig": false,
"md5_digest": "065de2155ed260154f954070ace3ed53",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 60500,
"upload_time": "2024-10-09T21:30:50",
"upload_time_iso_8601": "2024-10-09T21:30:50.623045Z",
"url": "https://files.pythonhosted.org/packages/81/d6/ffef3fc3b817da8ba3c498de9005c74dd934a4b44d23cb41dbd8457e157e/pm_remez-0.1.3.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-09 21:30:50",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "maia-sdr",
"github_project": "pm-remez",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "pm-remez"
}