blob: c8cc64a5fff3f12b13a099a14cccfe3491b993a9 [file] [log] [blame]
henrik.lundin@webrtc.orgd94659d2013-01-29 12:09:21 +00001/*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef MODULES_AUDIO_CODING_NETEQ_COMFORT_NOISE_H_
12#define MODULES_AUDIO_CODING_NETEQ_COMFORT_NOISE_H_
henrik.lundin@webrtc.orgd94659d2013-01-29 12:09:21 +000013
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020014#include "modules/audio_coding/neteq/audio_multi_vector.h"
15#include "rtc_base/constructormagic.h"
Mirko Bonadei71207422017-09-15 13:58:09 +020016#include "typedefs.h" // NOLINT(build/include)
henrik.lundin@webrtc.orgd94659d2013-01-29 12:09:21 +000017
18namespace webrtc {
19
20// Forward declarations.
21class DecoderDatabase;
22class SyncBuffer;
23struct Packet;
24
25// This class acts as an interface to the CNG generator.
26class ComfortNoise {
27 public:
28 enum ReturnCodes {
29 kOK = 0,
30 kUnknownPayloadType,
31 kInternalError,
32 kMultiChannelNotSupported
33 };
34
Yves Gerey665174f2018-06-19 15:03:05 +020035 ComfortNoise(int fs_hz,
36 DecoderDatabase* decoder_database,
henrik.lundin@webrtc.orgd94659d2013-01-29 12:09:21 +000037 SyncBuffer* sync_buffer)
38 : fs_hz_(fs_hz),
39 first_call_(true),
40 overlap_length_(5 * fs_hz_ / 8000),
41 decoder_database_(decoder_database),
Yves Gerey665174f2018-06-19 15:03:05 +020042 sync_buffer_(sync_buffer) {}
henrik.lundin@webrtc.orgd94659d2013-01-29 12:09:21 +000043
44 // Resets the state. Should be called before each new comfort noise period.
45 void Reset();
46
47 // Update the comfort noise generator with the parameters in |packet|.
ossua73f6c92016-10-24 08:25:28 -070048 int UpdateParameters(const Packet& packet);
henrik.lundin@webrtc.orgd94659d2013-01-29 12:09:21 +000049
50 // Generates |requested_length| samples of comfort noise and writes to
51 // |output|. If this is the first in call after Reset (or first after creating
52 // the object), it will also mix in comfort noise at the end of the
53 // SyncBuffer object provided in the constructor.
henrik.lundin@webrtc.orgfd11bbf2013-09-30 20:38:44 +000054 int Generate(size_t requested_length, AudioMultiVector* output);
henrik.lundin@webrtc.orgd94659d2013-01-29 12:09:21 +000055
56 // Returns the last error code that was produced by the comfort noise
57 // decoder. Returns 0 if no error has been encountered since the last reset.
58 int internal_error_code() { return internal_error_code_; }
59
60 private:
61 int fs_hz_;
62 bool first_call_;
63 size_t overlap_length_;
64 DecoderDatabase* decoder_database_;
65 SyncBuffer* sync_buffer_;
66 int internal_error_code_;
henrikg3c089d72015-09-16 05:37:44 -070067 RTC_DISALLOW_COPY_AND_ASSIGN(ComfortNoise);
henrik.lundin@webrtc.orgd94659d2013-01-29 12:09:21 +000068};
69
70} // namespace webrtc
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020071#endif // MODULES_AUDIO_CODING_NETEQ_COMFORT_NOISE_H_