-
-
Notifications
You must be signed in to change notification settings - Fork 16.5k
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
Loading model from Torch Hub causes unexpected module collision #2414
Comments
👋 Hello @Lymkwi, thank you for your interest in 🚀 YOLOv5! Please visit our ⭐️ Tutorials to get started, where you can find quickstart guides for simple tasks like Custom Data Training all the way to advanced concepts like Hyperparameter Evolution. If this is a 🐛 Bug Report, please provide screenshots and minimum viable code to reproduce your issue, otherwise we can not help you. If this is a custom training ❓ Question, please provide as much information as possible, including dataset images, training logs, screenshots, and a public link to online W&B logging if available. For business inquiries or professional support requests please visit https://www.ultralytics.com or email Glenn Jocher at [email protected]. RequirementsPython 3.8 or later with all requirements.txt dependencies installed, including $ pip install -r requirements.txt EnvironmentsYOLOv5 may be run in any of the following up-to-date verified environments (with all dependencies including CUDA/CUDNN, Python and PyTorch preinstalled):
StatusIf this badge is green, all YOLOv5 GitHub Actions Continuous Integration (CI) tests are currently passing. CI tests verify correct operation of YOLOv5 training (train.py), testing (test.py), inference (detect.py) and export (export.py) on MacOS, Windows, and Ubuntu every 24 hours and on every commit. |
@Lymkwi thanks for the bug report! I tried to reproduce your issue in a Colab notebook but everything ran correctly for me. The code I used is here. Can you please provide a link to a notebook that reproduces the issue you are seeing? !mkdir utils
!touch utils/__init__.py
import torch
import utils as utils_temp
# Model
model = torch.hub.load('ultralytics/yolov5', 'yolov5s', pretrained=True)
# Images
dir = 'https://github.com/ultralytics/yolov5/raw/master/data/images/'
imgs = [dir + f for f in ('zidane.jpg', 'bus.jpg')] # batched list of images
# Inference
results = model(imgs)
results.print() # or .show(), .save() |
@Lymkwi if I place the code in main.py I am now able to reproduce. Yes it seems there is a package naming conflic with the torch hub operations. The easiest workaround seems to be loading the model first before any other potentially conflicting imports (see main.py in screenshot below). Not sure if there is a general solution to this. What do you think? |
Loading the torch model before anything else can help in some situations but in the architecture of my project it did break the way I designed everything (so I ended up changing names instead). I'm not familiar enough with torch hub to begin to investigate a proper fix (as I still believe this is a bug), but at least it should deserve proper documentation so that people do not lose time trying to understand why a conflict happens (if it does). Somebody who can edit the Pytorch Hub wiki issue on this repo (which you can I believe?) could at least add a warning of this known problem for now IMO. |
@Lymkwi yes this is a good idea, we will be updating our documentation in the future and this is one of the changes we can make. I think the following guidelines should work for all users right? # Model
import torch
model = torch.hub.load('ultralytics/yolov5', 'yolov5s')
# Imports
# place added imports after model is loaded to avoid conflicts
# Images
dir = 'https://github.com/ultralytics/yolov5/raw/master/data/images/'
imgs = [dir + f for f in ('zidane.jpg', 'bus.jpg')] # batch of images
# Inference
results = model(imgs)
results.print() # or .show(), .save() |
According to your experiments, yes, this should cover most situations. |
This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions. |
Hi, I think I have a similar issue that prevent from loading more than one model using torch.hub If I'm not mistaken by reading the thread, loading the model shadows some module names, that then become unusable in torch. I'm using torch '1.9.1+cu102' on a Ubuntu 20.04 machine and to reproduce I do:
that ends up in
reversing the load order obviously ends up with:
Is there some workaround which I'm not seeing? |
@carloalbertobono thanks for the code, am able to reproduce in colab. I'm not sure there's a simple fix, but also this might be slightly outside of our scope. You should definitely raise on pytorch and/or hub repos also: https://github.com/pytorch/pytorch |
🐛 Bug
Using
torch.hub.load
to load any YOLOv5 model in an environment where eitherutils
ormodels
(and I assumedata
orweights
) are top-level modules causes an undetected conflict resulting in a crash.To Reproduce
The following minimalist directory structure :
with the following content for
main.py
:(you can keep
__init__.py
empty)Output:
Expected behavior
The model should be loaded without crashing, or it should at least be mentioned in #36 that one should be mindful of module name conflict (even when those modules are imported with other names) while using
torch.hub.load
Environment
Additional context
I have been running up against this issue for a couple hours now, trying to load a model from yolo's code itself at first then discovering Torch Hub. When using Torch Hub however, I kept encountering import crashes in my image captioning project that made no sense since
torch.hub.load
should treat imports it does separately from the context where it is ran (and even if it does not, importing modules with a different name should let me avoid this issue). At first I suspected that it was because my code was in a subdirectory of the top level. I modified the entry point of my project to only runtorch.hub.load
, and still crashed. Finally, after carving out huge chunks of the code base in a copy I made, I discovered that commentingimport utils
and other references to myutils
module (which is where I keep utilities like configuration and logging),torch.hub.load
worked.Considering how hacky python's module import system is, I could see why this is happening (i.e. there's a conflict between yolo's modules when torch imports them), but do not think this is a normal behaviour (since it basically forbids using
utils
,models
ordata
as top-level module names in any project that loads yolov5 from torch hub).The text was updated successfully, but these errors were encountered: