aboutsummaryrefslogtreecommitdiffstats
path: root/Alc/bformatdec.cpp
diff options
context:
space:
mode:
authorChris Robinson <[email protected]>2018-12-10 22:32:10 -0800
committerChris Robinson <[email protected]>2018-12-10 22:35:32 -0800
commit0d36ba0fbbed583e5f5fbe0a99fa0fd60773e2e0 (patch)
treeccece6d3fb7130026316134bdc60b1f0d38ba63f /Alc/bformatdec.cpp
parente87eb07db411a0ecd02b5b5c50a4a721150e846e (diff)
Use helpers to get the Ambisonic scales and layout maps
Diffstat (limited to 'Alc/bformatdec.cpp')
-rw-r--r--Alc/bformatdec.cpp12
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)