IIR coefficients for A,B,C and ITU_R_468 weighting filters
Project description
Two modules which provide the zpk coefficients for the A,B,C and ITU_R_468 weighting filters. These can then be used by signal.lfilter to filter audio signals.
In contrast to other implementations which get the high frequency end completely wrong (because of the bilinear transform) here I have used the matched z-transform which aims to match 1:1 the analogue and digital frequency response.
The precision towards the Nyquist frequency can be increased by using a higher sampling rate but given that audio has such low energies over 10kHz there is probably not much point to it.
On the other hand lower sampling rates are possible for example 8kHz if only low frequency noise has been measured.
Installation
The preferred way to install is with pip / pip3:
pip install sound_weighting_filters
Usage
Import the module:
import ABC_weighting
This has a single function:
get_zpk(curve='A', fs=False) - `curve` defines the weighting filter and can be 'A', 'B' or 'C'. - `fs` sets the sampling rate of the digital system.
Returns zeros, poles, gain of the filter.
For example:
z,p,k = ABC_weighting.get_zpk(fs = 48000)
The same applies to the ITU_R_468 module, for example:
z,p,k = ITU_R_468_weighting.get_zpk(fs = 48000)
Demo plots
Run:
python ABC_weighting.py
Credits
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
Hashes for sound_weighting_filters-0.9.2.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 070736a2dbfc963367102ef7390edf806486cc4443e1c095c50922aec93c1baa |
|
MD5 | 1fc2a671b7f59be8567637619f99e54c |
|
BLAKE2b-256 | ceb8c309b6ee20f5419ba15f905d67f9562c0babc9ef1468b75fe4af46db135a |