g
gyccc/timm-twins_svt_large.in1k-NPU
模型介绍文件和版本Pull Requests讨论分析
下载使用量0

timm/twins_svt_large.in1k on Ascend NPU

1. 简介

将 timm/twins_svt_large.in1k 图片分类模型适配到华为昇腾 NPU (Ascend910)。该模型为 Twins (SVT) Large 架构,参数量约 9927 万,支持 ImageNet-1K 1000 类分类。

适配方式:

  • 使用 ModelScope snapshot_download 下载模型权重(非 HuggingFace 直连)
  • 使用 timm.create_model(pretrained=False) 创建模型结构并加载本地权重
  • 无 fallback,无权重提交

2. 验证环境

项目信息
设备Ascend910
npu-smi25.5.2
框架PyTorch + torch_npu
模型参数量99,271,400
权重文件model.safetensors (378.7 MB)

3. 推理运行

cd timm-twins_svt_large.in1k-NPU
pip install -r requirements.txt
python inference.py

输出示例:

=== Inference Result (NPU) ===
Model: timm/twins_svt_large.in1k
Output shape: torch.Size([1, 1000])

Top-1: class_970  prob=0.8291
Top-2: class_979  prob=0.0585
Top-3: class_972  prob=0.0265
Top-4: class_980  prob=0.0038
Top-5: class_350  prob=0.0032

4. 精度验证

对单张测试图片进行 CPU 与 NPU 一致性验证:

指标数值
max_abs_error0.017189
mean_abs_error0.001445
relative_error0.4290%
cosine_similarity0.999995
threshold1.0%
结果PASS
  • CPU Top-1: class_970
  • NPU Top-1: class_970
  • CPU Top-5: class_970, class_979, class_972, class_980, class_350
  • NPU Top-5: class_970, class_979, class_972, class_980, class_350
  • Top-1 match: True
  • Top-5 match: True

5. 性能参考

指标数值
平均延迟13.73 ms
最小延迟13.17 ms
最大延迟14.16 ms
P5013.92 ms
P9014.16 ms
P9514.16 ms
吞吐量72.84 images/sec

测试条件:batch_size=1, 输入 224x224, 预热 2 次 + 正式 10 次。

6. 精度评测说明

本项目包含单图 smoke consistency 验证,非官方 ImageNet 完整验证集评测。详细指标见第 4 节。

7. 自验证截图

见 screenshots/self_verification.png。

8. 日志文件

文件说明
logs/inference.logNPU 推理结果
logs/accuracy.logCPU-NPU 精度一致性验证
logs/benchmark.logNPU 性能基准测试

9. 注意事项

  • 该模型约 9927 万参数,权重 378.7 MB,属中大规模模型
  • 使用 timm.create_model(pretrained=False) + 本地权重加载,禁止 HuggingFace 直连
  • 权重文件(*.bin, *.safetensors)未提交到仓库

10. 标签

#NPU