comparison data/model/WaveformOversampler.cpp @ 1766:85b9b466a59f

Merge from branch by-id
author Chris Cannam
date Wed, 17 Jul 2019 14:24:51 +0100
parents 074b860a7828
children
comparison
equal deleted inserted replaced
1730:649ac57c5a2d 1766:85b9b466a59f
17 #include "base/Profiler.h" 17 #include "base/Profiler.h"
18 18
19 #include "data/model/DenseTimeValueModel.h" 19 #include "data/model/DenseTimeValueModel.h"
20 20
21 floatvec_t 21 floatvec_t
22 WaveformOversampler::getOversampledData(const DenseTimeValueModel *source, 22 WaveformOversampler::getOversampledData(const DenseTimeValueModel &source,
23 int channel, 23 int channel,
24 sv_frame_t sourceStartFrame, 24 sv_frame_t sourceStartFrame,
25 sv_frame_t sourceFrameCount, 25 sv_frame_t sourceFrameCount,
26 int oversampleBy) 26 int oversampleBy)
27 { 27 {
51 51
52 return result; 52 return result;
53 } 53 }
54 54
55 floatvec_t 55 floatvec_t
56 WaveformOversampler::getFixedRatioData(const DenseTimeValueModel *source, 56 WaveformOversampler::getFixedRatioData(const DenseTimeValueModel &source,
57 int channel, 57 int channel,
58 sv_frame_t sourceStartFrame, 58 sv_frame_t sourceStartFrame,
59 sv_frame_t sourceFrameCount) 59 sv_frame_t sourceFrameCount)
60 { 60 {
61 Profiler profiler("WaveformOversampler::getFixedRatioData"); 61 Profiler profiler("WaveformOversampler::getFixedRatioData");
62 62
63 sv_frame_t sourceLength = source->getEndFrame(); 63 sv_frame_t sourceLength = source.getEndFrame();
64 64
65 if (sourceStartFrame + sourceFrameCount > sourceLength) { 65 if (sourceStartFrame + sourceFrameCount > sourceLength) {
66 sourceFrameCount = sourceLength - sourceStartFrame; 66 sourceFrameCount = sourceLength - sourceStartFrame;
67 if (sourceFrameCount <= 0) return {}; 67 if (sourceFrameCount <= 0) return {};
68 } 68 }
82 sv_frame_t i1 = sourceStartFrame + sourceFrameCount + filterTailIn; 82 sv_frame_t i1 = sourceStartFrame + sourceFrameCount + filterTailIn;
83 if (i1 > sourceLength) { 83 if (i1 > sourceLength) {
84 i1 = sourceLength; 84 i1 = sourceLength;
85 } 85 }
86 86
87 floatvec_t sourceData = source->getData(channel, i0, i1 - i0); 87 floatvec_t sourceData = source.getData(channel, i0, i1 - i0);
88 88
89 for (sv_frame_t i = i0; i < i1; ++i) { 89 for (sv_frame_t i = i0; i < i1; ++i) {
90 float v = sourceData[i - i0]; 90 float v = sourceData[i - i0];
91 sv_frame_t outOffset = 91 sv_frame_t outOffset =
92 (i - sourceStartFrame) * m_filterRatio - filterTailOut; 92 (i - sourceStartFrame) * m_filterRatio - filterTailOut;