Skip to main content

Stemgen is a Stem file generator. Convert any track into a stem and have fun with Traktor.

Project description

🎛 Stemgen

Stemgen is a Stem file generator. Convert any track into a Stem and have fun with Traktor.

A Stem file is an open, multi-channel audio file that contains a track split into four musical elements – bass, drums, vocals, and melody, for example. With each element available independently, you have more control over the music you play.

Stemgen uses bs_roformer or demucs to separate the 4 stems and ni-stem to create the Stem file.

Screenshot Before Screenshot After

Our new file contains four stems: drums, bass, other (melody) and vocals.

[!NOTE] Traktor Pro 4 includes stem separation! Fortunately, it is backward-compatible and you can upgrade without any issue. But unfortunately, Stemgen still makes sense because:

  • Stemgen is the only way to create lossless ALAC stem files... for now! Please make yourself heard on the forum if you think lossless stems matters
  • Stemgen is the only way to create your own stem files from Ableton Live and from a CLI
  • Stemgen writes the metadata of the original files to the stem files, so you can easily sync them between computers

Why?

"It's no secret that I'm fully behind the approach to encourage individuality in creativity and for artists to play differently. Stems is a new format that mirrors my constant quest for spontaneity to drive the art of performance forwards. I hope that releasing my album From My Mind To Yours in this format, mastered by LANDR, inspires others to support the approach and bring even more flexibility to the art of DJing amongst its most progressive supporters." – Richie Hawtin

Stems are fun but nobody's releasing them. Stemgen is a way to create your own stems with only one command.

[!NOTE] May 2023 Update: I saw François K last week in Paris at the Loft Babies party and I discovered that he's playing with Stems. I highly recommend checking out his videos on YouTube: https://www.youtube.com/playlist?list=PLCr4LSsJFk48tmNoKn-l7mgsB5XUd2Af9. He's a legend and a true pioneer. I'm so happy to see him having fun with Stems. And trust me: it's even better in real life. Can't wait to see him again!

"There is a really big difference between using a tool, a computer as a tool, to make it do specific things we want it to do, in the manner in which we want it to accomplish it. In most other situations, we all find ourselves dealing with a pre-programmed or pre-determined path that the software designer has decided we must use the software in order to get certain things done. And I think that makes it that we, little by little, become controlled by the path that was designed by the people who wrote the software and forced into these gullies that they created of usage, that this is how we are supposed to be doing things. And after a while I think it's making us forget who we were and what the essence of what the music was supposed to be about and really represented.

And this right here -- I have to be honest -- it's groundbreaking to me in that sense. It's putting me back in touch with using these tools that I'm using right now as mere instruments of my will, rather than me being forced around the way they were designed to be operated, and in the process losing the very essence of what I was trying to express. Goddammit!" – François K, Expansions (Live Stems Dub and Talk)

What?

  • Highest quality: ALAC stems by default, or AAC using the best encoder and quality possible.
  • Automatic metadata tagging: scraping metadata from the master file and writing it back to the stem file.
  • Batching: you can use this CLI to batch your stem creation and/or create a powerful workflow.
  • Universal: works on macOS, Windows and Linux.

Requirement

Usage

You can use stemgen.py to generate stems:

  • $ python3 stemgen.py track.wav
  • Have fun! Your new .stem.m4a file is in output dir
  • Supported input file format are .wav .wave .aif .aiff .flac

Bring your own stems

Manually

You can use stem.py to create stems:

  • $ python3 stem.py -i track/track.0.wav
  • You need to follow this naming convention: [TRACK_NAME].[TRACK_NUMBER].[FILE_EXTENSION]
  • TRACK_NAME should be identical for all files
  • Please use 0 as the TRACK_NUMBER for the master track. Example: 'track.0.wav' for the master file then 'track.1.wav' for the first stem, etc...
  • Have fun! Your new .stem.m4a file is in output dir
  • Supported input file format are .wav .wave .aif .aiff .flac

With Ableton Live

You can use Ableton Live to create stems:

  • $ python3 ableton.py

Quick install on macOS

  • python3 -m pip install -U demucs
  • python3 -m pip install mutagen
  • brew install coreutils ffmpeg sox

Quick install on Linux

Long install on Windows

qaac

If you plan to encode in AAC, you should install qaac. Here is a quick guide:

Then, to use Audio Toolbox from Apple:

  • git clone https://github.com/nu774/makeportable.git
  • cd makeportable
  • Download the iTunes installer from https://www.apple.com/itunes/download/win64
  • Copy the iTunes installer to the makeportable folder
  • makeportable.cmd
  • Copy the newly created folder QTfiles64 to your C:\Program Files\qaac folder

Then, to support FLAC files:

  • Download FLAC from https://github.com/xiph/flac/releases
  • Copy the libFLAC.dll file from the Win64 folder (or Win32 depending on your system)
  • Paste it in your C:\Program Files\qaac folder

Enjoy! You can now encode AAC stems with Apple Audio Toolbox, the highest quality AAC encoder.

Performance

  • Stem and Stemgen supports 16-bit and 24-bit audio files!
  • Stemgen needs to downsample the track to 44.1kHz to avoid problems with the separation software because the models are trained on 44.1kHz audio files. Stem uses the original sample rate.
  • You may notice that the output file is pretty big. Apple Lossless Codec (ALAC) for audio encoding is used for lossless audio compression at the cost of increased file size.

Screenshot Input Screenshot Output

Disclaimer

If you plan to use Stemgen on copyrighted material, make sure you get proper authorization from right owners beforehand.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

stemgen-2.1.0.tar.gz (66.0 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

stemgen-2.1.0-py3-none-any.whl (66.3 MB view details)

Uploaded Python 3

File details

Details for the file stemgen-2.1.0.tar.gz.

File metadata

  • Download URL: stemgen-2.1.0.tar.gz
  • Upload date:
  • Size: 66.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for stemgen-2.1.0.tar.gz
Algorithm Hash digest
SHA256 de8670ab7caa66f2cd2e30b59c1f4129af54c35fff4b92e9a635e0d2cc0fea46
MD5 22bb87740b34dc71541f5a1030d5501b
BLAKE2b-256 7864bd8db330dc0ea13de592e2166c9de11b20d1d3e5044dc3410a9304b23f72

See more details on using hashes here.

File details

Details for the file stemgen-2.1.0-py3-none-any.whl.

File metadata

  • Download URL: stemgen-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 66.3 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for stemgen-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8093c59763fb5e76ecbb792226a15532fdbba22b35faf258197d04c07b0c61d1
MD5 684d3e88c194601cdcc69100d79f5f2a
BLAKE2b-256 003829ff8fb0788c1685b80534deb9aaea2834a074cd313a87b914ebddaeee60

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page