| SAF
    | 
A frequency-dependent Ambisonic decoder for reproducing Ambisonic sound scenes over loudspeakers. More...
Go to the source code of this file.
| Data Structures | |
| struct | ambi_dec_codecPars | 
| Contains variables for sofa file loading, HRTF interpolation, and the loudspeaker decoders.  More... | |
| struct | ambi_dec_data | 
| Main structure for ambi_dec.  More... | |
| Macros | |
| #define | AMBI_DEC_FRAME_SIZE ( 128 ) | 
| Framesize, in time-domain samples. | |
| #define | HOP_SIZE ( 128 ) | 
| STFT hop size. | |
| #define | HYBRID_BANDS ( HOP_SIZE + 5 ) | 
| Number of frequency bands. | |
| #define | TIME_SLOTS ( AMBI_DEC_FRAME_SIZE / HOP_SIZE ) | 
| Number of STFT timeslots. | |
| #define | MAX_NUM_LOUDSPEAKERS ( MAX_NUM_OUTPUTS ) | 
| Maximum permitted output channels. | |
| #define | MIN_NUM_LOUDSPEAKERS ( 4 ) | 
| To avoid triangulation errors when using AllRAD. | |
| #define | NUM_DECODERS ( 2 ) | 
| One for low-frequencies and another for high-frequencies. | |
| Typedefs | |
| typedef AMBI_DEC_DECODING_METHODS | _Atomic_AMBI_DEC_DECODING_METHODS | 
| typedef AMBI_DEC_DIFFUSE_FIELD_EQ_APPROACH | _Atomic_AMBI_DEC_DIFFUSE_FIELD_EQ_APPROACH | 
| Functions | |
| void | ambi_dec_setCodecStatus (void *const hCmp, CODEC_STATUS newStatus) | 
| Sets codec status (see CODEC_STATUS enum) | |
| void | ambi_dec_interpHRTFs (void *const hAmbi, float azimuth_deg, float elevation_deg, float_complex h_intrp[HYBRID_BANDS][NUM_EARS]) | 
| Interpolates between the 3 nearest HRTFs using amplitude-preserving VBAP gains. | |
| void | loadLoudspeakerArrayPreset (LOUDSPEAKER_ARRAY_PRESETS preset, _Atomic_FLOAT32 dirs_deg[MAX_NUM_LOUDSPEAKERS][2], _Atomic_INT32 *nCH, int *nDims) | 
| Returns the loudspeaker directions for a specified loudspeaker array preset. | |
A frequency-dependent Ambisonic decoder for reproducing Ambisonic sound scenes over loudspeakers.
Different decoder settings can be specified for the low and high frequencies. A number of decoding options are also offered, including [1,2]. When utilising spherical harmonic signals derived from real microphone arrays, this implementation also allows the decoding order to be specified per frequency band; of course, this may also be used creatively. An optional, loudspeaker channel binauraliser is included, along with with SOFA file loading, for headphone listening.
The algorithms utilised in this Ambisonic decoder were pieced together and developed in collaboration with Archontis Politis.
Definition in file ambi_dec_internal.h.
| #define AMBI_DEC_FRAME_SIZE ( 128 ) | 
Framesize, in time-domain samples.
Definition at line 65 of file ambi_dec_internal.h.
| #define HOP_SIZE ( 128 ) | 
STFT hop size.
Definition at line 68 of file ambi_dec_internal.h.
| #define HYBRID_BANDS ( HOP_SIZE + 5 ) | 
Number of frequency bands.
Definition at line 69 of file ambi_dec_internal.h.
| #define MAX_NUM_LOUDSPEAKERS ( MAX_NUM_OUTPUTS ) | 
Maximum permitted output channels.
Definition at line 71 of file ambi_dec_internal.h.
| #define MIN_NUM_LOUDSPEAKERS ( 4 ) | 
To avoid triangulation errors when using AllRAD.
Definition at line 72 of file ambi_dec_internal.h.
| #define NUM_DECODERS ( 2 ) | 
One for low-frequencies and another for high-frequencies.
Definition at line 73 of file ambi_dec_internal.h.
| #define TIME_SLOTS ( AMBI_DEC_FRAME_SIZE / HOP_SIZE ) | 
Number of STFT timeslots.
Definition at line 70 of file ambi_dec_internal.h.
Definition at line 84 of file ambi_dec_internal.h.
Definition at line 85 of file ambi_dec_internal.h.
| void ambi_dec_interpHRTFs | ( | void *const | hAmbi, | 
| float | azimuth_deg, | ||
| float | elevation_deg, | ||
| float_complex | h_intrp[HYBRID_BANDS][NUM_EARS] ) | 
Interpolates between the 3 nearest HRTFs using amplitude-preserving VBAP gains.
The HRTF magnitude responses and HRIR ITDs are interpolated seperately before being re-combined.
| [in] | hAmbi | ambi_dec handle | 
| [in] | azimuth_deg | Interpolation direction azimuth in DEGREES | 
| [in] | elevation_deg | Interpolation direction elevation in DEGREES | 
| [out] | h_intrp | Interpolated HRTF | 
Definition at line 59 of file ambi_dec_internal.c.
| void ambi_dec_setCodecStatus | ( | void *const | hCmp, | 
| CODEC_STATUS | newStatus ) | 
Sets codec status (see CODEC_STATUS enum)
Definition at line 48 of file ambi_dec_internal.c.
| void loadLoudspeakerArrayPreset | ( | LOUDSPEAKER_ARRAY_PRESETS | preset, | 
| _Atomic_FLOAT32 | dirs_deg[MAX_NUM_LOUDSPEAKERS][2], | ||
| _Atomic_INT32 * | nCH, | ||
| int * | nDims ) | 
Returns the loudspeaker directions for a specified loudspeaker array preset.
The function also returns the number of loudspeakers in the array, and a crude estimate of whether it is 2D or 3D (based on whether the sum of the absolute loudspeaker elevation angle is not zero). Note: 2-D setups which are not on the horizontal plane (i.e. all elevations==0) will be registered as a 3-D setup. Further Note: default uniformly distributed points are used to pad the dirs_deg matrix up to the MAX_NUM_LOUDSPEAKERS, if nCH is less than this. This can help avoid scenarios of many sources being panned in the same direction, or triangulations errors.
| [in] | preset | See LOUDSPEAKER_ARRAY_PRESETS enum | 
| [out] | dirs_deg | Loudspeaker directions, [azimuth elevation] convention, in DEGREES; | 
| [out] | nCH | (&) number of loudspeaker directions in the array | 
| [out] | nDims | (&) number of dimensions (2 or 3) | 
Definition at line 117 of file ambi_dec_internal.c.