-
Notifications
You must be signed in to change notification settings - Fork 685
Torchaudio is not detecting FFmpeg #3789
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Comments
Loading manullay the binaries is working but, I would like it was automatic. ctypes.CDLL('C:/Program Files/ffmpeg/bin/avcodec-60.dll')
ctypes.CDLL('C:/Program Files/ffmpeg/bin/avdevice-60.dll')
ctypes.CDLL('C:/Program Files/ffmpeg/bin/avfilter-9.dll')
ctypes.CDLL('C:/Program Files/ffmpeg/bin/avformat-60.dll')
ctypes.CDLL('C:/Program Files/ffmpeg/bin/avutil-58.dll') I still don't know why it is not working without preloading libraries. |
If I locate the libraries in the same folder of EDIT: I have been checking the internal code and in file if os.name == "nt" and (3, 8) <= sys.version_info < (3, 9):
_init_dll_path() This code adds the paths from Thank you. |
Ran into this same unexpected behavior as well. If _init_dll_path() is allowed to run it works as expected |
Same problem here, struggling for hours. Win 11, Python 3.12.4, using pip, ffmpeg 6.1.2 with shared libraries, path OK, can run on CMD, restarted multiple times, etc... Using ctypes.CDLL workaround also did not work in my case. Only "soundfile" can be used. os.add_dll_directory("C:\\Programs\\ffmpeg-6.1\\bin\\") PS: I'm trying to convert my code to use torch/torchaudio. Before torchaudio I've been using PyAV without any problems - using ffmpeg for a decade. torchaudio's ffmpeg documentation is also very cryptic. As far as I can see, torchaudio moved to ffmpeg as the main cross-platform library, but still too many problems. |
Hi HarikalarKutusu, do you have all the required ffmpeg DLL files? In my case I need all of these for ffmpeg to be detected, in addition to executing _init_dll_path from the file modified in torchaudio:
Using the dlls from this ffmpeg shared build: https://github.com/GyanD/codexffmpeg/releases/tag/6.1.1 |
I used I did not update the _init_dll_path directly in tourchaudio distribution, but used
Let me try the one from your link... |
Joy! I was wrong.
Also changed the v3.8 limitation code to be safe. # if os.name == "nt" and (3, 8) <= sys.version_info < (3, 9):
# _init_dll_path()
if os.name == "nt" and (3, 8) <= sys.version_info < (3, 99):
_init_dll_path() It now works. Thank you for the guidance @chislonchow ! |
Just update
|
Docs and code that are trying to load libraries are very bad, for sure.
|
As a result I've figured out that BTW you can use |
After a couple hours of constant attempts at different solutions, including using the above, I managed a fully working solution by simply copying out the code from _init_dll_path in the torchaudio extensions and having it run if this is a Windows platform. Changing the version within the library code of torchaudio works just fine, yes, but I would rather not do that and want something that is replicable to anyone who would be interested in running my Jupyter notebooks without having to make such modifications. The reason for copying the code out is because for reasons unknown to me (I am not very experienced with Python modules), simply attempting to import the _init_dll_path module and running that does not seem to want to work when I then import torchaudio down below. (As in, the FFMPEG backend is not produced, even though the PATH is added to the DLL directories.) I am curious if just importing that method to call it is intializing the torchaudio module prematurely, as that what seems to be happening. Regardless, this is the first GitHub issue that shows in Google right now, so I wanted to contribute my findings. FFMPEG 6 with the shared library option needs to be installed, but there is some confusion there as well. When dowloading FFMPEG manually to stick somewhere to simply add to your PATH (which is what I do, as I use FFMPEG elsewhere for other tools as well), you must use the "Windows builds by BitbN" link on the ffmpeg.org page, and then you must download the ffmpeg-n6.1.2-27-ge16ff06adb-win64-gpl-shared-6.1.zip variant, very specificallly the GPL variant, as the LGPL version is missing the postproc-57 DLL. For FFMPEG 6.1, you should have the following DLLs:
It may not need all of these, but if one that it wants is missing, it tells you nothing and fails to load the FFMPEG backend. I kinda wish it would give you a bit more about what DLLs are missing (it took me 15 minutes to realize the LGPL variant of the downloads didn't have the postproc-57 DLL). Having this all setup is the first steps, but then torchaudio is not loading the backend anyway right now because of that version check described above. Changing that code in the library works, but I would rather have something a bit more flexible for others to easily run on their machines without needing to do the same modifications. My first thought was to run torchaudio._extension.utils._init_dll_path directly before importing torchaudio. My particular issue was that I wanted to use torchaudio.list_audio_backends immediately after importing torchaudio. For reasons that I speculated on above, that doesn't work, and it fails to load the FFMPEG backend. What I did instead was simply copied the code out of _init_dll_path and ran it directly: import os
import sys
# Manually call the _init_dll_path method to ensure that the system path is searched for FFMPEG.
# Calling torchaudio._extension.utils._init_dll_path does not work because it is initializing the torchadio module prematurely or something.
# See: https://github.com/pytorch/audio/issues/3789
if sys.platform == "win32":
print("Initializing DLL path for Windows")
for path in os.environ.get("PATH", "").split(";"):
if os.path.exists(path):
try:
os.add_dll_directory(path)
except Exception:
pass
import torch
import torchaudio
print(torch.__version__)
print(torchaudio.__version__)
print(torchaudio.list_audio_backends()) |
Thank you very much, I added this code at the start of my project and it works, the error disappeared! (In fact, I put the relevant code into a file |
I just want to say thank you to all you legends this has been a massive headache for me for the past hour and a half. PS for anyone who comes in the future. As of torchaudio 2.6.0, only FFMPEG version 4 to 6 work, and you must download the SHARED versoin. You can download it here |
🐛 Describe the bug
Hi everyone,
I am trying to use torchaudio with FFmpeg but for some reason it is not being detected.
I added the path 'C:\Program Files\ffmpeg\bin' to the PATH environment variable. As you can see I can execute ffmpeg from cmd. However, when I execute
torchaudio.list_audio_backends()
only 'soundfile' is detected. I tested this in a Python PIP (I can't use conda) virtual environment with version 3.10 and in another one with version 3.12 but, it didn't work in both. Torchaudio and torch versions are2.2.1
. I don't know if it is a problem with version compatibility but in the official documentation I saw ffmpeg 6 is supported and I checked the code which tries to load the libraries.I checked a lot of related issues but I couldn't find the right solution.
Any suggestions are welcome!
Thanks.
Versions
The text was updated successfully, but these errors were encountered: