From 4ae0193c125cc70176eb1660919d507fbf5378e4 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Wed, 8 Nov 2023 00:18:22 +0100 Subject: Don't feed channels to leqm that we don't have a correction factor for (#2647). --- src/lib/audio_analyser.cc | 15 +++++++-------- src/lib/audio_analyser.h | 1 + 2 files changed, 8 insertions(+), 8 deletions(-) (limited to 'src/lib') diff --git a/src/lib/audio_analyser.cc b/src/lib/audio_analyser.cc index 687da9cef..8cbc3145b 100644 --- a/src/lib/audio_analyser.cc +++ b/src/lib/audio_analyser.cc @@ -86,14 +86,14 @@ AudioAnalyser::AudioAnalyser (shared_ptr film, shared_ptraudio_channels(); + _leqm_channels = film->audio_channels(); auto content = _playlist->content(); if (content.size() == 1 && content[0]->audio) { - leqm_channels = content[0]->audio->mapping().mapped_output_channels().size(); + _leqm_channels = content[0]->audio->mapping().mapped_output_channels().size(); } /* XXX: is this right? Especially for more than 5.1? */ - vector channel_corrections(leqm_channels, 1); + vector channel_corrections(_leqm_channels, 1); add_if_required (channel_corrections, 4, -3); // Ls add_if_required (channel_corrections, 5, -3); // Rs add_if_required (channel_corrections, 6, -144); // HI @@ -108,7 +108,7 @@ AudioAnalyser::AudioAnalyser (shared_ptr film, shared_ptraudio_frame_rate(), 24, channel_corrections, @@ -150,15 +150,14 @@ AudioAnalyser::analyse (shared_ptr b, DCPTime time) #endif int const frames = b->frames (); - int const channels = b->channels (); - vector interleaved(frames * channels); + vector interleaved(frames * _leqm_channels); - for (int j = 0; j < channels; ++j) { + for (int j = 0; j < _leqm_channels; ++j) { float const* data = b->data(j); for (int i = 0; i < frames; ++i) { float s = data[i]; - interleaved[i * channels + j] = s; + interleaved[i * _leqm_channels + j] = s; float as = fabsf (s); if (as < 10e-7) { diff --git a/src/lib/audio_analyser.h b/src/lib/audio_analyser.h index 01eec36b1..3568d853d 100644 --- a/src/lib/audio_analyser.h +++ b/src/lib/audio_analyser.h @@ -71,6 +71,7 @@ private: Frame _samples_per_point = 1; boost::scoped_ptr _leqm; + int _leqm_channels = 0; Frame _done = 0; std::vector _sample_peak; std::vector _sample_peak_frame; -- cgit v1.2.3