mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-13 22:00:47 +01:00

- Directly include api/audio/audio_frame.h everywhere AudioFrame is used. - This *will* remove transient dependencies on libjpeg and a bunch of other things from the e.g. APM. - audio_frame.h still included from module_common_types.h for backwards compatibility with clients. Bug: webrtc:9139, webrtc:7504 Change-Id: Id96f9268c01667fbcc29a01f5c1dd25a37836897 Reviewed-on: https://webrtc-review.googlesource.com/62464 Commit-Queue: Fredrik Solenberg <solenberg@webrtc.org> Reviewed-by: Karl Wiberg <kwiberg@webrtc.org> Cr-Commit-Position: refs/heads/master@{#22845}
64 lines
2.2 KiB
C++
64 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 "common_types.h" // NOLINT(build/include)
|
|
|
|
//
|
|
// 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_
|