Skip to content

Python implementation for audio time-frequency automatic gain control

Notifications You must be signed in to change notification settings

miropp4343/pyagc

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Automatic Gain Control

Automatic Gain Control (AGC) for audio signals in python, based on Dan Ellis' Matlab code.

The code is based in the original Matlab implementation in the above link. It is almost exactly the same, with the exception of the STFT and ISTFT functions, which I implemented from scratch. A sample WAV file (obtained from the original Matlab source code) is provided for testing.

Dependencies

The code depends on NumPy / SciPy.

Example of usage

import scipy.io.wavfile
import numpy as np
from agc import tf_agc

# read audiofile
sr, d = scipy.io.wavfile.read('speech.wav')

# convert from int16 to float (-1,1) range
convert_16_bit = float(2 ** 15)
d = d / (convert_16_bit + 1.0)

# apply AGC
(y, D, E) = tf_agc(d, sr)

# convert back to int16 to save
y = np.int16(y / np.max(np.abs(y)) * convert_16_bit)
scipy.io.wavfile.write('speech_agc.wav', sr, y)

References

D. Ellis (2010), "Time-frequency automatic gain control", web resource, available: http://labrosa.ee.columbia.edu/matlab/tf_agc/

About

Python implementation for audio time-frequency automatic gain control

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%