Table des matières

Stemspleet

Demucs

Pour l'installer, les instructions sont correctes. J'ai eu une erreur au début sur la version de CMake ; il suffit de corriger CmakeLists.txt

Pour résumer, on clone le dépôt comme c'est dit, on compile (et si on a Arch en théorie on a depuis longtemps installé tout ce qu'il faut pour), on télécharge les modèles (ils ne sont pas lourds), puis on sépare les pistes.

Je compile en sollicitant moins le cpu de mon côté, je n'ai pas un foudre de guerre. Pour savoir combien de cœur sont dispo, on fait la commande nproc. Ou lscpu, les lignes “Thread(s) par cœur” et ““Cœur(s) par socket” indiquent plus de détail. Mais ce que dit nproc suffit.

git clone --recurse-submodules https://github.com/sevagh/demucs.cpp
mkdir -p build && cd build && cmake .. && make -j4
# les modèles
git clone https://huggingface.co/datasets/Retrobear/demucs.cpp

La commande : lien vers le soft, lien vers le modèle, liens vers la zik, lien vers le dossier où envoyer l'unmixage, nombre de thread à mettre au travail

./demucs_mt.cpp.main ./models.cpp/ggml-model-htdemucs-4s-f16.bin /lienvers/machin.wav ./demucs-out-cpp/ 8

À noter que si la version de base demande qu'on lui indique le chemin complet vers le modèle, la version ft attent le dossier où sont les modèles.

Bon format en entrée

Si on n'a pas un wav échantilloné à 44100 Hz, ça râle. Hop, un coup de ffmpeg :

ffmpeg -i musik.mp3 -ar 44100 -ac 2 -acodec pcm_s16le sortie.wav

Choix du modèle

De base, sans autre précision, les modèles séparent en 4 pistes (basse, batterie, voix, autres). “4s” ou “6s” indiquent précisément si on va avoir 4 ou 6 pistes (stem).

Et choix du binaire

Lors de la compilation, on obtient plusieurs binaires.

Raccourci via script bash

Je me suis fait un alias dans mes raccourcis, il suffit ensuite de rentrer demuc fichier.mp3 pour que :

  1. Ça crée un dossier (dans celui où est le mp3)
  2. Ça me convertisse dans le bon format de wav
  3. Ça transforme ça avec demuc, en n'utilisant pas tous mes cœurs.
demuc.sh
#!/bin/bash
# Variables
DEMUCSEXEC="/home/zatalyz/Documents/demucs.cpp/build/demucs_mt.cpp.main"
MODEL="/home/zatalyz/Documents/demucs.cpp/build/models.cpp/ggml-model-htdemucs-4s-f16.bin"
 
# Vérification du fichier d'entrée
if [ $# -ne 1 ]; then
    echo "Usage : $0 chemin/vers/fichier.mp3"
    exit 1
fi
 
INPUT="$1"
 
if [ ! -f "$INPUT" ]; then
    echo "Erreur : fichier introuvable."
    exit 1
fi
 
# Création du dossier de sortie
BASENAME=$(basename "$INPUT")
NAME="${BASENAME%.*}"
INPUTDIR=$(dirname "$INPUT")
OUTDIR="${INPUTDIR}/${NAME}_stem"
mkdir -p "$OUTDIR"
 
# Conversion en wav 44.1 kHz si nécessaire
WAVFILE="${OUTDIR}/${NAME}_44100.wav"
echo "Conversion de l'entrée en WAV 44.1kHz..."
ffmpeg -i "$INPUT" -ar 44100 -ac 2 -acodec pcm_s16le "$WAVFILE"
 
# Appel de demucs
echo "Séparation avec Demucs..."
"$DEMUCSEXEC" "$MODEL" "$WAVFILE" "$OUTDIR" 8
 
 
echo "Séparation terminée. Résultats dans : $OUTDIR"

L'alias étant (dans .aliases mais ça dépend des paramétrages de chacun) :

alias demuc="/home/zatalyz/Documents/scripts/demuc/demuc.sh"

Autres soft

 Ce texte est placé sous licence CC0