X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=audio_mixer.h;h=6e7719f23313238b5bebaab70fea90e47af1c8b0;hb=54067dbc70999d936adf9d263b5ff2b1efb4dfd0;hp=d00e8ecb4eeb3dd968940575944b9de5e8eba77e;hpb=6fe61fb9769469b573d84d1b9f06c7316b6937ed;p=nageru diff --git a/audio_mixer.h b/audio_mixer.h index d00e8ec..6e7719f 100644 --- a/audio_mixer.h +++ b/audio_mixer.h @@ -201,10 +201,17 @@ public: return final_makeup_gain_auto; } + struct BusLevel { + float current_level_dbfs[2]; // Digital peak of last frame, left and right. + float peak_level_dbfs[2]; // Digital peak with hold, left and right. + float gain_staging_db; + float compressor_attenuation_db; // A positive number; 0.0 for no attenuation. + }; + typedef std::function bus_level_lufs, + std::vector bus_levels, float global_level_lufs, float range_low_lufs, float range_high_lufs, - std::vector gain_staging_db, float final_makeup_gain_db, + float final_makeup_gain_db, float correlation)> audio_level_callback_t; void set_audio_level_callback(audio_level_callback_t callback) { @@ -230,7 +237,7 @@ private: void reset_alsa_mutex_held(DeviceSpec device_spec); std::map get_devices_mutex_held() const; void update_meters(const std::vector &samples); - void measure_bus_levels(unsigned bus_index, const std::vector &left, const std::vector &right); + void measure_bus_levels(unsigned bus_index, const std::vector &left, const std::vector &right, float volume); void send_audio_level_callback(); unsigned num_cards; @@ -263,6 +270,14 @@ private: std::atomic compressor_threshold_dbfs[MAX_BUSES]; std::atomic compressor_enabled[MAX_BUSES]; + struct PeakHistory { + float current_level = 0.0f; // Peak of the last frame (not in dB). + float current_peak = 0.0f; // Current peak of the peak meter (not in dB). + float last_peak = 0.0f; + float age_seconds = 0.0f; // Time since "last_peak" was set. + }; + PeakHistory peak_history[MAX_BUSES][2]; // Separate for each channel. + double final_makeup_gain = 1.0; // Under compressor_mutex. Read/write by the user. Note: Not in dB, we want the numeric precision so that we can change it slowly. bool final_makeup_gain_auto = true; // Under compressor_mutex. @@ -275,12 +290,6 @@ private: CorrelationMeasurer correlation; // Under audio_measure_mutex. Resampler peak_resampler; // Under audio_measure_mutex. std::atomic peak{0.0f}; - - // Under audio_measure_mutex. Note that Ebu_r128_proc has a broken - // copy constructor (it uses the default, but holds arrays), - // so we can't just use raw Ebu_r128_proc elements, but need to use - // unique_ptrs. - std::vector> bus_r128; }; #endif // !defined(_AUDIO_MIXER_H)