1 /*
2  *  Copyright (c) 2013 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 
11 #ifndef WEBRTC_COMMON_AUDIO_RESAMPLER_INCLUDE_PUSH_RESAMPLER_H_
12 #define WEBRTC_COMMON_AUDIO_RESAMPLER_INCLUDE_PUSH_RESAMPLER_H_
13 
14 #include "webrtc/base/scoped_ptr.h"
15 #include "webrtc/typedefs.h"
16 
17 namespace webrtc {
18 
19 class PushSincResampler;
20 
21 // Wraps PushSincResampler to provide stereo support.
22 // TODO(ajm): add support for an arbitrary number of channels.
23 template <typename T>
24 class PushResampler {
25  public:
26   PushResampler();
27   virtual ~PushResampler();
28 
29   // Must be called whenever the parameters change. Free to be called at any
30   // time as it is a no-op if parameters have not changed since the last call.
31   int InitializeIfNeeded(int src_sample_rate_hz, int dst_sample_rate_hz,
32                          size_t num_channels);
33 
34   // Returns the total number of samples provided in destination (e.g. 32 kHz,
35   // 2 channel audio gives 640 samples).
36   int Resample(const T* src, size_t src_length, T* dst, size_t dst_capacity);
37 
38  private:
39   rtc::scoped_ptr<PushSincResampler> sinc_resampler_;
40   rtc::scoped_ptr<PushSincResampler> sinc_resampler_right_;
41   int src_sample_rate_hz_;
42   int dst_sample_rate_hz_;
43   size_t num_channels_;
44   rtc::scoped_ptr<T[]> src_left_;
45   rtc::scoped_ptr<T[]> src_right_;
46   rtc::scoped_ptr<T[]> dst_left_;
47   rtc::scoped_ptr<T[]> dst_right_;
48 };
49 
50 }  // namespace webrtc
51 
52 #endif  // WEBRTC_COMMON_AUDIO_RESAMPLER_INCLUDE_PUSH_RESAMPLER_H_
53