summaryrefslogtreecommitdiffstats
path: root/dom/media/webaudio/test/test_periodicWaveDisableNormalization.html
blob: 229d48282ebf7f13509572707dd607aa394527e9 (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
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
<!DOCTYPE HTML>
<html>
<head>
  <title>Test PeriodicWave disableNormalization Parameter</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <script type="text/javascript" src="webaudio.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
</head>
<body>
<pre id="test">
<script class="testbody" type="text/javascript">

SimpleTest.waitForExplicitFinish();

// We create PerodicWave instances containing two tones and compare it to
// buffers created directly in JavaScript by adding the two waves together.
// Two of the PeriodicWaves are normalized, the other is not. This test is
// a modification of test_periodicWave.html.
//
// These constants are borrowed from test_periodicWave.html and modified
// so that the realPeak (which is the normalization factor) will be small
// enough that the errors are within the bounds for the test.
const realMax = 99;
var real = new Float32Array(realMax + 1);
real[1] = 2.0; // fundamental
real[realMax] = 0.25;

const realPeak = real[1] + real[realMax];
const realFundamental = 19.0;

const testLength = 4096;

addLoadEvent(function() {
  runTest();
});

var gTest = {
  createGraph(context) {
    var merger = context.createChannelMerger();

    var osc0 = context.createOscillator();
    var osc1 = context.createOscillator();
    var osc2 = context.createOscillator();

    osc0.setPeriodicWave(context.
                         createPeriodicWave(real,
                                            new Float32Array(real.length),
                                            {disableNormalization: false}));
    osc1.setPeriodicWave(context.
                         createPeriodicWave(real,
                                            new Float32Array(real.length)));
    osc2.setPeriodicWave(context.
                         createPeriodicWave(real,
                                            new Float32Array(real.length),
                                            {disableNormalization: true}));

    osc0.frequency.value = realFundamental;
    osc1.frequency.value = realFundamental;
    osc2.frequency.value = realFundamental;

    osc0.start();
    osc1.start();
    osc2.start();

    osc0.connect(merger, 0, 0);
    osc1.connect(merger, 0, 1);
    osc2.connect(merger, 0, 2);

    return merger;
  },
  createExpectedBuffers(context) {
    var buffer = context.createBuffer(3, testLength, context.sampleRate);

    for (var i = 0; i < buffer.length; ++i) {

      buffer.getChannelData(0)[i] = 1.0 / realPeak *
        (real[1] * Math.cos(2 * Math.PI * realFundamental * i /
                            context.sampleRate) +
         real[realMax] * Math.cos(2 * Math.PI * realMax * realFundamental * i /
                            context.sampleRate));

      buffer.getChannelData(1)[i] = buffer.getChannelData(0)[i];

      buffer.getChannelData(2)[i] =
        (real[1] * Math.cos(2 * Math.PI * realFundamental * i /
                            context.sampleRate) +
         real[realMax] * Math.cos(2 * Math.PI * realMax * realFundamental * i /
                            context.sampleRate));
    }
    return buffer;
  },
  'numberOfChannels': 3,
};

</script>
</pre>
</body>
</html>