Skip to main content

Several simple auditory models in JAX, Numpy and Torch

Project description

Python Auditory Toolbox

This is a Python port of (portions of) the Matlab Auditory Toolbox. This package provides code built upon the Numpy, PyTorch, and JAX numerical libraries.

The Python Auditory toolbox includes these functions from the original in Matlab:

  • Patternson-Holdworth ERB (Gammatone) Filter Bank
    • MakeErbFilters
    • ErbFilterBank
  • Correlogram Processing
    • CorrelogramFrame
    • CorrelogramArray
    • CorrelogramPitch
  • Demonstrations
    • MakeVowel
    • FMPoints
    • Spectrogram

This toolbox does not include Lyon's Passive Long-wave Cochlear model as this model has been supersceded by CARFAC.

All functions are available on top of any of these three computational libraries: JAX, NumPy or PyTorch.

This colab provides examples of calling (and testing) this libary using the NumPy functionality.

This toolbox can be used to build biophysically inspired models of the auditory periphery using JAX, PyTorch and NumPy. This can hopefully be used to further develop realistic models with better explanations of what is changing as we optimize to match different psychoacoustic tests. It may further be useful for developing auditory models such as those developed in Sarah Verhulst's (Hearing Technology Lab on GitHub) and Josh McDermott's (Model Metamers Paper) labs.

You can include the python_auditory_toolbox in your work in several ways. Via the Python package installer:

pip install python_auditory_toolbox

From GitHub at:

https://github.com/MalcolmSlaney/python_auditory_toolbox

Or see the toolbox in action (with pretty pictures) via Colab at:

https://colab.research.google.com/drive/1JGm24f1kOBl-EmtscJck58LGgWkfWGO8?usp=sharing

Note

This package includes three different implementations of the auditory toolbox and thus the union of the three different import requirements. Most users will probably be only using one of the three libraries (NumPy, JAX, or PyTorch), will only need to import one of the auditory_toolbox files, and will not need all the prerequisite libraries.

Please cite this work as:

Malcolm Slaney and Søren Fuglsang, Python Auditory Toolbox, 2023. https://github.com/MalcolmSlaney/python_auditory_toolbox. 

Examples

Here are the frequency responses for a 10-channel ERB gammatone filtebank.

Gammatone (ERB) Filter Reponse

Here is an example of a correlogram, here with a number of harmonic examples that demonstrate the correlogram representation. or via YouTube

MFCC (mel-frequency cepstral coefficients) is a classic speech representation that was often used in (pre-DNN) speech recognizers. It converts the original spectrogram, shown here,

Original tapestry spectrogram

into a 40 channel filterbank. And finally into a 13-dimensional cepstral representation.

We can invert these steps to reconstruct the original filterbank representation

Reconstruction of filterbank representation

And then the reconstruct the original spectrogram.

Reconstruction of spectrogram

Note, in particular, the pitch harmonics (the horizontal banding) have been filtered out by the cepstral processing.

Examples: PyTorch

The following code block demonstrates a feature extraction scheme that involves a 64-channel ERB gammatone filterbank. While the NumPy and JAX versions mimic the original Matlab API, the PyTorch version defines a class. The output features are shown below.

import torch
import torchaudio
import matplotlib.pyplot as plt
import auditory_toolbox_torch as pat

class CustomPipeline(torch.nn.Module):
  def __init__(self, sampling_rate: int = 16000) -> None:
    super().__init__()
    self.erbbank = pat.ErbFilterBank(sampling_rate,64,100)
    self.relu1 = torch.nn.ReLU()
    self.avgpool1 = torch.nn.AvgPool1d(80, stride=20)

  def forward(self, x: torch.Tensor) -> torch.Tensor:
    x = self.erbbank(x)
    x = self.relu1(x)
    x = self.avgpool1(x)
    x = torch.pow(x,0.3)
    return x
  
wav, fs = torchaudio.load('./examples/tapestry.wav')

pipeline =  CustomPipeline(fs)
pipeline.to(dtype=torch.float32)

fig = plt.figure()
plt.imshow(pipeline.forward(wav).squeeze(), aspect='auto', cmap='Blues')

Gammatone features

Authors

Malcolm Slaney (malcolm@ieee.org) and Søren A. Fuglsang (sorenaf@drcmr.dk)

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

python_auditory_toolbox-1.0.6.tar.gz (41.4 kB view details)

Uploaded Source

Built Distribution

python_auditory_toolbox-1.0.6-py3-none-any.whl (44.5 kB view details)

Uploaded Python 3

File details

Details for the file python_auditory_toolbox-1.0.6.tar.gz.

File metadata

File hashes

Hashes for python_auditory_toolbox-1.0.6.tar.gz
Algorithm Hash digest
SHA256 504637cca6aa56e876c6ade8e4c72d5a89f25d6f506dcd6abb89319c823da06c
MD5 bf2b245e81bd12e61dcf18db8eaaedb0
BLAKE2b-256 437d0dddde72a2ceaa7a2a595c2014b00db14f1f94b84cbf9048fc88f63fac0c

See more details on using hashes here.

File details

Details for the file python_auditory_toolbox-1.0.6-py3-none-any.whl.

File metadata

File hashes

Hashes for python_auditory_toolbox-1.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 adf2d4c9c3ee432631950e4cacd28a80988bdebaefc9248b38e8947396477674
MD5 5d6f8bdd54792a36d40edfdba0b5a3c2
BLAKE2b-256 2053bfba666f65a6ea9e7e8e575378d96e80f8303b96064d982509e24e57b630

See more details on using hashes here.

Supported by

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