AI音楽生成ツール「MusicGen」のインストールは、複数のライブラリ間の複雑な依存関係のため、多くのユーザーが挫折する難易度の高い作業です。本記事では、実際のトラブルシューティング経験を基に、確実にインストールを成功させる手順を解説します。
問題の本質
MusicGenのインストールが困難な理由は以下の通りです:
1. バージョン互換性の複雑さ
- PyTorch 2.1.0が必要
- Transformers 4.31.0以上が必要
- Gradioとhuggingface-hubの間でバージョン競合が発生
- tokenizerライブラリの複雑な依存関係
2. 環境固有の問題
- WindowsでのTriton非対応
- CUDA版とCPU版の混在
- 公式ドキュメントと実際の要件の乖離
確実なインストール手順
Step 1: 環境の準備
# 仮想環境を作成(必須)
python -m venv venv
venv\Scripts\activate
# Python 3.10推奨(3.9-3.11で動作確認済み)
python --version
重要: 既存の仮想環境に問題がある場合は、完全に削除して再作成してください。
deactivate
rmdir /s venv
python -m venv venv
venv\Scripts\activate
Step 2: PyTorchのインストール
PyTorchを最初にインストールすることが重要です。
# 公式要件に従ってPyTorch 2.1.0をインストール
python -m pip install 'torch==2.1.0'
# セットアップツールを準備
python -m pip install setuptools wheel
Step 3: AudioCraftのクローンとインストール
# リポジトリをクローン
git clone https://github.com/facebookresearch/audiocraft
cd audiocraft
# パッケージをインストール
python -m pip install -e .
Step 4: 依存関係の調整(最も重要な部分)
ここが最も困難な部分です。以下の順序で実行してください:
# 1. Transformersを正しいバージョンに固定
pip install transformers==4.31.0
# 2. huggingface-hubを互換性のあるバージョンに設定
pip install huggingface-hub==0.16.4
# 3. Gradioを安定版に設定
pip install gradio==3.44.4
注意: この順序を変更すると依存関係エラーが発生する可能性があります。
よくあるエラーと対処法
エラー 1: register_pytree_nodeが見つからない
AttributeError: module 'torch.utils._pytree' has no attribute 'register_pytree_node'
原因: TransformersとPyTorchのバージョン不整合
対処法:
pip install transformers==4.31.0
エラー 2: EncodecModelがインポートできない
ImportError: cannot import name 'EncodecModel' from 'transformers'
原因: Transformersのバージョンが古すぎる
対処法:
pip install 'transformers>=4.31.0'
エラー 3: get_tokenが見つからない
ImportError: cannot import name 'get_token' from 'huggingface_hub'
原因: GradioとHugging Face Hubのバージョン競合
対処法:
pip install huggingface-hub==0.16.4 gradio==3.44.4
エラー 4: audiocraft.demosモジュールが見つからない
ModuleNotFoundError: No module named 'audiocraft.demos'
原因: パッケージが正しくインストールされていない
対処法:
# 直接ファイルを実行
python demos/musicgen_app.py
起動確認
正常にインストールできた場合、以下のコマンドで起動します:
python demos/musicgen_app.py
次の内容で起動用バッチの作成します。(例 audiocraft.bat
echo Activating Virtual Environment and Running Musicgen Script
call .\venv\Scripts\activate.bat
python .\demos\musicgen_app.py
pause
成功時の表示:
Running on local URL: http://127.0.0.1:7860
ブラウザで上記URLにアクセスすればWebインターフェースが利用できます。
警告メッセージの対応
起動時に以下の警告が表示されますが、動作に問題ありません:
Triton警告
A matching Triton is not available, some optimizations will not be enabled.
WindowsでCUDAを使用していない場合は正常な表示です。
Gradio警告
You have unused kwarg parameters in Audio
バージョン間の互換性の問題ですが、機能には影響しません。
トラブルシューティングのコツ
1. 段階的なデバッグ
エラーが発生した場合は、以下の順序で確認してください:
- Python環境(バージョン、仮想環境の状態)
- PyTorchのインストール状況
- 各ライブラリのバージョン確認
- 依存関係の競合確認
2. バージョン確認コマンド
pip list | findstr -i "torch transformers gradio huggingface"
3. 完全リセットの手順
問題が解決しない場合は、環境を完全にリセットしてください:
deactivate
rmdir /s venv
python -m venv venv
venv\Scripts\activate
# 上記の手順を最初から実行
成功の鍵となるポイント
- 順序の遵守: PyTorch → AudioCraft → 依存関係調整の順序を守る
- バージョン固定: 曖昧なバージョン指定は避け、具体的なバージョンを指定する
- 仮想環境の利用: システムPythonではなく、必ず仮想環境を使用する
- 警告の理解: すべての警告がエラーではないことを理解する
まとめ
MusicGenのインストールは複雑ですが、正しい手順と対処法を知っていれば必ず成功します。依存関係の競合は避けられない問題ですが、本記事の手順に従うことで、効率的にインストールを完了できます。
問題が発生した場合は、段階的にデバッグし、必要に応じて環境をリセットすることが重要です。一度成功すれば、高品質なAI音楽生成を楽しむことができます。


コメント