Skip to main content

A research-based framework for exploring sound as well as machine learning in the context of sound.

Project description

PySoundTool

PySoundTool is an experimental framework for exploring sound as well as machine learning in the context of sound.

Binder License PyPI pyversions

Documentation

For examples and to navigate the code, see the documentation.

About

Note: as is, PySoundTool is not yet a stable framework, meaning changes might periodically be made without extreme focus on backwards compatibility.

Those who might find this useful:

  • speech and sound enthusiasts
  • digital signal processing / mathematics / physics / acoustics enthusiasts
  • deep learning enthusiasts
  • researchers
  • linguists
  • psycholinguists

The main goal of PySoundTool is to provide the code and functionality with more context via visualization, research, and mathematics. Most of the resources used to build the functionality stems from publicly available research and datasets. (For a list of open datasets, see my ever growing collection.)

As it covers quite a large range, from audio file conversion to implementation of trained neural networks, the purpose of PySoundTool is not to be the perfect implementation of all functions (although that is also a goal :P ), but rather a peak into how they can be implemented, hopefully offering others a foundation for trying out different ways of implementation (feature extraction, building neural networks, etc.).

This project is still in the beginning stages and has a lot of room for growth, especially with contributers having a background / knowlege in data science, computer science, machine and deep learning, physics, acoustics, or dsp. Contributers from other backgrounds are also welcome! If you'd like PySoundTool to do something it doesn't, try making it or create an issue.

Installation

Clone this repository. Set the working directory where you clone this repository.

Start a virtual environment:

$ python3 -m venv env

or, to better control your python version:

$ virtualenv -p python3.6 env

Then activate the environment

$ source env/bin/activate
(env)..$

Then install necessary installations via pip:

(env)..$ pip install -r requirements.txt

Examples

You can explore example code via:

  • Binder (albeit limited as some packages - librosa, soundfile - cannot be loaded into online environments)
  • locally on your machine via Jupyter Notebook
  • examples in the documentation.

Binder

Click on the Binder badge at the top of this README (it might take a while to load) and venture into the folder binder_notebooks.

Locally via Jupyter Notebook:

Install and run jupyter notebook:

(env)..$ pip install notebook
(env)..$ jupyter notebook

Venture into the folder jupyter_notebooks and have a go!

Example datasets

If you would like to play around with various types of sound, check out my repo containing mini datasets of sound, ranging from speech to noise. They are very small so don't expect much as it comes to training neural networks. These example datasets are used in some of the documentation examples.

Testing

If you want to run the tests for PySoundTool, they currently use audiofiles available in the example datasets repo, mentioned above. Also, see tests_requirements.txt. The packages located there will need to be installed via:

(env)..$ pip install -r tests_requirements.txt

About the Author

I studied clinical linguistics for my master's which introduced me to the inspiring world of open source software, python programming, and the beauty of acoustics. My interests broadened from academic experimental design to the development of tools for identifiying speech irregularities and beyond. Through this I discovered a bit of a missing niche in the Python community: a high-level sound tool for filtering, analysis, and deep learning that also offers context to its functionality. You can read more about me and my projects on my blog.

The Beginnings of PySoundTool

This project stemmed from the Prototype Fund project NoIze which was presented at PyConDE / PyData Berlin in 2019. This fork broadens the application of the software from smart noise filtering to general sound analysis, filtering, visualization, preparation, etc. Therefore the name has been adapted to more general sound functionality.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pysoundtool-0.1.0a1.tar.gz (2.9 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pysoundtool-0.1.0a1-py2.py3-none-any.whl (110.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pysoundtool-0.1.0a1.tar.gz.

File metadata

  • Download URL: pysoundtool-0.1.0a1.tar.gz
  • Upload date:
  • Size: 2.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/47.3.1 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.6.9

File hashes

Hashes for pysoundtool-0.1.0a1.tar.gz
Algorithm Hash digest
SHA256 b419fecc30680ddd675d258698e5653bbc443dd504e840e7c8a3952f5e26e9a8
MD5 fe06b8673e40bae418dcfaf813a50a86
BLAKE2b-256 9c0cc57ee43f6ab5d449e65fd2dba3d471d4a7d4020e59cfb0e3d03953991996

See more details on using hashes here.

File details

Details for the file pysoundtool-0.1.0a1-py2.py3-none-any.whl.

File metadata

  • Download URL: pysoundtool-0.1.0a1-py2.py3-none-any.whl
  • Upload date:
  • Size: 110.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/47.3.1 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.6.9

File hashes

Hashes for pysoundtool-0.1.0a1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 71f3ea777724539d8f9375feb0aeadc0e4181c6f2961013317a60f9895612842
MD5 8a113125c5b53293fe170f82b6e6d412
BLAKE2b-256 836e0aed67361ed89e5cc4f109ee2c80996564de885e2eaff49c4bfe29451fa6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page