aboutsummaryrefslogtreecommitdiffstats
path: root/alc/front_stablizer.h
blob: 0fedeb50eaaed4afd3e25963f3233a9b2611bf2c (plain)
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
#ifndef ALC_FRONT_STABLIZER_H
#define ALC_FRONT_STABLIZER_H

#include <array>
#include <memory>

#include "almalloc.h"
#include "core/bufferline.h"
#include "core/filters/splitter.h"


struct FrontStablizer {
    static constexpr size_t DelayLength{256u};

    FrontStablizer(size_t numchans) : DelayBuf{numchans} { }

    alignas(16) std::array<float,BufferLineSize + DelayLength> Side{};
    alignas(16) std::array<float,BufferLineSize + DelayLength> MidDirect{};
    alignas(16) std::array<float,DelayLength> MidDelay{};

    alignas(16) std::array<float,BufferLineSize + DelayLength> TempBuf{};

    BandSplitter MidFilter;
    alignas(16) FloatBufferLine MidLF{};
    alignas(16) FloatBufferLine MidHF{};

    using DelayLine = std::array<float,DelayLength>;
    al::FlexArray<DelayLine,16> DelayBuf;

    static std::unique_ptr<FrontStablizer> Create(size_t numchans)
    { return std::unique_ptr<FrontStablizer>{new(FamCount(numchans)) FrontStablizer{numchans}}; }

    DEF_FAM_NEWDEL(FrontStablizer, DelayBuf)
};

#endif /* ALC_FRONT_STABLIZER_H */