本项目将 timm/mobilevitv2_050.cvnets_in1k 图片分类模型适配到单卡昇腾 NPU (Ascend910) 上运行。使用 ModelScope snapshot_download 下载本地权重,通过 timm.create_model(..., pretrained=False) 加载,并在 NPU 上完成推理验证、精度一致性检查和性能基准测试。
环境检查日志见 logs/env_check.log。
pip install -r requirements.txt
python inference.py推理结果 (NPU Top-5):
输入尺寸: [1, 3, 256, 256]
输出尺寸: [1, 1000]
日志保存在 logs/inference.log。
对单张测试图片进行 CPU 与 NPU 一致性验证:
| 指标 | 数值 |
|---|---|
| max_abs_error | 0.014222 |
| mean_abs_error | 0.002890 |
| relative_error | 0.2071% |
| cosine_similarity | 0.999998 |
| threshold | 1.0% |
| 结果 | PASS |
基于单张测试图片在 NPU 上的基准测试(预热 2 次,正式 10 次):
| 指标 | 数值 |
|---|---|
| latency_avg_ms | 6.838 |
| latency_min_ms | 6.774 |
| latency_max_ms | 6.935 |
| latency_p50_ms | 6.845 |
| latency_p90_ms | 6.868 |
| latency_p95_ms | 6.868 |
| images_per_sec | 146.24 |
日志保存在 logs/benchmark.log。
本项目包含单图 smoke consistency 验证,非官方 ImageNet 完整验证集评测。详细指标见第 4 节。
见 screenshots/self_verification.png。
logs/env_check.log — NPU 环境检查logs/inference.log — NPU 推理结果logs/accuracy.log — CPU-NPU 精度一致性logs/benchmark.log — 性能基准测试snapshot_download 自动下载到本地缓存,不会提交到 Git 仓库。timm.create_model 必须设置 pretrained=False,禁止 HuggingFace 自动下载。timm.data.resolve_model_data_config 获取模型对应的预处理参数。.bin / .safetensors / .pth 等已在 .gitignore 中排除)。#NPU #Ascend #Ascend910 #MobileViTV2 #ImageClassification