Welcome to mirror list, hosted at ThFree Co, Russian Federation.

dither.h « apps « zita-resampler « src « dll - github.com/mpc-hc/sanear.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 1221ac2b17c5093678edc159c47059868fbe1e0f (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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// ----------------------------------------------------------------------------
//
//  Copyright (C) 2006-2011 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 3 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, see <http://www.gnu.org/licenses/>.
//
// ----------------------------------------------------------------------------


#ifndef __DITHER_H
#define __DITHER_H


#include <stdint.h>


class Dither
{
public:

    Dither (void);
    void reset (void);
    void proc_rectangular (const float *srce, int16_t *dest, int step, int nsam);
    void proc_triangular  (const float *srce, int16_t *dest, int step, int nsam);
    void proc_lipschitz   (const float *srce, int16_t *dest, int step, int nsam); 

private:

    enum { SIZE = 64 };

    float genrand (void)
    {
        _ran *= 1103515245;
        _ran += 12345;
	return _ran / _div;
    }

    float    _err [SIZE + 4];
    int      _ind;
    uint32_t _ran;

    static float _div;
};


#endif