JUCE-7.0.12-0-g4f43011b96 JUCE-7.0.12-0-g4f43011b96
JUCE — C++ application framework with suport for VST, VST3, LV2 audio plug-ins

« « « Anklang Documentation
Loading...
Searching...
No Matches
juce_FirstOrderTPTFilter.h
Go to the documentation of this file.
1 /*
2 ==============================================================================
3
4 This file is part of the JUCE library.
5 Copyright (c) 2022 - Raw Material Software Limited
6
7 JUCE is an open source library subject to commercial or open-source
8 licensing.
9
10 By using JUCE, you agree to the terms of both the JUCE 7 End-User License
11 Agreement and JUCE Privacy Policy.
12
13 End User License Agreement: www.juce.com/juce-7-licence
14 Privacy Policy: www.juce.com/juce-privacy-policy
15
16 Or: You may also use this code under the terms of the GPL v3 (see
17 www.gnu.org/licenses).
18
19 JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
20 EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
21 DISCLAIMED.
22
23 ==============================================================================
24*/
25
26namespace juce::dsp
27{
28
29enum class FirstOrderTPTFilterType
30{
31 lowpass,
32 highpass,
33 allpass
34};
35
36//==============================================================================
52template <typename SampleType>
54{
55public:
56 //==============================================================================
57 using Type = FirstOrderTPTFilterType;
58
59 //==============================================================================
62
63 //==============================================================================
65 void setType (Type newType);
66
71 void setCutoffFrequency (SampleType newFrequencyHz);
72
73 //==============================================================================
75 Type getType() const noexcept { return filterType; }
76
78 SampleType getCutoffFrequency() const noexcept { return cutoffFrequency; }
79
80 //==============================================================================
82 void prepare (const ProcessSpec& spec);
83
85 void reset();
86
88 void reset (SampleType newValue);
89
90 //==============================================================================
92 template <typename ProcessContext>
93 void process (const ProcessContext& context) noexcept
94 {
95 const auto& inputBlock = context.getInputBlock();
96 auto& outputBlock = context.getOutputBlock();
97 const auto numChannels = outputBlock.getNumChannels();
98 const auto numSamples = outputBlock.getNumSamples();
99
100 jassert (inputBlock.getNumChannels() <= s1.size());
101 jassert (inputBlock.getNumChannels() == numChannels);
102 jassert (inputBlock.getNumSamples() == numSamples);
103
104 if (context.isBypassed)
105 {
106 outputBlock.copyFrom (inputBlock);
107 return;
108 }
109
110 for (size_t channel = 0; channel < numChannels; ++channel)
111 {
112 auto* inputSamples = inputBlock .getChannelPointer (channel);
113 auto* outputSamples = outputBlock.getChannelPointer (channel);
114
115 for (size_t i = 0; i < numSamples; ++i)
116 outputSamples[i] = processSample ((int) channel, inputSamples[i]);
117 }
118
119 #if JUCE_DSP_ENABLE_SNAP_TO_ZERO
120 snapToZero();
121 #endif
122 }
123
124 //==============================================================================
126 SampleType processSample (int channel, SampleType inputValue);
127
132 void snapToZero() noexcept;
133
134private:
135 //==============================================================================
136 void update();
137
138 //==============================================================================
139 SampleType G = 0;
140 std::vector<SampleType> s1 { 2 };
141 double sampleRate = 44100.0;
142
143 //==============================================================================
144 Type filterType = Type::lowpass;
145 SampleType cutoffFrequency = 1000.0;
146};
147
148} // namespace juce::dsp
A first order filter class using the TPT (Topology-Preserving Transform) structure.
Type getType() const noexcept
Returns the type of the filter.
SampleType getCutoffFrequency() const noexcept
Returns the cutoff frequency of the filter.
void prepare(const ProcessSpec &spec)
Initialises the filter.
void snapToZero() noexcept
Ensure that the state variables are rounded to zero if the state variables are denormals.
SampleType processSample(int channel, SampleType inputValue)
Processes one sample at a time on a given channel.
void process(const ProcessContext &context) noexcept
Processes the input and output samples supplied in the processing context.
void setType(Type newType)
Sets the filter type.
void setCutoffFrequency(SampleType newFrequencyHz)
Sets the cutoff frequency of the filter.
void reset()
Resets the internal state variables of the filter.
#define jassert(expression)
Platform-independent assertion macro.
Type unalignedPointerCast(void *ptr) noexcept
Casts a pointer to another type via void*, which suppresses the cast-align warning which sometimes ar...
Definition juce_Memory.h:88
T size(T... args)
This structure is passed into a DSP algorithm's prepare() method, and contains information about vari...