npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

lowpass

v1.5.2

Published

Node.js Lowpass music filter

Downloads

18

Readme

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