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_
 |