# MIDIPhone
[![PyPI](https://img.shields.io/pypi/v/midiphone.svg)][pypi status]
[![Status](https://img.shields.io/pypi/status/midiphone.svg)][pypi status]
[![Python Version](https://img.shields.io/pypi/pyversions/midiphone)][pypi status]
[![License](https://img.shields.io/pypi/l/midiphone)][license]
[![Read the documentation at https://midiphone.readthedocs.io/](https://img.shields.io/readthedocs/midiphone/latest.svg?label=Read%20the%20Docs)][read the docs]
[![Tests](https://github.com/regulad/midiphone/workflows/Tests/badge.svg)][tests]
[![Codecov](https://codecov.io/gh/regulad/midiphone/branch/main/graph/badge.svg)][codecov]
[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)][pre-commit]
[![Black](https://img.shields.io/badge/code%20style-black-000000.svg)][black]
[pypi status]: https://pypi.org/project/midiphone/
[read the docs]: https://midiphone.readthedocs.io/
[tests]: https://github.com/regulad/midiphone/actions?workflow=Tests
[codecov]: https://app.codecov.io/gh/regulad/midiphone
[pre-commit]: https://github.com/pre-commit/pre-commit
[black]: https://github.com/psf/black
![IMG_1970.mov](IMG_1970.mov)
## Features
- Reconstruct a MIDI port from an audio input
- Buttons to help adjust sensitivity
- Saved config between sessions
## Requirements
- https://www.tobias-erichsen.de/software/loopmidi.html
- Some way to get your piano's audio into your computer (line in preferred)
- Python 3.11+
- Windows 10+ (for now; other OSes possibly added later)
- A sine wave voice on your piano (or a similar sound) (optional; but works best with it)
- My Yamaha PSR-E253 has a Sine wave on Voice 193, works well from C4-C5; iffy in other octaves
## Installation
#### EXE is on Releases page; you can use that if you don't want to install Python
You can install _MIDIPhone_ via [pip] from [PyPI]:
```console
$ pip install midiphone
```
## Usage
Please see the [Command-line Reference] for details.
## Contributing
Contributions are very welcome.
To learn more, see the [Contributor Guide].
## License
Distributed under the terms of the [GPL 3.0 license][license],
_MIDIPhone_ is free and open source software.
## Issues
If you encounter any problems,
please [file an issue] along with a detailed description.
## Credits
This project was generated from [@regulad]'s [neopy] template.
[@regulad]: https://github.com/regulad
[pypi]: https://pypi.org/
[neopy]: https://github.com/regulad/cookiecutter-neopy
[file an issue]: https://github.com/regulad/midiphone/issues
[pip]: https://pip.pypa.io/
<!-- github-only -->
[license]: https://github.com/regulad/midiphone/blob/main/LICENSE
[contributor guide]: https://github.com/regulad/midiphone/blob/main/CONTRIBUTING.md
[command-line reference]: https://midiphone.readthedocs.io/en/latest/usage.html
Raw data
{
"_id": null,
"home_page": "https://github.com/regulad/midiphone",
"name": "midiphone",
"maintainer": null,
"docs_url": null,
"requires_python": "<3.13,>=3.11",
"maintainer_email": null,
"keywords": null,
"author": "Parker Wahle",
"author_email": "regulad@regulad.xyz",
"download_url": null,
"platform": null,
"description": "# MIDIPhone\n\n[![PyPI](https://img.shields.io/pypi/v/midiphone.svg)][pypi status]\n[![Status](https://img.shields.io/pypi/status/midiphone.svg)][pypi status]\n[![Python Version](https://img.shields.io/pypi/pyversions/midiphone)][pypi status]\n[![License](https://img.shields.io/pypi/l/midiphone)][license]\n\n[![Read the documentation at https://midiphone.readthedocs.io/](https://img.shields.io/readthedocs/midiphone/latest.svg?label=Read%20the%20Docs)][read the docs]\n[![Tests](https://github.com/regulad/midiphone/workflows/Tests/badge.svg)][tests]\n[![Codecov](https://codecov.io/gh/regulad/midiphone/branch/main/graph/badge.svg)][codecov]\n\n[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)][pre-commit]\n[![Black](https://img.shields.io/badge/code%20style-black-000000.svg)][black]\n\n[pypi status]: https://pypi.org/project/midiphone/\n[read the docs]: https://midiphone.readthedocs.io/\n[tests]: https://github.com/regulad/midiphone/actions?workflow=Tests\n[codecov]: https://app.codecov.io/gh/regulad/midiphone\n[pre-commit]: https://github.com/pre-commit/pre-commit\n[black]: https://github.com/psf/black\n\n![IMG_1970.mov](IMG_1970.mov)\n\n## Features\n\n- Reconstruct a MIDI port from an audio input\n- Buttons to help adjust sensitivity\n- Saved config between sessions\n\n## Requirements\n\n- https://www.tobias-erichsen.de/software/loopmidi.html\n- Some way to get your piano's audio into your computer (line in preferred)\n- Python 3.11+\n- Windows 10+ (for now; other OSes possibly added later)\n- A sine wave voice on your piano (or a similar sound) (optional; but works best with it)\n - My Yamaha PSR-E253 has a Sine wave on Voice 193, works well from C4-C5; iffy in other octaves\n\n## Installation\n\n#### EXE is on Releases page; you can use that if you don't want to install Python\n\nYou can install _MIDIPhone_ via [pip] from [PyPI]:\n\n```console\n$ pip install midiphone\n```\n\n## Usage\n\nPlease see the [Command-line Reference] for details.\n\n## Contributing\n\nContributions are very welcome.\nTo learn more, see the [Contributor Guide].\n\n## License\n\nDistributed under the terms of the [GPL 3.0 license][license],\n_MIDIPhone_ is free and open source software.\n\n## Issues\n\nIf you encounter any problems,\nplease [file an issue] along with a detailed description.\n\n## Credits\n\nThis project was generated from [@regulad]'s [neopy] template.\n\n[@regulad]: https://github.com/regulad\n[pypi]: https://pypi.org/\n[neopy]: https://github.com/regulad/cookiecutter-neopy\n[file an issue]: https://github.com/regulad/midiphone/issues\n[pip]: https://pip.pypa.io/\n\n<!-- github-only -->\n\n[license]: https://github.com/regulad/midiphone/blob/main/LICENSE\n[contributor guide]: https://github.com/regulad/midiphone/blob/main/CONTRIBUTING.md\n[command-line reference]: https://midiphone.readthedocs.io/en/latest/usage.html\n",
"bugtrack_url": null,
"license": "GPL-3.0",
"summary": "Reconstruct MIDI notes over a virtual device from a live audio stream",
"version": "0.1.0",
"project_urls": {
"Changelog": "https://github.com/regulad/midiphone/releases",
"Documentation": "https://midiphone.readthedocs.io",
"Homepage": "https://github.com/regulad/midiphone",
"Repository": "https://github.com/regulad/midiphone"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "8a751358ef509b06f889902b0283649133db5fa70f31f749ef49e03938856f8e",
"md5": "7e8be4b7c160e85df781ba6924f8ba4f",
"sha256": "3558c65cfbdf2b5114849d78f5a231c1f3343a90c0345b21662fbf0d1280fad5"
},
"downloads": -1,
"filename": "midiphone-0.1.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "7e8be4b7c160e85df781ba6924f8ba4f",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<3.13,>=3.11",
"size": 22094,
"upload_time": "2024-06-17T12:43:35",
"upload_time_iso_8601": "2024-06-17T12:43:35.752701Z",
"url": "https://files.pythonhosted.org/packages/8a/75/1358ef509b06f889902b0283649133db5fa70f31f749ef49e03938856f8e/midiphone-0.1.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-06-17 12:43:35",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "regulad",
"github_project": "midiphone",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "midiphone"
}