hrtfer
Creates 3D audio for two speakers. Output is binaural (headphone) 3D audio.
Note
This opcode is deprecated; use hrtfstat or similar opcode instead
Syntax
Initialization
kAz -- azimuth value in degrees. Positive values represent position on the right, negative values are positions on the left.
kElev -- elevation value in degrees. Positive values represent position above horizontal, negative values are positions under horizontal.
At present, the only file which can be used with hrtfer is HRTFcompact. It must be passed to the opcode as the last argument within quotes as shown above.
HRTFcompact may also be obtained via anonymous ftp from: ftp://ftp.cs.bath.ac.uk/pub/dream/utilities/Analysis/HRTFcompact
Performance
These unit generators place a mono input signal in a virtual 3D space around the listener by convolving the input with the appropriate HRTF data specified by the opcode's azimuth and elevation values. hrtfer allows these values to be k-values, allowing for dynamic spatialization. hrtfer can only place the input at the requested position because the HRTF is loaded in at i-time (remember that currently, CSound has a limit of 20 files it can hold in memory, otherwise it causes a segmentation fault). The output will need to be scaled either by using balance or by multiplying the output by some scaling constant.
Note
The sampling rate of the orchestra must be 44.1kHz. This is because 44.1kHz is the sampling rate at which the HRTFs were measured. In order to be used at a different rate, the HRTFs would need to be re-sampled at the desired rate.
Examples
Here is an example of the hrtfer opcode. It uses the file hrtfer.csd, HRTFcompact, and drumsMlp.wav.
See also
Panning and Spatialization: Binaural spatialization
Credits
Authors: Eli Breder and David MacIntyre
Montreal
1996
Fixed the example thanks to a message from Istvan Varga.