axmol/thirdparty/openal/core/hrtf.h

90 lines
2.3 KiB
C
Raw Normal View History

2021-05-14 10:15:42 +08:00
#ifndef CORE_HRTF_H
#define CORE_HRTF_H
#include <array>
#include <cstddef>
#include <memory>
#include <string>
#include "almalloc.h"
#include "aloptional.h"
2021-05-14 10:15:42 +08:00
#include "alspan.h"
#include "atomic.h"
#include "ambidefs.h"
#include "bufferline.h"
#include "mixer/hrtfdefs.h"
#include "intrusive_ptr.h"
#include "vector.h"
2021-05-14 10:15:42 +08:00
struct HrtfStore {
RefCount mRef;
2023-02-04 15:03:54 +08:00
uint mSampleRate : 24;
uint mIrSize : 8;
2021-05-14 10:15:42 +08:00
struct Field {
float distance;
ubyte evCount;
};
/* NOTE: Fields are stored *backwards*. field[0] is the farthest field, and
* field[fdCount-1] is the nearest.
*/
2023-02-04 15:03:54 +08:00
al::span<const Field> mFields;
2021-05-14 10:15:42 +08:00
struct Elevation {
ushort azCount;
ushort irOffset;
};
2023-02-04 15:03:54 +08:00
Elevation *mElev;
const HrirArray *mCoeffs;
const ubyte2 *mDelays;
void getCoeffs(float elevation, float azimuth, float distance, float spread, HrirArray &coeffs,
const al::span<uint,2> delays);
2021-05-14 10:15:42 +08:00
void add_ref();
2023-02-04 15:03:54 +08:00
void dec_ref();
2021-05-14 10:15:42 +08:00
DEF_PLACE_NEWDEL()
};
using HrtfStorePtr = al::intrusive_ptr<HrtfStore>;
struct EvRadians { float value; };
struct AzRadians { float value; };
struct AngularPoint {
EvRadians Elev;
AzRadians Azim;
};
struct DirectHrtfState {
2022-04-25 12:02:45 +08:00
std::array<float,BufferLineSize> mTemp;
2021-05-14 10:15:42 +08:00
/* HRTF filter state for dry buffer content */
uint mIrSize{0};
al::FlexArray<HrtfChannelState> mChannels;
DirectHrtfState(size_t numchans) : mChannels{numchans} { }
/**
* Produces HRTF filter coefficients for decoding B-Format, given a set of
* virtual speaker positions, a matching decoding matrix, and per-order
* high-frequency gains for the decoder. The calculated impulse responses
* are ordered and scaled according to the matrix input.
*/
2023-02-04 15:03:54 +08:00
void build(const HrtfStore *Hrtf, const uint irSize, const bool perHrirMin,
2021-05-14 10:15:42 +08:00
const al::span<const AngularPoint> AmbiPoints, const float (*AmbiMatrix)[MaxAmbiChannels],
const float XOverFreq, const al::span<const float,MaxAmbiOrder+1> AmbiOrderHFGain);
static std::unique_ptr<DirectHrtfState> Create(size_t num_chans);
DEF_FAM_NEWDEL(DirectHrtfState, mChannels)
};
al::vector<std::string> EnumerateHrtf(al::optional<std::string> pathopt);
2021-05-14 10:15:42 +08:00
HrtfStorePtr GetLoadedHrtf(const std::string &name, const uint devrate);
#endif /* CORE_HRTF_H */