sofar 0.3.0

Pure Rust SOFA/HRTF reader and renderer
Documentation

Sofar

Pure Rust SOFA Reader and HRTF Renderer

Features

A pure Rust implementation for reading HRTF filters from SOFA files (Spatially Oriented Format for Acoustics).

The render module implements uniformly partitioned convolution algorithm for rendering HRTF filters.

Based on the libmysofa C library by Christian Hoene / Symonics GmbH.

Example


use sofar::reader::{OpenOptions, Filter};
use sofar::render::Renderer;

// Open sofa file, resample HRTF data if needed to 44_100
let sofa = OpenOptions::new()
    .sample_rate(44100.0)
    .open("my/sofa/file.sofa")
    .unwrap();

let filt_len = sofa.filter_len();
let mut filter = Filter::new(filt_len);

// Get filter at position
sofa.filter(0.0, 1.0, 0.0, &mut filter);

let mut render = Renderer::builder(filt_len)
    .with_sample_rate(44100.0)
    .with_partition_len(64)
    .build()
    .unwrap();

render.set_filter(&filter).unwrap();

let input = vec![0.0; 256];
let mut left = vec![0.0; 256];
let mut right = vec![0.0; 256];

// read_input()

render.process_block(&input, &mut left, &mut right).unwrap();

You can run cpal renderer example like this:

cargo run --example renderer -- <FILENAME-MONO.wav> libmysofa-sys/libmysofa/share/default.sofa

Acknowledgments

This project is a Rust port of libmysofa, a C library for reading SOFA files.

  • libmysofa Copyright © 2016-2017 Symonics GmbH, Christian Hoene (BSD-3-Clause)
  • KD-tree Copyright © 2007-2011 John Tsiombikas (BSD-3-Clause)

See the NOTICE file for full attribution details.

License

This project is licensed under either of

at your option.