65 lines
2.2 KiB
C
65 lines
2.2 KiB
C
|
/*
|
||
|
* Copyright (c) 2013 The WebRTC project authors. All Rights Reserved.
|
||
|
*
|
||
|
* Use of this source code is governed by a BSD-style license
|
||
|
* that can be found in the LICENSE file in the root of the source
|
||
|
* tree. An additional intellectual property rights grant can be found
|
||
|
* in the file PATENTS. All contributing project authors may
|
||
|
* be found in the AUTHORS file in the root of the source tree.
|
||
|
*/
|
||
|
|
||
|
#ifndef MODULES_AUDIO_CODING_ACM2_CALL_STATISTICS_H_
|
||
|
#define MODULES_AUDIO_CODING_ACM2_CALL_STATISTICS_H_
|
||
|
|
||
|
#include "api/audio/audio_frame.h"
|
||
|
#include "modules/audio_coding/include/audio_coding_module_typedefs.h"
|
||
|
|
||
|
//
|
||
|
// This class is for book keeping of calls to ACM. It is not useful to log API
|
||
|
// calls which are supposed to be called every 10ms, e.g. PlayoutData10Ms(),
|
||
|
// however, it is useful to know the number of such calls in a given time
|
||
|
// interval. The current implementation covers calls to PlayoutData10Ms() with
|
||
|
// detailed accounting of the decoded speech type.
|
||
|
//
|
||
|
// Thread Safety
|
||
|
// =============
|
||
|
// Please note that this class in not thread safe. The class must be protected
|
||
|
// if different APIs are called from different threads.
|
||
|
//
|
||
|
|
||
|
namespace webrtc {
|
||
|
|
||
|
namespace acm2 {
|
||
|
|
||
|
class CallStatistics {
|
||
|
public:
|
||
|
CallStatistics() {}
|
||
|
~CallStatistics() {}
|
||
|
|
||
|
// Call this method to indicate that NetEq engaged in decoding. |speech_type|
|
||
|
// is the audio-type according to NetEq, and |muted| indicates if the decoded
|
||
|
// frame was produced in muted state.
|
||
|
void DecodedByNetEq(AudioFrame::SpeechType speech_type, bool muted);
|
||
|
|
||
|
// Call this method to indicate that a decoding call resulted in generating
|
||
|
// silence, i.e. call to NetEq is bypassed and the output audio is zero.
|
||
|
void DecodedBySilenceGenerator();
|
||
|
|
||
|
// Get statistics for decoding. The statistics include the number of calls to
|
||
|
// NetEq and silence generator, as well as the type of speech pulled of off
|
||
|
// NetEq, c.f. declaration of AudioDecodingCallStats for detailed description.
|
||
|
const AudioDecodingCallStats& GetDecodingStatistics() const;
|
||
|
|
||
|
private:
|
||
|
// Reset the decoding statistics.
|
||
|
void ResetDecodingStatistics();
|
||
|
|
||
|
AudioDecodingCallStats decoding_stat_;
|
||
|
};
|
||
|
|
||
|
} // namespace acm2
|
||
|
|
||
|
} // namespace webrtc
|
||
|
|
||
|
#endif // MODULES_AUDIO_CODING_ACM2_CALL_STATISTICS_H_
|