98 void process (
const ProcessContext& context)
noexcept
100 auto&& inBlock = context.getInputBlock();
101 auto&& outBlock = context.getOutputBlock();
103 jassert (inBlock.getNumChannels() == outBlock.getNumChannels());
104 jassert (inBlock.getNumSamples() == outBlock.getNumSamples());
106 auto len = inBlock.getNumSamples();
107 auto numChannels = inBlock.getNumChannels();
109 if (context.isBypassed)
111 bias.skip (
static_cast<int> (len));
113 if (context.usesSeparateInputAndOutputBlocks())
114 outBlock.copyFrom (inBlock);
119 if (numChannels == 1)
121 auto* src = inBlock.getChannelPointer (0);
122 auto* dst = outBlock.getChannelPointer (0);
124 for (
size_t i = 0; i < len; ++i)
125 dst[i] = src[i] + bias.getNextValue();
129 JUCE_BEGIN_IGNORE_WARNINGS_MSVC (6255 6386)
130 auto* biases =
static_cast<FloatType*
> (alloca (
sizeof (FloatType) * len));
132 for (
size_t i = 0; i < len; ++i)
133 biases[i] = bias.getNextValue();
135 for (
size_t chan = 0; chan < numChannels; ++chan)
136 FloatVectorOperations::add (outBlock.getChannelPointer (chan),
137 inBlock.getChannelPointer (chan),
138 biases,
static_cast<int> (len));
139 JUCE_END_IGNORE_WARNINGS_MSVC