File size: 4,405 Bytes
c2b5bcd
 
 
 
 
 
 
 
 
5035fe7
 
 
 
b4c98e9
5035fe7
b4c98e9
5035fe7
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
c717de4
 
 
 
5035fe7
b4c98e9
 
 
ff2ab51
b4c98e9
ff2ab51
 
 
5035fe7
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
b4c98e9
5035fe7
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
b4c98e9
 
 
 
 
5035fe7
 
 
 
7e9283d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
---
license: mit
language:
- en
metrics:
- accuracy
pipeline_tag: image-classification
tags:
- biology
---

# Bird-Species-Classification

This project only to show a demo of Bird Species Classification model within 1400+ species of birds.

The model is trained with 224x224 resolution.

This model has been converted to run on the Axera NPU using **w8a16** quantization.

This model has been optimized with the following LoRA: 

Compatible with Pulsar2 version: 5.1

## Convert tools links:

For those who are interested in model conversion, you can try to export axmodel through 

- [Pulsar2 Link, How to Convert ONNX to axmodel](https://pulsar2-docs.readthedocs.io/en/latest/pulsar2/introduction.html) 


## Support Platform

- AX650
  - [M4N-Dock(爱芯派Pro)](https://wiki.sipeed.com/hardware/zh/maixIV/m4ndock/m4ndock.html)
  - [M.2 Accelerator card](https://docs.m5stack.com/zh_CN/ai_hardware/LLM-8850_Card)
- AX630C
  - [爱芯派2](https://axera-pi-2-docs-cn.readthedocs.io/zh-cn/latest/index.html)
  - [Module-LLM](https://docs.m5stack.com/zh_CN/module/Module-LLM)
  - [LLM630 Compute Kit](https://docs.m5stack.com/zh_CN/core/LLM630%20Compute%20Kit)
 
| Models       | Platforms    | latency       | Top5 Accuracy | CMM size(MB)  |
| -------------| -------------| ------------- | --------------| --------------|
|              | AX650        | 0.19ms        |               |               |
| bird-s       | AX630C       | 0.54ms        | 66%           | 1.07          |
|              | AX615        | 0.87ms        |               |               |
|              | AX650        | 0.58ms        |               |               |
| bird-m       | AX630C       | 2.52ms        | 79%           | 12.2          |
|              | AX615        | 4.97ms        |               |               |

## How to use

Download all files from this repository to the device

```
root@ax650:~/Bird-Species-Classification# tree
.
β”œβ”€β”€ README.md
β”œβ”€β”€ axmodel_infer.py
β”œβ”€β”€ class_name.txt
β”œβ”€β”€ model
β”‚Β Β  β”œβ”€β”€ AX615
β”‚Β Β  β”‚Β Β  β”œβ”€β”€ bird_615_npu1.axmodel
β”‚Β Β  β”‚Β Β  └── bird_615_npu2.axmodel
β”‚Β Β  β”œβ”€β”€ AX620E
β”‚Β Β  β”‚Β Β  β”œβ”€β”€ bird_630_npu1.axmodel
β”‚Β Β  β”‚Β Β  └── bird_630_npu2.axmodel
β”‚Β Β  └── AX650
β”‚Β Β      └── bird_650_npu3.axmodel
β”œβ”€β”€ onnx_infer.py
β”œβ”€β”€ prediction_result_top5.png
β”œβ”€β”€ quant
β”‚Β Β  β”œβ”€β”€ Bird.json
β”‚Β Β  β”œβ”€β”€ README.md
β”‚Β Β  └── bird.tar.gz
└── test_images
    β”œβ”€β”€ 03111_2c0dfa5a-c4a0-47f8-ac89-6a289208050f.jpg
    β”œβ”€β”€ 03332_01b365c3-a741-4f45-bac2-4345bc901ec6.jpg
    β”œβ”€β”€ 03412_0ffc115b-43b4-4474-a373-24233f391de3.jpg
    β”œβ”€β”€ 03615_0dfbf6ae-434d-4648-b5d2-08412546ea64.jpg
    β”œβ”€β”€ 04251_3a52191e-be71-4539-98ea-14a8f2347330.jpg
    β”œβ”€β”€ 04405_0c5a6785-0bc2-49d9-9702-b9e94ba9b686.jpg
    └── 04593_3d74d5a7-15b1-4bb9-af6f-1bcd78485787.jpg

6 directories, 20 files

```

### python env requirement

#### pyaxengine

https://github.com/AXERA-TECH/pyaxengine

```
wget https://github.com/AXERA-TECH/pyaxengine/releases/download/0.1.3rc0/axengine-0.1.3-py3-none-any.whl
pip install axengine-0.1.3-py3-none-any.whl
```

## Inference with AX650 Host, such as M4N-Dock(爱芯派Pro)

```
root@ax650:~/Bird-Species-Classification# python3 axmodel_infer.py --image test_images/04251_3a52191e-be71-4539-98ea-14a8f2347330.jpg
[INFO] Available providers:  ['AxEngineExecutionProvider']
Loading ONNX model with providers: ['AxEngineExecutionProvider']
[INFO] Using provider: AxEngineExecutionProvider
[INFO] Chip type: ChipType.MC50
[INFO] VNPU type: VNPUType.DISABLED
[INFO] Engine version: 2.12.0s
[INFO] Model type: 2 (triple core)
[INFO] Compiler version: 5.1-patch1 74996179

Image: test_images/04251_3a52191e-be71-4539-98ea-14a8f2347330.jpg
Top-5 Predictions:
#1: 04251_Animalia_Chordata_Aves_Passeriformes_Tityridae_Tityra_semifasciata (0.9823)
#2: 04333_Animalia_Chordata_Aves_Passeriformes_Tyrannidae_Tyrannus_savana (0.0103)
#3: 04208_Animalia_Chordata_Aves_Passeriformes_Sylviidae_Sylvia_melanocephala (0.0056)
#4: 03561_Animalia_Chordata_Aves_Coraciiformes_Alcedinidae_Todiramphus_chloris (0.0009)
#5: 04455_Animalia_Chordata_Aves_Piciformes_Picidae_Melanerpes_lewis (0.0005)
Result saved to: prediction_result_top5.png
```

output:
<img src="./prediction_result_top5.png" width="200%" alt="ι’„ζ΅‹η»“ζžœ" />