65282b1926ee349617fcc2bae57f88775c4c4f49
[dcpomatic.git] / src / lib / analyse_audio_job.h
1 /*
2     Copyright (C) 2012-2015 Carl Hetherington <cth@carlh.net>
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
18 */
19
20 /** @file  src/lib/analyse_audio_job.h
21  *  @brief AnalyseAudioJob class.
22  */
23
24 #include "job.h"
25 #include "audio_point.h"
26 #include "types.h"
27
28 class AudioBuffers;
29 class AudioAnalysis;
30 class Playlist;
31 class AudioPoint;
32 class AudioFilterGraph;
33 class Filter;
34
35 /** @class AnalyseAudioJob
36  *  @brief A job to analyse the audio of a film and make a note of its
37  *  broad peak and RMS levels.
38  *
39  *  After computing the peak and RMS levels the job will write a file
40  *  to Film::audio_analysis_path.
41  */
42 class AnalyseAudioJob : public Job
43 {
44 public:
45         AnalyseAudioJob (boost::shared_ptr<const Film>, boost::shared_ptr<const Playlist>);
46         ~AnalyseAudioJob ();
47
48         std::string name () const;
49         std::string json_name () const;
50         void run ();
51
52         boost::shared_ptr<const Playlist> playlist () const {
53                 return _playlist;
54         }
55
56 private:
57         void analyse (boost::shared_ptr<const AudioBuffers>);
58
59         boost::shared_ptr<const Playlist> _playlist;
60
61         int64_t _done;
62         int64_t _samples_per_point;
63         AudioPoint* _current;
64
65         float _sample_peak;
66         Frame _sample_peak_frame;
67
68         boost::shared_ptr<AudioAnalysis> _analysis;
69
70         boost::shared_ptr<AudioFilterGraph> _ebur128;
71         std::vector<Filter const *> _filters;
72
73         static const int _num_points;
74 };