Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

babycat

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

babycat

An audio decoding and manipulation library, with bindings for C, Python, and WebAssembly.

  • 0.0.15
  • PyPI
  • Socket score

Maintainers
1

Babycat Logo

Babycat is an audio decoding and manipulation library

Rustdoc status crates.io status Rust dependency status

Features

Decoding, resampling, and encoding

Babycat's core feature set includes:

  • decoding MP3, FLAC, and WAV.
  • resampling audio to different frame rates.
  • encoding waveforms to WAV.

Bindings for Rust, Python, WebAssembly, and C

Babycat can be used from the following target languages:

  • Rust. The majority of Babycat is written in Rust, with the exception of a few C dependencies like libsamplerate.
  • Python. Babycat's Python bindings allow you to decode, resample, and encode audio without being slowed down by Python's Global Interpreter Lock (GIL). Babycat also integrates with Jupyter, allowing you to play and listen to audio streams decoded by Babycat inside of a Jupyter notebook.
  • WebAssembly. Babycat generates JavaScript/WebAssembly bindings that can run either in a web browser or in Node.js.
  • C. Babycat exposes a C API, which is useful for both creating audio analysis projects in C or creating Babycat bindings for languages not mentioned above.

Effective multithreading and parallelism

Babycat is designed to parallelize the decoding of many audio files across multiple CPU cores. Babycat's Python bindings allow for parallel audio decoding without being slowed down by Python's Global Interpreter Lock.

Open source under the MIT license

The audio ecosystem is full of expensive proprietary software packages, or (L)GPL-licensed code that restricts how you can use it. In contrast, Babycat is licensed under the MIT license, allowing you to use Babycat any way you want for free.

Babycat is battle-tested in industry

Babycat was built at and is actively maintained by Neocrym, a record label that uses artificial intelligence to find and promote the world's greatest musicians. Neocrym uses Babycat to decode millions of songs as part of audio feature engineering pipelines for machine learning models.

Learn more

Source code and issues

You can find Babycat's source code at github.com/babycat-io/babycat.

API documentation and releases

babycat.io is our main documentation website. You can find documentation and releases for each binding at:

BindingDocumentationReleases
Rustdocs.rs/babycatcrates.io/crates/babycat
Pythonbabycat.io/api/pythonpypi.org/project/babycat
WebAssemblybabycat.io/api/wasmnpmjs.com/package/babycat
Cbabycat.io/api/cNo releases yet. You can compile from source.

Tutorials

You can learn more about how to use Babycat from our long-form tutorials:

Acknowledgements

The first version of Babycat was an internal project at Neocrym written by Ritik Mishra Since then, the code has been extended and open-sourced by James Mishra.

Babycat is built on top of many high-quality open source packages, including:

Babycat's goal is to provide a simple and consistent API on top of the existing audio ecosystem, without sacrificing performance, portability, or permissive licensing.

FAQs


Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc