-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmeterprocessor.cpp
More file actions
67 lines (66 loc) · 1.76 KB
/
meterprocessor.cpp
File metadata and controls
67 lines (66 loc) · 1.76 KB
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
#include "meterprocessor.h"
#include <cmath>
#include <cstring>
#include <iostream>
MeterProcessor::MeterProcessor(uint8_t channels, uint32_t samplerate)
: Processor(channels, samplerate)
{
_v.resize(_numChannels);
_z1.resize(_numChannels);
_z2.resize(_numChannels);
_reset.resize(_numChannels);
setType(Processor::METER);
_w = 11.1f / 44100;
_g = 1.5f * 1.571f;
}
MeterProcessor::~MeterProcessor()
{
}
void MeterProcessor::process(sample_t* in, sample_t* out, uint32_t samples)
{
// initPeaks();
for (uint8_t c = 0; c < _numChannels; ++c) {
float z1, z2, m, t1, t2;
z1 = _z1[c];
z2 = _z2[c];
m = _reset[c] ? 0 : _v[c];
_reset[c] = false;
//n /= 4;
for (uint32_t s = c; s < samples - (_numChannels * 3); s += _numChannels) {
sample_t* p = in + s;
t2 = z2 / 2;
t1 = fabsf(*( p )-t2);
z1 += _w * (t1 - z1);
t1 = fabsf(*(p + _numChannels) - t2);
z1 += _w * (t1 - z1);
t1 = fabsf(*(p + _numChannels * 2) - t2);
z1 += _w * (t1 - z1);
t1 = fabsf(*(p + _numChannels * 3) - t2);
z1 += _w * (t1 - z1);
z2 += 4 * _w * (z1 - z2);
if (z2 > m)
m = z2;
//out[s + c] = in[s + c];
}
_z1[c] = z1;
_z2[c] = z2 + 1e-10f;
_v[c] = m;
}
}
void MeterProcessor::initPeaks()
{
for (uint8_t i = 0; i < _numChannels; ++i) {
_v[i] = 0.0f;
_z1[i] = 0.0f;
_z2[i] = 0.0f;
_reset[i] = false;
}
}
MeterValues MeterProcessor::getValues()
{
for (uint8_t i = 0; i < _numChannels; ++i) {
_reset[i] = true;
_v[i] = clamp(fabs((_g * _v[i])), 0.0f, 1.0f);
}
return _v;
}