blob: 366fc32660a70310663e6795b75d406a91c2bee6 [file] [log] [blame]
Alex Loikoe36e8bb2018-02-16 11:54:07 +01001/*
2 * Copyright (c) 2018 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 MODULES_AUDIO_PROCESSING_INCLUDE_AUDIO_FRAME_VIEW_H_
12#define MODULES_AUDIO_PROCESSING_INCLUDE_AUDIO_FRAME_VIEW_H_
13
14#include "api/array_view.h"
15
16// Class to pass audio data in T** format, where T is a numeric type.
17template <class T>
18class AudioFrameView {
19 public:
20 // |num_channels| and |channel_size| describe the T**
21 // |audio_samples|. |audio_samples| is assumed to point to a
22 // two-dimensional |num_channels * channel_size| array of floats.
23 AudioFrameView(T* const* audio_samples,
24 size_t num_channels,
25 size_t channel_size)
26 : audio_samples_(audio_samples),
27 num_channels_(num_channels),
28 channel_size_(channel_size) {}
29
Alex Loiko153f11e2018-02-16 12:39:00 +010030 // Implicit cast to allow converting Frame<float> to
31 // Frame<const float>.
32 template <class U>
33 AudioFrameView(AudioFrameView<U> other)
34 : audio_samples_(other.data()),
35 num_channels_(other.num_channels()),
36 channel_size_(other.samples_per_channel()) {}
37
Alex Loikoe36e8bb2018-02-16 11:54:07 +010038 AudioFrameView() = delete;
39
40 size_t num_channels() const { return num_channels_; }
41
42 size_t samples_per_channel() const { return channel_size_; }
43
44 rtc::ArrayView<T> channel(size_t idx) {
45 RTC_DCHECK_LE(0, idx);
46 RTC_DCHECK_LE(idx, num_channels_);
47 return rtc::ArrayView<T>(audio_samples_[idx], channel_size_);
48 }
49
50 rtc::ArrayView<const T> channel(size_t idx) const {
51 RTC_DCHECK_LE(0, idx);
52 RTC_DCHECK_LE(idx, num_channels_);
53 return rtc::ArrayView<const T>(audio_samples_[idx], channel_size_);
54 }
55
Alex Loiko153f11e2018-02-16 12:39:00 +010056 T* const* data() { return audio_samples_; }
57
Alex Loikoe36e8bb2018-02-16 11:54:07 +010058 private:
59 T* const* audio_samples_;
60 size_t num_channels_;
61 size_t channel_size_;
62};
63
64#endif // MODULES_AUDIO_PROCESSING_INCLUDE_AUDIO_FRAME_VIEW_H_