Spherical Harmonics Room (shroom): a Python library for room acoustics simulation, Ambisonics processing, and spherical microphone array modelling.
Project description
shroom
Spherical Harmonics Room
A Python library for simulating room acoustics using Spherical Harmonics (Ambisonics). It provides tools for simulating room impulse responses (ARIR), microphone arrays, and binaural rendering.
Features
- Room Simulation: Image Source Method (ISM) adapted for Spherical Harmonics.
- Spatial Signals: Unified handling of Time, Frequency, Space, and Spherical Harmonics (SH) domains.
- Processors: Modular processing chain including:
ArrayDecoder: Simulates spherical microphone arrays.ASMEncoder: Encodes microphone signals to Ambisonics (ASM).BinauralDecoder: Decodes Ambisonics to Binaural audio using HRTFs.
- Rotation: Efficient rotation of sound fields and HRTFs using Wigner-D matrices, or via space domain grid rotation.
- Visualization: 2D and 3D plotting of room geometry, sources, and receiver orientation.
Installation
The package is published on PyPI as pyshroom (not shroom). There are two install flavors:
1. Minimal — just the core library
pip install pyshroom
Installs shroom and its runtime dependencies (numpy, scipy, matplotlib, pyroomacoustics, sofar). This is all you need to simulate rooms, encode Ambisonics, and render binaural audio from your own scripts.
2. With shroom_dev — extras for examples and projects
pip install "pyshroom[dev]"
Installs everything above plus the companion package shroom_dev, which bundles helper modules used by the examples, tests, and research projects in this repo:
shroom_dev.plot—loglog_plotfor error curves with variance bands.shroom_dev.sound—play_audiohelper aroundsounddevice.shroom_dev.errors— the ASM/BSM evaluation metrics used by theprojects/scripts (asm_mse_error,asm_bin_mse_error,asm_bin_magnitude_mse_error,linear_spectral_error,bsm_mse_error,bsm_mag_mse_error).shroom_dev.file_utils— extra file loaders.
The [dev] extra also pulls in pytest, black, sounddevice, and pyyaml.
Running from a git checkout
If you cloned the repo to hack on the library itself, install it editable:
git clone https://github.com/Yhonatangayer/shroom.git
cd shroom
pip install -e ".[dev]"
You can then run the example scripts under examples/ and the research scripts under projects/ directly — they import from shroom and shroom_dev.
Quick Start
Basic Binaural Rendering
import numpy as np
from shroom.acoustics.room import Room
from shroom.paths import DEFAULT_WAV_PATH
# 1. Initialize Room
room = Room(
dimensions=[6.0, 5.0, 3.0],
absorption=0.8,
sh_order=3,
fs=48000
)
# 2. Add Source and Receiver
room.add_source([4.0, 2.0, 1.5], signal=DEFAULT_WAV_PATH)
room.set_receiver([2.0, 2.0, 1.5])
# 3. Compute Ambisonics Response
amb_signal = room.compute_amb()
# 4. Plot
room.plot(plot_3d=True)
Dynamic Head Rotation
import numpy as np
from scipy.spatial.transform import Rotation
from shroom.acoustics.room import Room
from shroom.acoustics.processors import BinauralDecoder
from shroom.utils.file_utils import load_file
from shroom.paths import DEFAULT_HRTF_PATH, DEFAULT_WAV_PATH
# 1. Initialize Room & Compute Ambisonics (Reference Frame)
room = Room(dimensions=[6.0, 5.0, 3.0], sh_order=3, fs=48000)
room.add_source([4.0, 2.0, 1.5], signal=DEFAULT_WAV_PATH)
room.set_receiver([2.0, 2.0, 1.5])
amb_ref = room.compute_amb()
# 2. Load HRTF
hrtf_base = load_file(DEFAULT_HRTF_PATH)
hrtf_base.toSH(N_sp=3)
# 3. Rotate Listener Orientation (Modal Rotation via Wigner-D)
rot = Rotation.from_euler("zyx", [45, 0, 0], degrees=True) # 45 deg Yaw
hrtf_rot = hrtf_base.copy()
hrtf_rot.rotate_sh_domain(rot)
# 4. Decode with Rotated HRTF
decoder = BinauralDecoder(hrtf_rot, sh_order=3)
binaural = decoder.process(amb_ref)
Complete ASM Processing Chain
from shroom.acoustics.processors import ProcessorChain, ArrayDecoder, ASMEncoder, BinauralDecoder
from shroom.encoders.asm import ASM
# 1. Setup Signal Chain: Room -> Array -> ASM Encoder -> Binaural Decoder
# Note: array_time_sh and asm_instance must be pre-configured
chain = ProcessorChain([
ArrayDecoder(array_time_sh), # Simulate mic recordings
ASMEncoder(asm_instance), # Encode mics to Ambisonics (ASM)
BinauralDecoder(hrtf, sh_order=1) # Render to binaural
])
# 2. Process Ambisonics through the Chain
binaural_output = chain.process(room.compute_amb())
Optimized Low-Order Rendering (MagLS)
from shroom.acoustics.hrtf_processing import magls_hrtf
from shroom.acoustics.processors import BinauralDecoder
# 1. Compute MagLS-optimized HRTF (Mitigates spectral artifacts at low SH orders)
hrtf_magls = magls_hrtf(original_hrtf, sh_order=1)
# 2. Decode using optimized modal weights
decoder = BinauralDecoder(hrtf_magls, sh_order=1)
binaural_output = decoder.process(room.compute_amb())
Dependencies
- numpy
- scipy
- matplotlib
- pyroomacoustics
- soundfile
- sounddevice
- sofar
Paper and Citation
If you use shroom in your research, please cite our paper: SHroom: A Python Framework for Ambisonics Room Acoustics Simulation and Binaural Rendering
@misc{gayer2026shroompythonframeworkambisonics,
title={SHroom: A Python Framework for Ambisonics Room Acoustics Simulation and Binaural Rendering},
author={Yhonatan Gayer},
year={2026},
eprint={2603.27342},
archivePrefix={arXiv},
primaryClass={eess.AS},
url={https://arxiv.org/abs/2603.27342},
}
License
MIT License
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyshroom-0.1.1.tar.gz.
File metadata
- Download URL: pyshroom-0.1.1.tar.gz
- Upload date:
- Size: 2.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a4d925e8403c1b0aca290a776dedfc3fc05a5c9bcb21a9847ea3015ec39e10d9
|
|
| MD5 |
c196471e71c257f5fc887360846c05f4
|
|
| BLAKE2b-256 |
1869bcb7d1ad6bd3b0f8e07abbb2ac3070a84715bb6b7e4cfe4bf9a22de1d17c
|
File details
Details for the file pyshroom-0.1.1-py3-none-any.whl.
File metadata
- Download URL: pyshroom-0.1.1-py3-none-any.whl
- Upload date:
- Size: 2.8 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
779b195ca356cefbeb06229fff8f722360145428fa5dff5c4b7a29a9454145b8
|
|
| MD5 |
9872075978d34d447ca307213681f2cd
|
|
| BLAKE2b-256 |
5f1356698a31e3129e89190ae29ed95b6240eb42af4fbad69a7faa14a5e8ab16
|