From 0a03596af11570f5dba473c93c67c59d285d7bc2 Mon Sep 17 00:00:00 2001 From: Chris Robinson Date: Tue, 22 Mar 2016 14:42:53 -0700 Subject: Simplify setting the matrix coeffs --- Alc/bformatdec.c | 56 ++++++++++++++------------------------------------------ 1 file changed, 14 insertions(+), 42 deletions(-) diff --git a/Alc/bformatdec.c b/Alc/bformatdec.c index fff693bc..f5a8e8c4 100644 --- a/Alc/bformatdec.c +++ b/Alc/bformatdec.c @@ -183,30 +183,16 @@ void bformatdec_reset(BFormatDec *dec, const AmbDecConf *conf, ALuint chancount, { ALuint chan = chanmap[i]; ALuint j, k = 0; + ALfloat gain; - for(j = 0;j < 1;j++) + for(j = 0;j < MAX_AMBI_COEFFS;j++) { + if(j == 0) gain = conf->LFOrderGain[0] / ratio; + else if(j == 1) gain = conf->LFOrderGain[1] / ratio; + else if(j == 4) gain = conf->LFOrderGain[2] / ratio; + else if(j == 9) gain = conf->LFOrderGain[3] / ratio; if((conf->ChanMask&(1<MatrixLF[chan][j] = conf->LFMatrix[i][k++] / coeff_scale[j] * - conf->LFOrderGain[0] / ratio; - } - for(;j < 4;j++) - { - if((conf->ChanMask&(1<MatrixLF[chan][j] = conf->LFMatrix[i][k++] / coeff_scale[j] * - conf->LFOrderGain[1] / ratio; - } - for(;j < 9;j++) - { - if((conf->ChanMask&(1<MatrixLF[chan][j] = conf->LFMatrix[i][k++] / coeff_scale[j] * - conf->LFOrderGain[2] / ratio; - } - for(;j < 16;j++) - { - if((conf->ChanMask&(1<MatrixLF[chan][j] = conf->LFMatrix[i][k++] / coeff_scale[j] * - conf->LFOrderGain[3] / ratio; + dec->MatrixLF[chan][j] = conf->LFMatrix[i][k++] / coeff_scale[j] * gain; } } } @@ -216,30 +202,16 @@ void bformatdec_reset(BFormatDec *dec, const AmbDecConf *conf, ALuint chancount, { ALuint chan = chanmap[i]; ALuint j, k = 0; + ALfloat gain; - for(j = 0;j < 1;j++) - { - if((conf->ChanMask&(1<MatrixHF[chan][j] = conf->HFMatrix[i][k++] / coeff_scale[j] * - conf->HFOrderGain[0] * ratio; - } - for(;j < 4;j++) - { - if((conf->ChanMask&(1<MatrixHF[chan][j] = conf->HFMatrix[i][k++] / coeff_scale[j] * - conf->HFOrderGain[1] * ratio; - } - for(;j < 9;j++) - { - if((conf->ChanMask&(1<MatrixHF[chan][j] = conf->HFMatrix[i][k++] / coeff_scale[j] * - conf->HFOrderGain[2] * ratio; - } - for(;j < 16;j++) + for(j = 0;j < MAX_AMBI_COEFFS;j++) { + if(j == 0) gain = conf->HFOrderGain[0] * ratio; + else if(j == 1) gain = conf->HFOrderGain[1] * ratio; + else if(j == 4) gain = conf->HFOrderGain[2] * ratio; + else if(j == 9) gain = conf->HFOrderGain[3] * ratio; if((conf->ChanMask&(1<MatrixHF[chan][j] = conf->HFMatrix[i][k++] / coeff_scale[j] * - conf->HFOrderGain[3] * ratio; + dec->MatrixHF[chan][j] = conf->HFMatrix[i][k++] / coeff_scale[j] * gain; } } } -- cgit v1.2.3