diff options
author | Clément Bœsch <u@pkh.me> | 2017-03-22 11:30:53 +0100 |
---|---|---|
committer | Clément Bœsch <u@pkh.me> | 2017-03-22 11:30:53 +0100 |
commit | fd5e1d132b460acc533e7d71148c6eca2c691d99 (patch) | |
tree | fa4b0ee868e81933d6b1447b461412e28f5ac1af /libavcodec/ac3dsp.c | |
parent | e39d4ff150f45d82aabafa5a34f5c9ec7a829d15 (diff) | |
parent | a9ba59591ed509fb7e6decfde8da4cbfd4ddf4b8 (diff) | |
download | ffmpeg-fd5e1d132b460acc533e7d71148c6eca2c691d99.tar.gz |
Merge commit 'a9ba59591ed509fb7e6decfde8da4cbfd4ddf4b8'
* commit 'a9ba59591ed509fb7e6decfde8da4cbfd4ddf4b8':
ac3dsp: Add some special-case handling for the C downmix function
Merged-by: Clément Bœsch <u@pkh.me>
Diffstat (limited to 'libavcodec/ac3dsp.c')
-rw-r--r-- | libavcodec/ac3dsp.c | 39 |
1 files changed, 38 insertions, 1 deletions
diff --git a/libavcodec/ac3dsp.c b/libavcodec/ac3dsp.c index 23abc5685e..47963b99e1 100644 --- a/libavcodec/ac3dsp.c +++ b/libavcodec/ac3dsp.c @@ -216,9 +216,46 @@ static void ac3_sum_square_butterfly_float_c(float sum[4], static void ac3_downmix_c(float **samples, float **matrix, int out_ch, int in_ch, int len) { + int **matrix_cmp = (int **)matrix; int i, j; float v0, v1; - if (out_ch == 2) { + + if (in_ch == 5 && out_ch == 2 && + !(matrix_cmp[1][0] | matrix_cmp[0][2] | + matrix_cmp[1][3] | matrix_cmp[0][4] | + (matrix_cmp[0][1] ^ matrix_cmp[1][1]) | + (matrix_cmp[0][0] ^ matrix_cmp[1][2]))) { + float front_mix = matrix[0][0]; + float center_mix = matrix[0][1]; + float surround_mix = matrix[0][3]; + + for (i = 0; i < len; i++) { + v0 = samples[0][i] * front_mix + + samples[1][i] * center_mix + + samples[3][i] * surround_mix; + + v1 = samples[1][i] * center_mix + + samples[2][i] * front_mix + + samples[4][i] * surround_mix; + + samples[0][i] = v0; + samples[1][i] = v1; + } + } else if (in_ch == 5 && out_ch == 1 && + matrix_cmp[0][0] == matrix_cmp[0][2] && + matrix_cmp[0][3] == matrix_cmp[0][4]) { + float front_mix = matrix[0][0]; + float center_mix = matrix[0][1]; + float surround_mix = matrix[0][3]; + + for (i = 0; i < len; i++) { + samples[0][i] = samples[0][i] * front_mix + + samples[1][i] * center_mix + + samples[2][i] * front_mix + + samples[3][i] * surround_mix + + samples[4][i] * surround_mix; + } + } else if (out_ch == 2) { for (i = 0; i < len; i++) { v0 = v1 = 0.0f; for (j = 0; j < in_ch; j++) { |