1.5.2 • Published 10 years ago

lowpass v1.5.2

Weekly downloads
14
License
MIT
Repository
github
Last release
10 years ago

lowpass

Simple nodejs Audio manipulation library, based on node-wav

This module offers basics nodejs manipuji

  • LowPass : fast and basic (moving average-based) low pass filter
  • Cutter : Basic Stream to handle mp3 streams
  • Wav2energy : Transform
  • getBPM : soundstretch wrapper for nodejs
  • getBuildUp : Build-up detection (when music energy is more than a defined threshold)

Combined with node-lame it can also manage mp3 files.

Installation

Install through npm:

$ npm install lowpass

Example

Here's how you would use the lowpass filter on a standard PCM WAVE file out of the speakers using node-wav and node-speaker :

var fs = require('fs');
var wav = require('wav');
var Speaker = require('speaker');
var LowPass = require('lowpass').LowPass;

var file = fs.createReadStream('input1.wav');
var reader = new wav.Reader();

var speaker, lowpass;

// the "format" event gets emitted at the end of the WAVE header
reader.on('format', function (format) {
  speaker = new Speaker(format);
  lowPass = new LowPass({format : format});

  // the lowpass is piped between file reader and speaker
  reader.pipe(lowPass);
  lowPass.pipe(speaker);
});

// pipe the WAVE file to the Reader instance
file.pipe(reader);

Same example with mp3 file and the node-lame package

var fs = require('fs');
var wav = require('wav');
var Speaker = require('speaker');
var LowPass = require('lowpass').LowPass;

var file = fs.createReadStream('input.mp3');
var lame = require('lame');

var speaker, lowpass;

// start reading the MP3 file from the input
var decoder = new lame.Decoder();

// we have to wait for the "format" event before we can start encoding
decoder.on('format', onFormat);

// and start transferring the data
file.pipe(decoder);

function onFormat (format) {
  speaker = new Speaker(format);

  lowPass = new LowPass({
  	format : format
  });

  // write the decoded MP3 into the lowpass filter then the speaker
  decoder.pipe(lowPass).pipe(speaker);
};

LowPass()

The LowPass class accepts the data from node-wav outputs the raw audio data transformed by the low pass.

it has the following options :

var LowPass = require('lowpass').LowPass;

//First form
new LowPass({
	format : format, //format from node-wav, mandatory option
	movAvLength : 128 // moving average window
});

//Second Form
new LowPass({
	format : format, //format from node-wav, mandatory option
	movAvLength : 152 // Hz
});

By default the cut-off correspond to a 128 length moving average window. For a 44100 sampleRate, it is equivalent to 152Hz low pass filter.

getBPM()

The getBPM function call soundstretch utility to get the BPM of a song.

var getBPM = require('lowpass').getBPM;

getBPM("input.wav", function(err, bpm){
	console.log("BPM is ", bpm);
});

Be carefull, soundstretch must be installed in your system.

Other tools

See examples

Thanks

Thanks to TooTallNate for the published libraries

1.5.2

10 years ago

1.5.1

10 years ago

1.5.0

10 years ago

1.4.0

10 years ago

1.3.0

10 years ago

1.2.0

10 years ago

1.1.0

10 years ago

1.0.0

10 years ago