Buffer audio samples into fixed-sized blocks, with overlap
Project description
Python: Buffer audio samples into fixed-sized blocks, with overlap
This small utility package encapsulates a single-consumer, single-producer ringbuffer.
- Populate the buffer with arbitrary-length arrays
- Query the buffer, and it returns blocks of a specified fixed length, optionally with overlap between successive blocks
It is designed primarily for applying the short-time Fourier transform (STFT) to successive blocks of an input audio stream (see below for example).
It is safe for usage in real-time audio applications, as no memory allocation or system I/O is done within the extend
method as long as auto_resize=False
is specified when initialising.
Usage
To do block-sized buffering with overlap in conjunction with sounddevice:
import sounddevice as sd
import numpy as np
import blockbuffer
block_size = 1024
hop_size = 128
bb = blockbuffer.BlockBuffer(block_size=block_size,
hop_size=hop_size,
num_channels=2)
def input_callback(data, num_frames, time, status):
global bb
bb.extend(data)
for block in bb:
block_windowed = block.T * np.hanning(block_size)
block_spectrum = np.fft.rfft(block_windowed)
stream = sd.InputStream(callback=input_callback, channels=1)
stream.start()
Source code
Source code is available on GitHub.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file blockbuffer-0.0.4.tar.gz
.
File metadata
- Download URL: blockbuffer-0.0.4.tar.gz
- Upload date:
- Size: 4.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fd7560a692f44900bfabc1db9fef6acabfcbe3f5a37e83f8c26ede956e35888b |
|
MD5 | 198152fa19a0892b052c035d8f103c7c |
|
BLAKE2b-256 | 71c5dfe0b6018a41124024383f4c2a287f02508f235cc91bfa2ac16648d89383 |