diff options
| author | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2013-09-25 12:05:06 +0000 |
|---|---|---|
| committer | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2013-09-25 12:05:06 +0000 |
| commit | 6b48eaf5918e54b4f6cc7e9366da72ee6fe416b6 (patch) | |
| tree | c9444416ff941a434fed97b7d2d786fa194088f9 /src/plugins/General/rgscan/gain_analysis.c | |
| parent | 9705552640a9c340df9c8a8b3c3ce07ede56c278 (diff) | |
| download | qmmp-6b48eaf5918e54b4f6cc7e9366da72ee6fe416b6.tar.gz qmmp-6b48eaf5918e54b4f6cc7e9366da72ee6fe416b6.tar.bz2 qmmp-6b48eaf5918e54b4f6cc7e9366da72ee6fe416b6.zip | |
rgscan: added album gain calculation
git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@3723 90c681e8-e032-0410-971d-27865f9a5e38
Diffstat (limited to 'src/plugins/General/rgscan/gain_analysis.c')
| -rw-r--r-- | src/plugins/General/rgscan/gain_analysis.c | 49 |
1 files changed, 33 insertions, 16 deletions
diff --git a/src/plugins/General/rgscan/gain_analysis.c b/src/plugins/General/rgscan/gain_analysis.c index 9829537f5..a3535d5fd 100644 --- a/src/plugins/General/rgscan/gain_analysis.c +++ b/src/plugins/General/rgscan/gain_analysis.c @@ -136,7 +136,7 @@ struct GainHandle int freqindex; int first; Uint32_t A [(size_t)(STEPS_per_dB * MAX_dB)]; - Uint32_t B [(size_t)(STEPS_per_dB * MAX_dB)]; +// Uint32_t B [(size_t)(STEPS_per_dB * MAX_dB)]; }; // for each filter: @@ -293,7 +293,7 @@ InitGainAnalysis (GainHandle_t **handle, long samplefreq ) (*handle)->lout = (*handle)->loutbuf + MAX_ORDER; (*handle)->rout = (*handle)->routbuf + MAX_ORDER; - memset((*handle)->B, 0, sizeof((*handle)->B)); + //memset((*handle)->B, 0, sizeof((*handle)->B)); return INIT_GAIN_ANALYSIS_OK; } @@ -445,43 +445,42 @@ int AnalyzeSamples (GainHandle_t *handle, const Float_t* left_samples, const Flo } -static Float_t -analyzeResult ( Uint32_t* Array, size_t len ) +static Float_t analyzeResult (Uint32_t* Array, size_t len) { - Uint32_t elems; + Uint32_t elems = 0; Int32_t upper; size_t i; elems = 0; - for ( i = 0; i < len; i++ ) + for (i = 0; i < len; i++) elems += Array[i]; - if ( elems == 0 ) + if (elems == 0) return GAIN_NOT_ENOUGH_SAMPLES; upper = (Int32_t) ceil (elems * (1. - RMS_PERCENTILE)); - for ( i = len; i-- > 0; ) { - if ( (upper -= Array[i]) <= 0 ) + for (i = len; i-- > 0; ) + { + if ((upper -= Array[i]) <= 0) break; } return (Float_t) ((Float_t)PINK_REF - (Float_t)i / (Float_t)STEPS_per_dB); } - Float_t GetTitleGain(GainHandle_t *handle) { Float_t retval; int i = 0; - retval = analyzeResult (handle->A, sizeof(handle->A)/sizeof(*handle->A) ); + retval = analyzeResult (handle->A, sizeof(handle->A)/sizeof(*handle->A)); - for (i = 0; i < (int)(sizeof(handle->A)/sizeof(*handle->A)); i++ ) + /*for (i = 0; i < (int)(sizeof(handle->A)/sizeof(*handle->A)); i++ ) { handle->B[i] += handle->A[i]; handle->A[i] = 0; - } + }*/ - for ( i = 0; i < MAX_ORDER; i++ ) + for (i = 0; i < MAX_ORDER; i++ ) { handle->linprebuf[i] = handle->lstepbuf[i] = handle->loutbuf[i] = 0.f; handle->rinprebuf[i] = handle->rstepbuf[i] = handle->routbuf[i] = 0.f; @@ -492,11 +491,27 @@ Float_t GetTitleGain(GainHandle_t *handle) return retval; } +Float_t GetAlbumGain(GainHandle_t **handle, int count) +{ + Uint32_t B [(size_t)(STEPS_per_dB * MAX_dB)]; + memset (B, 0, sizeof(B)); + + int i = 0, j = 0; + + for(i = 0; i < count; ++i) + { + for(j = 0; j < sizeof(handle[i]->A)/sizeof(*handle[i]->A); ++j) + { + B[j] += handle[i]->A[j]; + } + } + return analyzeResult(B, sizeof(B)/sizeof(*B)); +} -Float_t GetAlbumGain(GainHandle_t *handle) +/*Float_t GetAlbumGain(GainHandle_t *handle) { return analyzeResult (handle->B, sizeof(handle->B)/sizeof(*handle->B)); -} +}*/ void DeinitGainAbalysis(GainHandle_t *handle) { @@ -507,3 +522,5 @@ void DeinitGainAbalysis(GainHandle_t *handle) + + |
