X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Faudio_analysis.h;h=038059502b225f44de78208bd32913cfd722b631;hp=0a5e6194dfccf13f396cd8e02f9f1e08715ed1a3;hb=da44da6f31f97d39ca91c35955e573e76371f2c2;hpb=f0192490565c72aa9838f40cbab56c4c0c60e522 diff --git a/src/lib/audio_analysis.h b/src/lib/audio_analysis.h index 0a5e6194d..038059502 100644 --- a/src/lib/audio_analysis.h +++ b/src/lib/audio_analysis.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2018 Carl Hetherington + Copyright (C) 2012-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,9 +18,11 @@ */ + #ifndef DCPOMATIC_AUDIO_ANALYSIS_H #define DCPOMATIC_AUDIO_ANALYSIS_H + #include "dcpomatic_time.h" #include "audio_point.h" #include @@ -28,13 +30,16 @@ #include #include + namespace xmlpp { class Element; } + class Playlist; -class AudioAnalysis : public boost::noncopyable + +class AudioAnalysis { public: explicit AudioAnalysis (int c); @@ -43,13 +48,13 @@ public: void add_point (int c, AudioPoint const & p); struct PeakTime { - PeakTime (float p, DCPTime t) + PeakTime (float p, dcpomatic::DCPTime t) : peak (p) , time (t) {} float peak; - DCPTime time; + dcpomatic::DCPTime time; }; void set_sample_peak (std::vector peak) { @@ -100,7 +105,7 @@ public: _analysis_gain = gain; } - boost::optional samples_per_point () const { + int64_t samples_per_point () const { return _samples_per_point; } @@ -108,7 +113,7 @@ public: _samples_per_point = spp; } - boost::optional sample_rate () const { + int sample_rate () const { return _sample_rate; } @@ -116,25 +121,35 @@ public: _sample_rate = sr; } + void set_leqm (double leqm) { + _leqm = leqm; + } + + boost::optional leqm () const { + return _leqm; + } + void write (boost::filesystem::path); - float gain_correction (boost::shared_ptr playlist); + float gain_correction (std::shared_ptr playlist); private: - std::vector > _data; + std::vector> _data; std::vector _sample_peak; std::vector _true_peak; boost::optional _integrated_loudness; boost::optional _loudness_range; + boost::optional _leqm; /** If this analysis was run on a single piece of * content we store its gain in dB when the analysis * happened. */ boost::optional _analysis_gain; - boost::optional _samples_per_point; - boost::optional _sample_rate; + int64_t _samples_per_point = 0; + int _sample_rate = 0; static int const _current_state_version; }; + #endif