import argparse, json, torch from torchvision import models, transforms from PIL import Image import urllib.request IMAGENET_URL = "https://raw.githubusercontent.com/pytorch/hub/master/imagenet_classes.txt" def load_labels(): with urllib.request.urlopen(IMAGENET_URL) as f: labels = [s.strip() for s in f.read().decode("utf-8").splitlines()] return labels def main(): parser = argparse.ArgumentParser() parser.add_argument("--image", type=str, default=None, help="Path to an image") args = parser.parse_args() device = torch.device("cuda" if torch.cuda.is_available() else "cpu") model = models.mobilenet_v2(weights=models.MobileNet_V2_Weights.DEFAULT).to(device).eval() preprocess = models.MobileNet_V2_Weights.DEFAULT.transforms() img = Image.open(args.image).convert("RGB") if args.image else Image.new("RGB", (224,224), "white") x = preprocess(img).unsqueeze(0).to(device) with torch.no_grad(): logits = model(x) probs = torch.softmax(logits, dim=-1)[0] top5 = torch.topk(probs, 5) labels = load_labels() for p, idx in zip(top5.values, top5.indices): print(f"{labels[idx]}: {float(p):.4f}") if __name__ == "__main__": main()