diff options
author | Chris Robinson <[email protected]> | 2018-12-10 22:32:10 -0800 |
---|---|---|
committer | Chris Robinson <[email protected]> | 2018-12-10 22:35:32 -0800 |
commit | 0d36ba0fbbed583e5f5fbe0a99fa0fd60773e2e0 (patch) | |
tree | ccece6d3fb7130026316134bdc60b1f0d38ba63f /Alc/bformatdec.cpp | |
parent | e87eb07db411a0ecd02b5b5c50a4a721150e846e (diff) |
Use helpers to get the Ambisonic scales and layout maps
Diffstat (limited to 'Alc/bformatdec.cpp')
-rw-r--r-- | Alc/bformatdec.cpp | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/Alc/bformatdec.cpp b/Alc/bformatdec.cpp index 8b12149a..888c7cab 100644 --- a/Alc/bformatdec.cpp +++ b/Alc/bformatdec.cpp @@ -69,6 +69,13 @@ ALsizei GetACNIndex(const BFChannelConfig *chans, ALsizei numchans, ALsizei acn) } #define GetChannelForACN(b, a) GetACNIndex((b).Ambi.Map, (b).NumChannels, (a)) +auto GetAmbiScales(AmbDecScale scaletype) noexcept -> decltype(AmbiScale::N3D2N3D)& +{ + if(scaletype == AmbDecScale::FuMa) return AmbiScale::FuMa2N3D; + if(scaletype == AmbDecScale::SN3D) return AmbiScale::SN3D2N3D; + return AmbiScale::N3D2N3D; +} + } // namespace @@ -122,10 +129,7 @@ void BFormatDec::reset(const AmbDecConf *conf, ALsizei chancount, ALuint srate, mUpSampler[3].Gains[LF_BAND] = 0.0f; } - const ALfloat (&coeff_scale)[MAX_AMBI_COEFFS] = - (conf->CoeffScale == AmbDecScale::FuMa) ? AmbiScale::FuMa2N3D : - (conf->CoeffScale == AmbDecScale::SN3D) ? AmbiScale::SN3D2N3D : - /*(conf->CoeffScale == AmbDecScale::N3D) ?*/ AmbiScale::N3D2N3D; + const ALfloat (&coeff_scale)[MAX_AMBI_COEFFS] = GetAmbiScales(conf->CoeffScale); mMatrix = MatrixU{}; if(conf->FreqBands == 1) |