<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title>Test DynamicsCompressor with Gain</title> <script src="/tests/SimpleTest/SimpleTest.js"></script> <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" /> </head> <body> <script class="testbody" type="text/javascript"> SimpleTest.waitForExplicitFinish(); addLoadEvent(function() { var samplerate = 44100; var context = new OfflineAudioContext(1, samplerate/100, samplerate); var osc = context.createOscillator(); osc.frequency.value = 2400; var gain = context.createGain(); gain.gain.value = 1.5; // These numbers are borrowed from the example code on MDN // https://developer.mozilla.org/en-US/docs/Web/API/DynamicsCompressorNode var compressor = context.createDynamicsCompressor(); compressor.threshold.value = -50; compressor.knee.value = 40; compressor.ratio.value = 12; compressor.reduction.value = -20; compressor.attack.value = 0; compressor.release.value = 0.25; osc.connect(gain); gain.connect(compressor); compressor.connect(context.destination); osc.start(); context.startRendering().then(buffer => { var peak = Math.max(...buffer.getChannelData(0)); console.log(peak); // These values are experimentally determined. Without dynamics compression // the peak should be just under 1.5. We also check for a minimum value // to make sure we are not getting all zeros. ok(peak >= 0.2 && peak < 1.0, "Peak value should be greater than 0.25 and less than 1.0"); SimpleTest.finish(); }); }); </script> <pre> </pre> </body>