LMMS
Loading...
Searching...
No Matches
MixHelpers.h
Go to the documentation of this file.
1/*
2 * MixHelpers.h - helper functions for mixing buffers
3 *
4 * Copyright (c) 2014 Tobias Doerffel <tobydox/at/users.sourceforge.net>
5 *
6 * This file is part of LMMS - https://lmms.io
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public
10 * License as published by the Free Software Foundation; either
11 * version 2 of the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public
19 * License along with this program (see COPYING); if not, write to the
20 * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
21 * Boston, MA 02110-1301 USA.
22 *
23 */
24
25#ifndef LMMS_MIX_HELPERS_H
26#define LMMS_MIX_HELPERS_H
27
28#include "AudioBufferView.h"
29
30namespace lmms
31{
32
33class ValueBuffer;
34class SampleFrame;
35
36namespace MixHelpers
37{
38
39bool isSilent(const SampleFrame* src, int frames);
40
41bool isSilent(std::span<const sample_t> buffer);
42
44void add( SampleFrame* dst, const SampleFrame* src, int frames );
45
47void add(PlanarBufferView<sample_t> dst, PlanarBufferView<const sample_t> src);
48
50void multiply(SampleFrame* dst, float coeff, int frames);
51
53void addMultiplied( SampleFrame* dst, const SampleFrame* src, float coeffSrc, int frames );
54
56void addSwappedMultiplied( SampleFrame* dst, const SampleFrame* src, float coeffSrc, int frames );
57
59void addMultipliedByBuffer( SampleFrame* dst, const SampleFrame* src, float coeffSrc, ValueBuffer * coeffSrcBuf, int frames );
60
62void addMultipliedByBuffers( SampleFrame* dst, const SampleFrame* src, ValueBuffer * coeffSrcBuf1, ValueBuffer * coeffSrcBuf2, int frames );
63
65void addMultipliedStereo( SampleFrame* dst, const SampleFrame* src, float coeffSrcLeft, float coeffSrcRight, int frames );
66
68void multiplyAndAddMultiplied( SampleFrame* dst, const SampleFrame* src, float coeffDst, float coeffSrc, int frames );
69
71void multiplyAndAddMultipliedJoined( SampleFrame* dst, const sample_t* srcLeft, const sample_t* srcRight, float coeffDst, float coeffSrc, int frames );
72
73} // namespace MixHelpers
74
75
76} // namespace lmms
77
78#endif // LMMS_MIX_HELPERS_H
Definition SampleFrame.h:41
Definition ValueBuffer.h:38
Definition MixHelpers.cpp:34
void multiplyAndAddMultipliedJoined(SampleFrame *dst, const sample_t *srcLeft, const sample_t *srcRight, float coeffDst, float coeffSrc, int frames)
Multiply dst by coeffDst and add samples from srcLeft/srcRight multiplied by coeffSrc.
Definition MixHelpers.cpp:224
void addMultiplied(SampleFrame *dst, const SampleFrame *src, float coeffSrc, int frames)
Add samples from src multiplied by coeffSrc to dst.
Definition MixHelpers.cpp:119
void addMultipliedByBuffers(SampleFrame *dst, const SampleFrame *src, ValueBuffer *coeffSrcBuf1, ValueBuffer *coeffSrcBuf2, int frames)
Add samples from src multiplied by coeffSrc and coeffSrcBuf to dst.
Definition MixHelpers.cpp:161
bool isSilent(const SampleFrame *src, int frames)
Definition MixHelpers.cpp:63
void addSwappedMultiplied(SampleFrame *dst, const SampleFrame *src, float coeffSrc, int frames)
Add samples from src multiplied by coeffSrc to dst, swap inputs.
Definition MixHelpers.cpp:146
void add(SampleFrame *dst, const SampleFrame *src, int frames)
Add samples from src to dst.
Definition MixHelpers.cpp:81
void multiplyAndAddMultiplied(SampleFrame *dst, const SampleFrame *src, float coeffDst, float coeffSrc, int frames)
Multiply dst by coeffDst and add samples from src multiplied by coeffSrc.
Definition MixHelpers.cpp:217
void addMultipliedByBuffer(SampleFrame *dst, const SampleFrame *src, float coeffSrc, ValueBuffer *coeffSrcBuf, int frames)
Add samples from src multiplied by coeffSrc and coeffSrcBuf to dst.
Definition MixHelpers.cpp:152
void addMultipliedStereo(SampleFrame *dst, const SampleFrame *src, float coeffSrcLeft, float coeffSrcRight, int frames)
Add samples from src multiplied by coeffSrcLeft/coeffSrcRight to dst.
Definition MixHelpers.cpp:189
void multiply(SampleFrame *dst, float coeff, int frames)
Multiply samples from dst by coeff.
Definition MixHelpers.cpp:138
Definition AudioAlsa.cpp:35
float sample_t
Definition LmmsTypes.h:39