File: decoder.h

package info (click to toggle)
ambdec 0.7.1-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, buster, forky, sid, trixie
  • size: 704 kB
  • sloc: cpp: 3,888; makefile: 45
file content (124 lines) | stat: -rw-r--r-- 4,289 bytes parent folder | download
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// ----------------------------------------------------------------------------
//
//  Copyright (C) 2006-2017 Fons Adriaensen <fons@linuxaudio.org>
//    
//  This program is free software; you can redistribute it and/or modify
//  it under the terms of the GNU General Public License as published by
//  the Free Software Foundation; either version 2 of the License, or
//  (at your option) any later version.
//
//  This program is distributed in the hope that it will be useful,
//  but WITHOUT ANY WARRANTY; without even the implied warranty of
//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
//  GNU General Public License for more details.
//
//  You should have received a copy of the GNU General Public License
//  along with this program; if not, write to the Free Software
//  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
//
// ----------------------------------------------------------------------------


#ifndef __DECODER_H
#define __DECODER_H


#include <inttypes.h>
#include "global.h"
#include "xover2.h"
#include "nffilt.h"
#include "adconf.h"


class Output
{
public:

    Output (void) : _dline (0) {}
    ~Output (void) { delete[] _dline; }

    float        _matlf [MAXIP]; // matrix row
    float        _mathf [MAXIP]; // matrix row
    NF_filt1     _nffilt1;       // near field filters
    NF_filt2     _nffilt2;
    NF_filt3     _nffilt3;
    NF_filt4     _nffilt4;
    int          _delay;         // delay in samples  
    float       *_dline;         // delay buffer
    float        _gcorr;
    float        _gain0;
};
    

class Decoder
{
public:

    Decoder (void);
    ~Decoder (void);

    enum { FRAG_SIZE = 256 };
    enum { COMP_NFE_IP = 1, COMP_NFE_OP = 2, COMP_LEVEL = 4, COMP_DELAY = 8 };
    enum { TEST_OFF, TEST_INT, TEST_EXT };

    void init (int frate);
    void reset (void);
    void set_config (AD_conf *C);
    void set_matrix (AD_conf *C);

    void set_gain (float gain) { _gain = gain; }
    void set_solo (uint64_t solo) { _solo = solo; }
    void set_mute (uint64_t mute) { _mute = mute; }
    void set_test (int test) { _inp1 = test; }

    void process (int n, float *ip[], float *op[], float *ts, float *lm);

private:

    void matr1band (int nf, int ind0, int ind1, float *out, Output *Z);
    void matr2band (int nf, int ind0, int ind1, float *out, Output *Z);
    void make_test (void);

    float       _frate;
    int         _nsig0;                      // number of inputs of degree 0
    int         _nsig1;                      // number of inputs of degree 1
    int         _nsig2;                      // number of inputs of degree 2
    int         _nsig3;                      // number of inputs of degree 3
    int         _nsig4;                      // number of inputs of degree 4
    int         _noutp;                      // number of outputs
    int         _nband;                      // number of frequency bands, 1 or 2
    int         _dsize;                      // size of delay lines in samples
    int         _tsize;                      // size of test signal in samples
    int         _comp;                       // compensation options
    int         _inp0;                       // current input
    int         _inp1;                       // next input
    uint64_t    _solo;                       // solo mask
    uint64_t    _mute;                       // mute mask
    float       _gain;                       // volume
    int         _idel;                       // delay write index 
    int         _itst;                       // test read index
    NF_filt1    _nffilt1 [3];                // near_field filters
    NF_filt2    _nffilt2 [5];
    NF_filt3    _nffilt3 [7];
    NF_filt4    _nffilt4 [9];
    LR2conf     _lr2conf;
    LR2filt     _lr2filt [MAXIP];
    float       _scale [MAXIP]; 
    float       _ip_lf [MAXIP][FRAG_SIZE];
    float       _ip_hf [MAXIP][FRAG_SIZE];
    Output      _output [MAXOP];
    float       _sig0 [FRAG_SIZE];
    float       _sig1 [FRAG_SIZE];
    float       _sig2 [FRAG_SIZE];
    float       _sig3 [FRAG_SIZE];
    float       _sig4 [FRAG_SIZE];
    float      *_test;

    static const float _g_norm [MAXIP];
    static const float _g_sn3d [MAXIP];
    static const float _g_fuma [16];
};


#endif