aa56af1ecb
This keeps the decoder matrices and coefficient mapping together for if it changes in the future.
50 lines
1.4 KiB
C
50 lines
1.4 KiB
C
#ifndef ALC_HRTF_H
|
|
#define ALC_HRTF_H
|
|
|
|
#include "AL/al.h"
|
|
#include "AL/alc.h"
|
|
|
|
#include "alMain.h"
|
|
#include "alstring.h"
|
|
|
|
|
|
struct Hrtf {
|
|
ALuint sampleRate;
|
|
ALsizei irSize;
|
|
ALubyte evCount;
|
|
|
|
const ALubyte *azCount;
|
|
const ALushort *evOffset;
|
|
const ALshort *coeffs;
|
|
const ALubyte *delays;
|
|
|
|
const char *filename;
|
|
struct Hrtf *next;
|
|
};
|
|
|
|
#define HRTFDELAY_BITS (20)
|
|
#define HRTFDELAY_FRACONE (1<<HRTFDELAY_BITS)
|
|
#define HRTFDELAY_MASK (HRTFDELAY_FRACONE-1)
|
|
|
|
/* The maximum number of virtual speakers used to generate HRTF coefficients
|
|
* for decoding B-Format.
|
|
*/
|
|
#define HRTF_AMBI_MAX_CHANNELS 16
|
|
|
|
void FreeHrtfs(void);
|
|
|
|
vector_HrtfEntry EnumerateHrtf(const_al_string devname);
|
|
void FreeHrtfList(vector_HrtfEntry *list);
|
|
|
|
void GetHrtfCoeffs(const struct Hrtf *Hrtf, ALfloat elevation, ALfloat azimuth, ALfloat spread, ALfloat gain, ALfloat (*coeffs)[2], ALsizei *delays);
|
|
|
|
/**
|
|
* Produces HRTF filter coefficients for decoding B-Format, given a set of
|
|
* virtual speaker positions and HF/LF matrices for decoding to them. The
|
|
* returned coefficients are ordered and scaled according to the matrices.
|
|
* Returns the maximum impulse-response length of the generated coefficients.
|
|
*/
|
|
ALsizei BuildBFormatHrtf(const struct Hrtf *Hrtf, ALfloat (*coeffs)[HRIR_LENGTH][2], ALsizei NumChannels, const ALfloat (*restrict AmbiPoints)[2], const ALfloat (*restrict AmbiMatrix)[2][MAX_AMBI_COEFFS], ALsizei AmbiCount);
|
|
|
|
#endif /* ALC_HRTF_H */
|