| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 43 Resample(nullptr, source_length, float_buffer_.get(), destination_frames_); | 43 Resample(nullptr, source_length, float_buffer_.get(), destination_frames_); |
| 44 FloatS16ToS16(float_buffer_.get(), destination_frames_, destination); | 44 FloatS16ToS16(float_buffer_.get(), destination_frames_, destination); |
| 45 source_ptr_int_ = nullptr; | 45 source_ptr_int_ = nullptr; |
| 46 return destination_frames_; | 46 return destination_frames_; |
| 47 } | 47 } |
| 48 | 48 |
| 49 size_t PushSincResampler::Resample(const float* source, | 49 size_t PushSincResampler::Resample(const float* source, |
| 50 size_t source_length, | 50 size_t source_length, |
| 51 float* destination, | 51 float* destination, |
| 52 size_t destination_capacity) { | 52 size_t destination_capacity) { |
| 53 CHECK_EQ(source_length, resampler_->request_frames()); | 53 RTC_CHECK_EQ(source_length, resampler_->request_frames()); |
| 54 CHECK_GE(destination_capacity, destination_frames_); | 54 RTC_CHECK_GE(destination_capacity, destination_frames_); |
| 55 // Cache the source pointer. Calling Resample() will immediately trigger | 55 // Cache the source pointer. Calling Resample() will immediately trigger |
| 56 // the Run() callback whereupon we provide the cached value. | 56 // the Run() callback whereupon we provide the cached value. |
| 57 source_ptr_ = source; | 57 source_ptr_ = source; |
| 58 source_available_ = source_length; | 58 source_available_ = source_length; |
| 59 | 59 |
| 60 // On the first pass, we call Resample() twice. During the first call, we | 60 // On the first pass, we call Resample() twice. During the first call, we |
| 61 // provide dummy input and discard the output. This is done to prime the | 61 // provide dummy input and discard the output. This is done to prime the |
| 62 // SincResampler buffer with the correct delay (half the kernel size), thereby | 62 // SincResampler buffer with the correct delay (half the kernel size), thereby |
| 63 // ensuring that all later Resample() calls will only result in one input | 63 // ensuring that all later Resample() calls will only result in one input |
| 64 // request through Run(). | 64 // request through Run(). |
| 65 // | 65 // |
| 66 // If this wasn't done, SincResampler would call Run() twice on the first | 66 // If this wasn't done, SincResampler would call Run() twice on the first |
| 67 // pass, and we'd have to introduce an entire |source_frames| of delay, rather | 67 // pass, and we'd have to introduce an entire |source_frames| of delay, rather |
| 68 // than the minimum half kernel. | 68 // than the minimum half kernel. |
| 69 // | 69 // |
| 70 // It works out that ChunkSize() is exactly the amount of output we need to | 70 // It works out that ChunkSize() is exactly the amount of output we need to |
| 71 // request in order to prime the buffer with a single Run() request for | 71 // request in order to prime the buffer with a single Run() request for |
| 72 // |source_frames|. | 72 // |source_frames|. |
| 73 if (first_pass_) | 73 if (first_pass_) |
| 74 resampler_->Resample(resampler_->ChunkSize(), destination); | 74 resampler_->Resample(resampler_->ChunkSize(), destination); |
| 75 | 75 |
| 76 resampler_->Resample(destination_frames_, destination); | 76 resampler_->Resample(destination_frames_, destination); |
| 77 source_ptr_ = nullptr; | 77 source_ptr_ = nullptr; |
| 78 return destination_frames_; | 78 return destination_frames_; |
| 79 } | 79 } |
| 80 | 80 |
| 81 void PushSincResampler::Run(size_t frames, float* destination) { | 81 void PushSincResampler::Run(size_t frames, float* destination) { |
| 82 // Ensure we are only asked for the available samples. This would fail if | 82 // Ensure we are only asked for the available samples. This would fail if |
| 83 // Run() was triggered more than once per Resample() call. | 83 // Run() was triggered more than once per Resample() call. |
| 84 CHECK_EQ(source_available_, frames); | 84 RTC_CHECK_EQ(source_available_, frames); |
| 85 | 85 |
| 86 if (first_pass_) { | 86 if (first_pass_) { |
| 87 // Provide dummy input on the first pass, the output of which will be | 87 // Provide dummy input on the first pass, the output of which will be |
| 88 // discarded, as described in Resample(). | 88 // discarded, as described in Resample(). |
| 89 std::memset(destination, 0, frames * sizeof(*destination)); | 89 std::memset(destination, 0, frames * sizeof(*destination)); |
| 90 first_pass_ = false; | 90 first_pass_ = false; |
| 91 return; | 91 return; |
| 92 } | 92 } |
| 93 | 93 |
| 94 if (source_ptr_) { | 94 if (source_ptr_) { |
| 95 std::memcpy(destination, source_ptr_, frames * sizeof(*destination)); | 95 std::memcpy(destination, source_ptr_, frames * sizeof(*destination)); |
| 96 } else { | 96 } else { |
| 97 for (size_t i = 0; i < frames; ++i) | 97 for (size_t i = 0; i < frames; ++i) |
| 98 destination[i] = static_cast<float>(source_ptr_int_[i]); | 98 destination[i] = static_cast<float>(source_ptr_int_[i]); |
| 99 } | 99 } |
| 100 source_available_ -= frames; | 100 source_available_ -= frames; |
| 101 } | 101 } |
| 102 | 102 |
| 103 } // namespace webrtc | 103 } // namespace webrtc |
| OLD | NEW |