File: virtmic.h

package info (click to toggle)
amb-plugins 0.8.1-8
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 352 kB
  • sloc: cpp: 5,065; makefile: 85
file content (91 lines) | stat: -rw-r--r-- 2,430 bytes parent folder | download | duplicates (5)
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
/*
    Copyright (C) 2004-2009 Fons Adriaensen <fons@kokkinizita.net>
    
    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 __VIRTMIC_H
#define __VIRTMIC_H


#include <math.h>


class Virtmic 
{
public:

    Virtmic (void);
    ~Virtmic (void);

    void process (int n, float *W, float *X, float *Y, float *Z, float *L, float *R);
    void set_azim  (float v) { _azim1  = -v / 360.0f; }
    void set_elev  (float v) { _elev1  =  v / 360.0f; }
    void set_angle (float v) { _angle1 =  v / 720.0f; }
    void set_direc (float v) { _direc1 =  v; }

private:
 
    int lincheck (float& v, float& v1)
    {
	float d;
        d = v1 - v;
        if (fabsf (d) < 1e-3f) return 0;
        else if (d >  0.05f) v += 0.05f;
        else if (d < -0.05f) v -= 0.05f;
        else v = v1;
	return 1;
    }

    int circheck (float& v, float& v1)
    {
	float d;
        d = v1 - v;
        d -= floorf (d + 0.5f);
        if (fabsf (d) < 1e-3f) return 0;
        else if (d >  0.02f) v += 0.02f;
        else if (d < -0.02f) v -= 0.02f;
        else v = v1;
        v -= floorf (v);
	return 1;
    }

    float diff (int n, float v, float v1)
    {
	float d;
        d = (v1 - v) / n;
	return (fabsf (d) < 1e-9f) ? 0 : d;
    }


    float      _azim;     // current azimuth
    float      _azim1;    // target azimuth  
    float      _elev;     // current elevation
    float      _elev1;    // target elevation 
    float      _angle;    // current mic angle
    float      _angle1;   // target mic angle
    float      _direc;    // current mic pattern
    float      _direc1;   // target mic pattern
    float      _csw;      // matrix elements
    float      _csx;      
    float      _csy;
    float      _csz;
    float      _cdx;
    float      _cdy;
};


#endif