1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
/* SPDX-License-Identifier: BSD-3-Clause */
/* SPDX-FileCopyrightText: OpenMPT Project Developers and Contributors */
#pragma once
#include "openmpt/all/BuildSettings.hpp"
#include "mpt/audio/span.hpp"
#include "mpt/base/macros.hpp"
#include "openmpt/soundbase/SampleConvert.hpp"
#include <algorithm>
#include <cassert>
#include <cstddef>
OPENMPT_NAMESPACE_BEGIN
template <typename TBufOut, typename TBufIn>
void CopyAudio(TBufOut buf_out, TBufIn buf_in)
{
assert(buf_in.size_frames() == buf_out.size_frames());
assert(buf_in.size_channels() == buf_out.size_channels());
std::size_t countFrames = std::min(buf_in.size_frames(), buf_out.size_frames());
std::size_t channels = std::min(buf_in.size_channels(), buf_out.size_channels());
for(std::size_t frame = 0; frame < countFrames; ++frame)
{
for(std::size_t channel = 0; channel < channels; ++channel)
{
buf_out(channel, frame) = SC::sample_cast<typename TBufOut::sample_type>(buf_in(channel, frame));
}
}
}
template <typename TBufOut, typename TBufIn>
void CopyAudio(TBufOut buf_out, TBufIn buf_in, std::size_t countFrames)
{
assert(countFrames <= buf_in.size_frames());
assert(countFrames <= buf_out.size_frames());
assert(buf_in.size_channels() == buf_out.size_channels());
std::size_t channels = std::min(buf_in.size_channels(), buf_out.size_channels());
for(std::size_t frame = 0; frame < countFrames; ++frame)
{
for(std::size_t channel = 0; channel < channels; ++channel)
{
buf_out(channel, frame) = SC::sample_cast<typename TBufOut::sample_type>(buf_in(channel, frame));
}
}
}
template <typename TBufOut, typename TBufIn>
void CopyAudioChannels(TBufOut buf_out, TBufIn buf_in, std::size_t channels, std::size_t countFrames)
{
assert(countFrames <= buf_in.size_frames());
assert(countFrames <= buf_out.size_frames());
assert(channels <= buf_in.size_channels());
assert(channels <= buf_out.size_channels());
for(std::size_t frame = 0; frame < countFrames; ++frame)
{
for(std::size_t channel = 0; channel < channels; ++channel)
{
buf_out(channel, frame) = SC::sample_cast<typename TBufOut::sample_type>(buf_in(channel, frame));
}
}
}
// Copy numChannels interleaved sample streams.
template <typename Tin, typename Tout>
void CopyAudioChannelsInterleaved(Tout *MPT_RESTRICT outBuf, const Tin *MPT_RESTRICT inBuf, std::size_t numChannels, std::size_t countFrames)
{
CopyAudio(mpt::audio_span_interleaved<Tout>(outBuf, numChannels, countFrames), mpt::audio_span_interleaved<const Tin>(inBuf, numChannels, countFrames));
}
OPENMPT_NAMESPACE_END
|