libfmp


Namelibfmp JSON
Version 1.2.6 PyPI version JSON
download
home_pagehttp://audiolabs-erlangen.de/FMP
SummaryPython module for fundamentals of music processing
upload_time2024-02-14 08:54:10
maintainer
docs_urlNone
authorMeinard Müller and Frank Zalkow
requires_python>=3.8
licenseMIT
keywords audio music sound
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # libfmp

This repository contains the Python package libfmp. This package goes hand in hand with the FMP Notebooks, a collection of educational material for teaching and learning Fundamentals of Music Processing (FMP) with a particular focus on the audio domain. For detailed explanations and example appliciations of the libfmp-functions we refer to the FMP Notebooks:

https://audiolabs-erlangen.de/FMP

The FMP notebooks also contain a dedicated notebook for libfmp:

https://www.audiolabs-erlangen.de/resources/MIR/FMP/B/B_libfmp.html

There is also an API documentation for libfmp:

https://meinardmueller.github.io/libfmp

If you use the package libfmp, please consider the following references.

## References

Meinard Müller and Frank Zalkow. [libfmp: A Python Package for Fundamentals of Music Processing.](https://joss.theoj.org/papers/10.21105/joss.03326) Journal of Open Source Software (JOSS), 6(63), 2021.

Meinard Müller and Frank Zalkow. [FMP Notebooks: Educational Material for Teaching and Learning Fundamentals of Music Processing.](https://archives.ismir.net/ismir2019/paper/000069.pdf) Proceedings of the International Conference on Music Information Retrieval (ISMIR), pp. 573–580, Delft, The Netherlands, 2019.

Meinard Müller. [Fundamentals of Music Processing – Using Python and Jupyter Notebooks.](http://www.music-processing.de/) Springer Verlag, 2nd edition, 2021.

Meinard Müller. [An Educational Guide Through the FMP Notebooks for Teaching and Learning Fundamentals of Music Processing.](https://www.mdpi.com/2624-6120/2/2/18) Signals, 2(2): 245–285, 2021.

## Statement of Need

The libfmp package bundles core concepts from the music information retrieval (MIR) field in the form of well-documented and easy-to-use Python functions. It is designed to aid students with the transition from being learners (e.g., studying the FMP notebooks) to becoming researchers by providing proper software support for building and experimenting with complex MIR pipelines. Going beyond and complementing existing Python packages (such as librosa), the libfmp package contains (previously unpublished) reference implementations of MIR algorithms from the literature and new Python implementations of previously published MATLAB toolboxes. The functionality of libfmp addresses diverse MIR tasks such as tuning estimation, music structure analysis, audio thumbnailing, chord recognition, tempo estimation, beat and local pulse tracking, fragment-level music retrieval, and audio decomposition.

## Installing

With Python >= 3.6, you can install libfmp using the Python package manager pip:

```
pip install libfmp
```

## Contributing

The libfmp-package has been developed in the context of the FMP notebooks. Being an integral part, all libfmp-functions need to manually synchronized with text passages, explanations, and the code in the FMP notebooks. Of course, we are happy for suggestions and contributions. However, to facilitate the synchronization, we would be grateful for either directly contacting us via email (meinard.mueller@audiolabs-erlangen.de) or for creating [an issue](https://github.com/meinardmueller/libfmp/issues) in our GitHub repository. Please do not submit a pull request without prior consultation with us.

If you want to report an issue with libfmp or seek support, please use the same communication channels (email or GitHub issue).

## Tests

The functions of libmfp are also covered in the [FMP notebooks](https://audiolabs-erlangen.de/FMP). There, you find several test cases for the functions, showing typical input-output behaviors. Beyond these tests, the FMP notebooks offer extensive explanations of these functions. Thus, we consider FMP as a replacement for conventional unit tests.

Furthermore, we provide a small script that tests one function of each subpackage from libfmp. Rather than covering the full functionality of libfmp, it only verifies the correct import structure within the libfmp package.

There are two options for executing the test script. The first is just to run the script, which results in no output if there are no errors.

```
python test_examples.py
```

The second option is to use [pytest](https://pytest.org), which results in a more instructive output. pytest is available when installing libfmp with the extra requirements for testing.

```
pip install 'libfmp[tests]'
pytest test_examples.py
```

## Acknowledgements

The main authors of libfmp, Meinard Müller and Frank Zalkow, are associated with the International Audio Laboratories Erlangen, which are a joint institution of the Friedrich-Alexander-Universität Erlangen-Nürnberg (FAU) and Fraunhofer Institute for Integrated Circuits IIS. We thank the German Research Foundation (DFG) for various research grants that allow us for conducting fundamental research in music processing. Furthermore, we thank the various people who have contributed to libfmp with code and suggestions. In particular, we want to thank (in alphabetic order) Stefan Balke, Michael Krause, Patricio Lopez-Serrano, Julian Reck, Sebastian Rosenzweig, Angel Villar-Corrales, Christof Weiß, and Tim Zunner.

            

Raw data

            {
    "_id": null,
    "home_page": "http://audiolabs-erlangen.de/FMP",
    "name": "libfmp",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": "",
    "keywords": "audio music sound",
    "author": "Meinard M\u00fcller and Frank Zalkow",
    "author_email": "meinard.mueller@audiolabs-erlangen.de",
    "download_url": "https://files.pythonhosted.org/packages/40/6a/85d79d54d040a60a94d01e3cbfd6221aa9a7a4ffa3fda0b2074c4cf95438/libfmp-1.2.6.tar.gz",
    "platform": null,
    "description": "# libfmp\n\nThis repository contains the Python package libfmp. This package goes hand in hand with the FMP Notebooks, a collection of educational material for teaching and learning Fundamentals of Music Processing (FMP) with a particular focus on the audio domain. For detailed explanations and example appliciations of the libfmp-functions we refer to the FMP Notebooks:\n\nhttps://audiolabs-erlangen.de/FMP\n\nThe FMP notebooks also contain a dedicated notebook for libfmp:\n\nhttps://www.audiolabs-erlangen.de/resources/MIR/FMP/B/B_libfmp.html\n\nThere is also an API documentation for libfmp:\n\nhttps://meinardmueller.github.io/libfmp\n\nIf you use the package libfmp, please consider the following references.\n\n## References\n\nMeinard M\u00fcller and Frank Zalkow. [libfmp: A Python Package for Fundamentals of Music Processing.](https://joss.theoj.org/papers/10.21105/joss.03326) Journal of Open Source Software (JOSS), 6(63), 2021.\n\nMeinard M\u00fcller and Frank Zalkow. [FMP Notebooks: Educational Material for Teaching and Learning Fundamentals of Music Processing.](https://archives.ismir.net/ismir2019/paper/000069.pdf) Proceedings of the International Conference on Music Information Retrieval (ISMIR), pp. 573–580, Delft, The Netherlands, 2019.\n\nMeinard M\u00fcller. [Fundamentals of Music Processing – Using Python and Jupyter Notebooks.](http://www.music-processing.de/) Springer Verlag, 2nd edition, 2021.\n\nMeinard M\u00fcller. [An Educational Guide Through the FMP Notebooks for Teaching and Learning Fundamentals of Music Processing.](https://www.mdpi.com/2624-6120/2/2/18) Signals, 2(2): 245–285, 2021.\n\n## Statement of Need\n\nThe libfmp package bundles core concepts from the music information retrieval (MIR) field in the form of well-documented and easy-to-use Python functions. It is designed to aid students with the transition from being learners (e.g., studying the FMP notebooks) to becoming researchers by providing proper software support for building and experimenting with complex MIR pipelines. Going beyond and complementing existing Python packages (such as librosa), the libfmp package contains (previously unpublished) reference implementations of MIR algorithms from the literature and new Python implementations of previously published MATLAB toolboxes. The functionality of libfmp addresses diverse MIR tasks such as tuning estimation, music structure analysis, audio thumbnailing, chord recognition, tempo estimation, beat and local pulse tracking, fragment-level music retrieval, and audio decomposition.\n\n## Installing\n\nWith Python >= 3.6, you can install libfmp using the Python package manager pip:\n\n```\npip install libfmp\n```\n\n## Contributing\n\nThe libfmp-package has been developed in the context of the FMP notebooks. Being an integral part, all libfmp-functions need to manually synchronized with text passages, explanations, and the code in the FMP notebooks. Of course, we are happy for suggestions and contributions. However, to facilitate the synchronization, we would be grateful for either directly contacting us via email (meinard.mueller@audiolabs-erlangen.de) or for creating [an issue](https://github.com/meinardmueller/libfmp/issues) in our GitHub repository. Please do not submit a pull request without prior consultation with us.\n\nIf you want to report an issue with libfmp or seek support, please use the same communication channels (email or GitHub issue).\n\n## Tests\n\nThe functions of libmfp are also covered in the [FMP notebooks](https://audiolabs-erlangen.de/FMP). There, you find several test cases for the functions, showing typical input-output behaviors. Beyond these tests, the FMP notebooks offer extensive explanations of these functions. Thus, we consider FMP as a replacement for conventional unit tests.\n\nFurthermore, we provide a small script that tests one function of each subpackage from libfmp. Rather than covering the full functionality of libfmp, it only verifies the correct import structure within the libfmp package.\n\nThere are two options for executing the test script. The first is just to run the script, which results in no output if there are no errors.\n\n```\npython test_examples.py\n```\n\nThe second option is to use [pytest](https://pytest.org), which results in a more instructive output. pytest is available when installing libfmp with the extra requirements for testing.\n\n```\npip install 'libfmp[tests]'\npytest test_examples.py\n```\n\n## Acknowledgements\n\nThe main authors of libfmp, Meinard M\u00fcller and Frank Zalkow, are associated with the International Audio Laboratories Erlangen, which are a joint institution of the Friedrich-Alexander-Universit\u00e4t Erlangen-N\u00fcrnberg (FAU) and Fraunhofer Institute for Integrated Circuits IIS. We thank the German Research Foundation (DFG) for various research grants that allow us for conducting fundamental research in music processing. Furthermore, we thank the various people who have contributed to libfmp with code and suggestions. In particular, we want to thank (in alphabetic order) Stefan Balke, Michael Krause, Patricio Lopez-Serrano, Julian Reck, Sebastian Rosenzweig, Angel Villar-Corrales, Christof Wei\u00df, and Tim Zunner.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Python module for fundamentals of music processing",
    "version": "1.2.6",
    "project_urls": {
        "Download": "https://github.com/meinardmueller/libfmp",
        "Homepage": "http://audiolabs-erlangen.de/FMP"
    },
    "split_keywords": [
        "audio",
        "music",
        "sound"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "681f09bc6a8164aafd3a70450e134e00634f99fee2d3d8da716ca51dad25d3e0",
                "md5": "d341e820bb6ba8f75559371f15f379b2",
                "sha256": "da87f2d7a7b40bcc38dd59c601b07d93fbd8158b317651c2016a9c3d696e6b38"
            },
            "downloads": -1,
            "filename": "libfmp-1.2.6-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "d341e820bb6ba8f75559371f15f379b2",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 110046,
            "upload_time": "2024-02-14T08:54:07",
            "upload_time_iso_8601": "2024-02-14T08:54:07.836664Z",
            "url": "https://files.pythonhosted.org/packages/68/1f/09bc6a8164aafd3a70450e134e00634f99fee2d3d8da716ca51dad25d3e0/libfmp-1.2.6-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "406a85d79d54d040a60a94d01e3cbfd6221aa9a7a4ffa3fda0b2074c4cf95438",
                "md5": "f959026135a5e674a1fe565ea38b447a",
                "sha256": "12082f89c294517a846d4928dadc578e54409f523a31db418306a429daadd6bb"
            },
            "downloads": -1,
            "filename": "libfmp-1.2.6.tar.gz",
            "has_sig": false,
            "md5_digest": "f959026135a5e674a1fe565ea38b447a",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 84874,
            "upload_time": "2024-02-14T08:54:10",
            "upload_time_iso_8601": "2024-02-14T08:54:10.801017Z",
            "url": "https://files.pythonhosted.org/packages/40/6a/85d79d54d040a60a94d01e3cbfd6221aa9a7a4ffa3fda0b2074c4cf95438/libfmp-1.2.6.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-02-14 08:54:10",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "meinardmueller",
    "github_project": "libfmp",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "libfmp"
}
        
Elapsed time: 0.22996s