This repository contains Jupyter notebooks that use Python to do basic sound analysis including importing WAV files, ploting waveforms, and computing and plotting power spectra and spectrograms. There are two example Jupyter notebooks. One uses Matplotlib to produce static images, and the other uses Plotly to produce interactive images. The Matplotlib/static image notebook requires less memory and computer porcessing to produce images. Also, the static images can be readily imported into presentations and papers. The interactive images require more computer resources to produce and save. They are good for exploring the details of a plot because the user can zoom and pan the plot without re-plotting. Plotly/interactive plots can be exported to Javascript-enabled HTML files that can be opened in most browsers or included in webpages.
-
Beats.wav - sound recording of beats produced by two tuning forks vibrating at different frequencies. Included as an example sound recording to analyze.
-
OrganPipeOpenClosed.wav - sound recording of a tube (organ pipe) alternating between playing with both ends open and one end closed. There is also a voice speaking on the recording. Included as an example sound recording to analyze.
-
README.md - This file.
-
Sound Analysis-Interactive Figures.ipynb - Jupyter notebook that demonstrates sound analysis using Plotly to produce interactive figures.
-
Sound Analysis-Interactive Figures-colab.ipynb - Jupyter notebook that demonstrates sound analysis using Plotly to produce interactive figures. This version contains the configuration and installation commands necessary to run the notebook on Google Colab.
-
Sound Analysis-Static Figures.ipynb - Jupyter notebook that demonstrates sound analysis using Matplotlib to produce static figures.
-
Sound Analysis-Static Figures-colab.ipynb - Jupyter notebook that demonstrates sound analysis using Matplotlib to produce static figures. This version contains the configuration and installation commands necessary to run the notebook on Google Colab.
-
requirements.txt - List of additional packages to install when this project is imported into Binder (see below), which reads this file and installs these packages automatically.
In order to run these Jupyter notebooks on a local computer, you must have a version of Python 3.6 or greater with Jupyter installed with these additional packages:
- numpy
- scipy
- matplotlib
- plotly
- svsound - install this with
conda install -c sprague252 svsound
or withpip install svsound
.
Clone this git repository from GitHub with the following command.
git clone https://github.com/sprague252/SVImageProcessing.git
Once you have everything configured, start Jupyter Notebook or Jupyter Lab and open either of the two notebooks described above.
The easiest way to run these notebooks is to use Google Colab, which will use computers in the Google cloud to run the Python code. In order to do this, you must have a Google account with sufficient space on your Google Drive.
In order to run these files on Colab, open the notebook ColabSetUp.ipynb
and run the commands in Colab. You can do open the notebook with the following link.
Open ColabSetUp.ipynb on Google Colab.
Binder is a cloud service that allows users to run Jupyter notebooks from Github repositories (no account required). Binder will not save your files after you end your session, so be sure to download all of your results before closing.