
Security News
Attackers Are Hunting High-Impact Node.js Maintainers in a Coordinated Social Engineering Campaign
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.
pitchy is a simple pitch-detection library written entirely in JavaScript that aims to be fast and accurate enough to be used in real-time applications such as tuners. To do this, it uses the McLeod Pitch Method, described in the paper A Smarter Way to Find Pitch by Philip McLeod and Geoff Wyvill.
A playground page is available to allow experimentation with the library and how different configurations may impact the quality of the results.
Note for v4 users: as of v4, Pitchy is distributed as a pure ES module. There are several implications of this for using various build and test tools: a Gist by sindresorhus gives a more detailed overview (including suggestions for various tools) than what can be covered in this README. The short version is that you may want to consider migrating your own project to ES modules. If all else fails, you can continue to use v3, as v4 contains no functional changes.
You can install pitchy using NPM (or similar tools such as Yarn):
npm install pitchy
You can also use a CDN, such as esm.sh, directly from a browser or Deno:
import { PitchDetector } from "https://esm.sh/pitchy@4";
Note that this package is
ESM-only,
meaning it can't be used with require. However, it can still be used from
CommonJS code, albeit only in async contexts, using dynamic import:
const { PitchDetector } = await import("pitchy");
The main functionality of this module is exposed by the PitchDetector class.
Instances of PitchDetector are generally created using one of the three static
helper methods corresponding to the desired output buffer type:
PitchDetector.forFloat32Array(inputLength)PitchDetector.forFloat64Array(inputLength)PitchDetector.forNumberArray(inputLength)Once a PitchDetector instance is created, the findPitch(input, sampleRate)
method can be used to find the pitch of the time-domain data in input,
returning an array consisting of the detected pitch (in Hz) and a "clarity"
measure from 0 to 1 that indicates how "clear" the pitch is (low values indicate
noise rather than a true pitch).
For efficiency reasons, the input to the findPitch method must always have the
length indicated by the inputLength that was passed when constructing the
PitchDetector.
An Autocorrelator class with a similar interface to PitchDetector is exposed
for those who want to use the autocorrelation function for other things.
A simple usage example is available on GitHub Pages.
This is free software, distributed under the MIT license.
FAQs
A simple pitch detection library.
The npm package pitchy receives a total of 6,254 weekly downloads. As such, pitchy popularity was classified as popular.
We found that pitchy demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.

Security News
Axios compromise traced to social engineering, showing how attacks on maintainers can bypass controls and expose the broader software supply chain.

Security News
Node.js has paused its bug bounty program after funding ended, removing payouts for vulnerability reports but keeping its security process unchanged.