tpu-mlir


Nametpu-mlir JSON
Version 1.14 PyPI version JSON
download
home_pagehttps://github.com/sophgo/tpu-mlir
SummaryMachine learning compiler based on MLIR for Sophgo TPU v1.14-g9f8d4d4-20241231
upload_time2024-12-31 09:17:02
maintainerNone
docs_urlNone
authorSOPHGO
requires_python<3.11,>=3.10
license2-Clause BSD
keywords python3.10 unbuntu22.04 linux tpu-mlir
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ![](./docs/assets/sophgo_cover.png)

# TPU-MLIR

For Chinese version: [README](https://github.com/sophgo/tpu-mlir/blob/master/README_cn.md).

TPU-MLIR is an open-source machine-learning compiler based on MLIR for TPU. This project provides a complete toolchain, which can convert pre-trained neural networks from different frameworks into binary files `bmodel` that can be efficiently operated on TPUs.

SOPHGO aims to become a leading global provider of general-purpose computing power. SOPHGO focuses on the research, development, and promotion of computing products such as Deep Learning and RISC-V processors, and has built a comprehensive application matrix covering the 'cloud, edge, and endpoint' scenarios with its self-developed products. SOPHGO provides computing products and integrated solutions for applications such as smart cities, intelligent computing centers, smart security, intelligent transportation, safety production, industrial quality inspection, and intelligent terminals. The company has research and development centers in more than 10 cities in China including Beijing, Shanghai, Shenzhen, Qingdao, and Xiamen, as well as in the United States and Singapore.

Currently, supported Deep Learning frameworks are PyTorch, ONNX, TFLite and Caffe. Models from other frameworks need to be converted to ONNX models.


# Prebuilt TPU-MLIR Python Package

We provide TPU-MLIR python package for quick installation by skipping the building step.
Environment prerequisite: python >= 3.10 and ubuntu:22.04 (It is recommended to use our docker image directly).

To install:

``` shell
pip install tpu_mlir
```

# Resources

Here are some resources to help you better understand the project:

| Index | Documents |
| :---: | --- |
| 01 | [TPU-MLIR paper](https://arxiv.org/abs/2210.15016) |
| 02 | [TPU-MLIR Technical Reference Manual](https://tpumlir.org/en/docs/developer_manual/index.html) |
| 03 | [TPU-MLIR Quick Start](https://tpumlir.org/en/docs/quick_start/index.html) |

| Index | Sharing Sessions |
| :---: | --- |
| 01 | [TPU-MLIR Paper](https://www.bilibili.com/video/BV1My4y1o73Q/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |
| 02 | [LayerGroup](https://www.bilibili.com/video/BV1wo4y1z7AG/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |

| Index | Topic | Video Links |
| :---: | --- | --- |
| 01 | What is Depp Learning Compiler? | [Depp Learning Compiler Intro](https://www.bilibili.com/video/BV1yP4y1d7gz/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8)|
| 02 | MLIR Intro | [Basic Syntax (1)](https://www.bilibili.com/video/BV1CP411n7fj/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Basic Syntax (2)](https://www.bilibili.com/video/BV1Gt4y1F7mt/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Basic Syntax (3)](https://www.bilibili.com/video/BV1UN4y1w72r/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Dialect Conversion](https://www.bilibili.com/video/BV1UG411c7nm/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Pattern Rewriting](https://www.bilibili.com/video/BV1R44y1d7xv/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8)|
| 03 | TPU-MLIR Intro | [Overview](https://www.bilibili.com/video/BV19d4y1B7eR/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Front-end Conversion](https://www.bilibili.com/video/BV1yv4y1S7WT/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Lowering](https://www.bilibili.com/video/BV1gg411z7mC/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |
| 04 | Quantization | [Overview](https://www.bilibili.com/video/BV1d8411j7t4/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Formula Derivation](https://www.bilibili.com/video/BV1SW4y1H7Uu/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Calibration](https://www.bilibili.com/video/BV1qK411R75k/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [QAT](https://www.bilibili.com/video/BV12g411J7WQ/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8)|
| 05 | TPU Memory | [Ep1](https://www.bilibili.com/video/BV1T24y1G7pu/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Ep2](https://www.bilibili.com/video/BV1VY4y1y7ET/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |
| 06 | TPU-MLIR Practice | [To Onnx Format](https://www.bilibili.com/video/BV1FD4y1H7pT/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Graph Optimization](https://www.bilibili.com/video/BV1AR4y1U7D6/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Operator Support](https://www.bilibili.com/video/BV1tL411r71p/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Model Support](https://www.bilibili.com/video/BV1mM411y7Ep/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Fuse Preprocess](https://www.bilibili.com/video/BV1ao4y1H7m8/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Accuracy Validation](https://www.bilibili.com/video/BV14e4y1M79d/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |

If you have any questions while doing the tasks above, you can ask or check the existing answers in our [Q&A Platform](https://ask.tpumlir.org/questions).

# How to Build

After cloning the code of this project, it needs to be compiled in docker.

* Download the required image from [dockerhub](https://hub.docker.com/r/sophgo/tpuc_dev).

``` shell
docker pull sophgo/tpuc_dev:latest
```

* If the pulling failed, you can download it in the following way:

``` shell
wget https://sophon-file.sophon.cn/sophon-prod-s3/drive/24/06/14/12/sophgo-tpuc_dev-v3.2_191a433358ad.tar.gz

docker load -i sophgo-tpuc_dev-v3.2_191a433358ad.tar.gz
```

* Create the container:

``` shell
# myname1234 is just an example, you can set your own name
docker run --privileged --name myname1234 -v $PWD:/workspace -it sophgo/tpuc_dev:latest
```

After the container is created, the directory of the code in docker should be `/workspace/tpu-mlir`.

* Building

Run the following command in the project directory:

``` shell
cd tpu-mlir
source ./envsetup.sh
./build.sh
```
# Usage

Introduce the usage of `TPU-MLIR` by a simple example of compiling `yolov5s.onnx` and running it on the BM1684X TPU platform.

The model comes from the official website of yolov5: <https://github.com/ultralytics/yolov5/releases/download/v6.0/yolov5s.onnx>.

It has been placed in project path `regression/model/yolov5s.onnx`.

## Preparation

Firstly, create a `model_yolov5s` directory at the same level directory with this project. Then put both model and image files into it.

The operation is as follows:

``` shell
mkdir model_yolov5s && cd model_yolov5s
cp ${REGRESSION_PATH}/model/yolov5s.onnx .
cp -rf ${REGRESSION_PATH}/dataset/COCO2017 .
cp -rf ${REGRESSION_PATH}/image .
mkdir workspace && cd workspace
```
## Model to MLIR

If the model takes images as input, we need to learn its preprocessing before transforming. No preprocessing needs to be considered if the input is npz file. The preprocessing process is formulated as follows:

$$
y = (x - mean) \times scale,
$$

where `x` represents the input.

The input of the official yolov5 is RGB image. Each value will be multiplied by `1/255`. Mean and scale are `0.0, 0.0, 0.0` and `0.0039216, 0.0039216, 0.0039216` respectively.

The model conversion command:

``` shell
model_transform.py \
    --model_name yolov5s \
    --model_def ../yolov5s.onnx \
    --input_shapes [[1,3,640,640]] \
    --mean 0.0,0.0,0.0 \
    --scale 0.0039216,0.0039216,0.0039216 \
    --keep_aspect_ratio \
    --pixel_format rgb \
    --output_names 350,498,646 \
    --test_input ../image/dog.jpg \
    --test_result yolov5s_top_outputs.npz \
    --mlir yolov5s.mlir
```

Main arguments of `model_transform.py` (for complete information please check the technical reference manual):

| **Argument**           | Required? | **Description**            |
| ------------------- |  :-:  | ------------------- |
| model_name          | Yes    | Model name          |
| model_def           | Yes    | Model definition file (`.onnx`,`.pt`,`.tflite` or `.prototxt`) |
| model_data          | No    | Specify the model weight file, required when it is caffe model (corresponding to the '.caffemodel' file) |
| input_shapes        | No    | The shape of the input, such as `[[1,3,640,640]]` (a two-dimensional array), which can support multiple inputs |
| resize_dims         | No    | The size of the original image to be adjusted to. If not specified, it will be resized to the input size of the model |
| keep_aspect_ratio   | No    | Whether to maintain the aspect ratio when resize. False by default. It will pad 0 to the insufficient part when setting |
| mean                | No    | The mean of each channel of the image. The default is 0.0,0.0,0.0                    |
| scale               | No    | The scale of each channel of the image. The default is 1.0,1.0,1.0                    |
| pixel_format        | No    | Image type, can be rgb, bgr, gray or rgbd              |
| output_names        | No    | The names of the output. Use the output of the model if not specified, otherwise use the specified names as the output |
| test_input          | No    | The input file for validation, which can be an image, npy or npz. No validation will be carried out if it is not specified |
| test_result         | No    | Output file to save validation result                                         |
| excepts             | No    | Names of network layers that need to be excluded from validation. Separated by comma                      |
| debug               | No    | if open debug, immediate model file will keep; or will remove after conversion done |
| mlir                | Yes    | The output mlir file name (including path)                                       |


After converting to mlir file, a `${model_name}_in_f32.npz` file containing preprocessed input will be generated.


## MLIR to F16 bmodel

Convert the mlir file to the F16 bmodel by the following command:

``` shell
model_deploy.py \
  --mlir yolov5s.mlir \
  --quantize F16 \
  --processor bm1684x \
  --test_input yolov5s_in_f32.npz \
  --test_reference yolov5s_top_outputs.npz \
  --model yolov5s_1684x_f16.bmodel
```

Main arguments of `model_deploy.py` (for complete information please check the technical reference manual):

| **Argument**           | Required? | **Description**                       |
| ------------------- | :-: | ----------------------------- |
| mlir                | Yes    | Mlir file                                             |
| quantize            | Yes    | Quantization type (F32/BF16/F16/INT8)                     |
| processor           | Yes    | The platform that the model will use.      |
| calibration_table   | No    | The quantization table path. Required when it is INT8 quantization                 |
| tolerance           | No    | Tolerance for the minimum similarity between MLIR quantized and MLIR fp32 inference results |
| correctnetss        | No    | Tolerance for the minimum similarity between simulator and MLIR quantized inference results. 0.99,0.90 by default |
| excepts             | No    | Names of network layers that need to be excluded from validation. Separated by comma |
| debug               | No    | if open debug, immediate model file will keep; or will remove after conversion done |
| model               | Yes    | Name of output model file (including path)                                  |
| dynamic             | No     | dynamic codegen for to support dynamic shape                                |

## MLIR to INT8 bmodel

Before converting to the INT8 model, you need to run calibration to get the calibration table. The number of input data is about 100 to 1000 according to the situation.

Then use the calibration table to generate a symmetric int8 bmodel. It is generally not recommended to use the asymmetric one if the symmetric one already meets the requirements, because
the performance of the asymmetric model will be slightly worse than the symmetric model.

Here is an example of the existing 100 images from COCO2017 to perform calibration:

``` shell
run_calibration.py yolov5s.mlir \
  --dataset ../COCO2017 \
  --input_num 100 \
  -o yolov5s_cali_table
```


Execute the following command to convert to the INT8 symmetric quantized model:

``` shell
model_deploy.py \
  --mlir yolov5s.mlir \
  --quantize INT8 \
  --calibration_table yolov5s_cali_table \
  --processor bm1684x \
  --test_input yolov5s_in_f32.npz \
  --test_reference yolov5s_top_outputs.npz \
  --tolerance 0.85,0.45 \
  --model yolov5s_1684x_int8.bmodel
```

## Results Comparison

This project has a yolov5 sample written in python (path:  `python/samples/detect_yolov5.py`) for object detection. Read the code to learn how the model is used:
  1. preprocess the input
  2. model inference to get output
  3. post-process the output

The following code is used to verify the output of onnx/f32/int8 model respectively:

* ONNX model:

``` shell
detect_yolov5.py \
  --input ../image/dog.jpg \
  --model ../yolov5s.onnx \
  --output dog_origin.jpg
```


* F16 bmodel:

``` shell
detect_yolov5.py \
  --input ../image/dog.jpg \
  --model yolov5s_1684x_f16.bmodel \
  --output dog_f16.jpg
```

* INT8 **symmetric quantized** bmodel:

``` shell
detect_yolov5.py \
  --input ../image/dog.jpg \
  --model yolov5s_1684x_int8.bmodel \
  --output dog_int8.jpg
```


Outputs of different models are compared below:

![](./docs/quick_start/assets/yolov5s.png)



# Auxiliary Tools

## Model Inference Tool `model_runner.py`

Supports bmodel/mlir/pytorch/onnx/tflite/caffe.

``` shell
model_runner.py \
  --input resnet18_in_f32.npz \
  --model resnet18_1684x_f32.bmodel \
  --output resnet18_output.npz
```

## Tool for `bmodel`

The `bmodel` file can be viewed and edited by `model_tool`:

```
  model_tool
    --info model_file : show brief model info
    --print model_file : show detailed model info
    --extract model_file : extract one multi-net bmodel to multi one-net bmodels
    --combine file1 .. fileN -o new_file: combine bmodels to one bmodel by filepath
    --combine_dir dir1 .. dirN -o new_dir: combine bmodels to one bmodel by directory path
    --dump model_file start_offset byte_size out_file: dump binary data to file from bmodel
```

For example, to get basic information of `bmodel`:

``` shell
model_tool --info resnet18_1684x_f32.bmodel
```



# Related Links

* [Official Network](https://tpumlir.org)
* [Discourse](https://ask.tpumlir.org)
* [Videos](https://space.bilibili.com/1829795304/channel/collectiondetail?sid=734875)

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/sophgo/tpu-mlir",
    "name": "tpu-mlir",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<3.11,>=3.10",
    "maintainer_email": null,
    "keywords": "python3.10, unbuntu22.04, linux, tpu-mlir",
    "author": "SOPHGO",
    "author_email": "sales@sophgo.com",
    "download_url": null,
    "platform": "unbuntu22.04",
    "description": "![](./docs/assets/sophgo_cover.png)\n\n# TPU-MLIR\n\nFor Chinese version: [README](https://github.com/sophgo/tpu-mlir/blob/master/README_cn.md).\n\nTPU-MLIR is an open-source machine-learning compiler based on MLIR for TPU. This project provides a complete toolchain, which can convert pre-trained neural networks from different frameworks into binary files `bmodel` that can be efficiently operated on TPUs.\n\nSOPHGO aims to become a leading global provider of general-purpose computing power. SOPHGO focuses on the research, development, and promotion of computing products such as Deep Learning and RISC-V processors, and has built a comprehensive application matrix covering the 'cloud, edge, and endpoint' scenarios with its self-developed products. SOPHGO provides computing products and integrated solutions for applications such as smart cities, intelligent computing centers, smart security, intelligent transportation, safety production, industrial quality inspection, and intelligent terminals. The company has research and development centers in more than 10 cities in China including Beijing, Shanghai, Shenzhen, Qingdao, and Xiamen, as well as in the United States and Singapore.\n\nCurrently, supported Deep Learning frameworks are PyTorch, ONNX, TFLite and Caffe. Models from other frameworks need to be converted to ONNX models.\n\n\n# Prebuilt TPU-MLIR Python Package\n\nWe provide TPU-MLIR python package for quick installation by skipping the building step.\nEnvironment prerequisite: python >= 3.10 and ubuntu:22.04 (It is recommended to use our docker image directly).\n\nTo install:\n\n``` shell\npip install tpu_mlir\n```\n\n# Resources\n\nHere are some resources to help you better understand the project:\n\n| Index | Documents |\n| :---: | --- |\n| 01 | [TPU-MLIR paper](https://arxiv.org/abs/2210.15016) |\n| 02 | [TPU-MLIR Technical Reference Manual](https://tpumlir.org/en/docs/developer_manual/index.html) |\n| 03 | [TPU-MLIR Quick Start](https://tpumlir.org/en/docs/quick_start/index.html) |\n\n| Index | Sharing Sessions |\n| :---: | --- |\n| 01 | [TPU-MLIR Paper](https://www.bilibili.com/video/BV1My4y1o73Q/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |\n| 02 | [LayerGroup](https://www.bilibili.com/video/BV1wo4y1z7AG/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |\n\n| Index | Topic | Video Links |\n| :---: | --- | --- |\n| 01 | What is Depp Learning Compiler? | [Depp Learning Compiler Intro](https://www.bilibili.com/video/BV1yP4y1d7gz/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8)|\n| 02 | MLIR Intro | [Basic Syntax (1)](https://www.bilibili.com/video/BV1CP411n7fj/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Basic Syntax (2)](https://www.bilibili.com/video/BV1Gt4y1F7mt/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Basic Syntax (3)](https://www.bilibili.com/video/BV1UN4y1w72r/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Dialect Conversion](https://www.bilibili.com/video/BV1UG411c7nm/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Pattern Rewriting](https://www.bilibili.com/video/BV1R44y1d7xv/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8)|\n| 03 | TPU-MLIR Intro | [Overview](https://www.bilibili.com/video/BV19d4y1B7eR/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Front-end Conversion](https://www.bilibili.com/video/BV1yv4y1S7WT/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Lowering](https://www.bilibili.com/video/BV1gg411z7mC/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |\n| 04 | Quantization | [Overview](https://www.bilibili.com/video/BV1d8411j7t4/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Formula Derivation](https://www.bilibili.com/video/BV1SW4y1H7Uu/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Calibration](https://www.bilibili.com/video/BV1qK411R75k/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [QAT](https://www.bilibili.com/video/BV12g411J7WQ/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8)|\n| 05 | TPU Memory | [Ep1](https://www.bilibili.com/video/BV1T24y1G7pu/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Ep2](https://www.bilibili.com/video/BV1VY4y1y7ET/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |\n| 06 | TPU-MLIR Practice | [To Onnx Format](https://www.bilibili.com/video/BV1FD4y1H7pT/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Graph Optimization](https://www.bilibili.com/video/BV1AR4y1U7D6/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Operator Support](https://www.bilibili.com/video/BV1tL411r71p/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Model Support](https://www.bilibili.com/video/BV1mM411y7Ep/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Fuse Preprocess](https://www.bilibili.com/video/BV1ao4y1H7m8/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8), [Accuracy Validation](https://www.bilibili.com/video/BV14e4y1M79d/?share_source=copy_web&vd_source=90fd7c624ed0c40af96748bd0b8dd3e8) |\n\nIf you have any questions while doing the tasks above, you can ask or check the existing answers in our [Q&A Platform](https://ask.tpumlir.org/questions).\n\n# How to Build\n\nAfter cloning the code of this project, it needs to be compiled in docker.\n\n* Download the required image from [dockerhub](https://hub.docker.com/r/sophgo/tpuc_dev).\n\n``` shell\ndocker pull sophgo/tpuc_dev:latest\n```\n\n* If the pulling failed, you can download it in the following way:\n\n``` shell\nwget https://sophon-file.sophon.cn/sophon-prod-s3/drive/24/06/14/12/sophgo-tpuc_dev-v3.2_191a433358ad.tar.gz\n\ndocker load -i sophgo-tpuc_dev-v3.2_191a433358ad.tar.gz\n```\n\n* Create the container:\n\n``` shell\n# myname1234 is just an example, you can set your own name\ndocker run --privileged --name myname1234 -v $PWD:/workspace -it sophgo/tpuc_dev:latest\n```\n\nAfter the container is created, the directory of the code in docker should be `/workspace/tpu-mlir`.\n\n* Building\n\nRun the following command in the project directory:\n\n``` shell\ncd tpu-mlir\nsource ./envsetup.sh\n./build.sh\n```\n# Usage\n\nIntroduce the usage of `TPU-MLIR` by a simple example of compiling `yolov5s.onnx` and running it on the BM1684X TPU platform.\n\nThe model comes from the official website of yolov5: <https://github.com/ultralytics/yolov5/releases/download/v6.0/yolov5s.onnx>.\n\nIt has been placed in project path `regression/model/yolov5s.onnx`.\n\n## Preparation\n\nFirstly, create a `model_yolov5s` directory at the same level directory with this project. Then put both model and image files into it.\n\nThe operation is as follows:\n\n``` shell\nmkdir model_yolov5s && cd model_yolov5s\ncp ${REGRESSION_PATH}/model/yolov5s.onnx .\ncp -rf ${REGRESSION_PATH}/dataset/COCO2017 .\ncp -rf ${REGRESSION_PATH}/image .\nmkdir workspace && cd workspace\n```\n## Model to MLIR\n\nIf the model takes images as input, we need to learn its preprocessing before transforming. No preprocessing needs to be considered if the input is npz file. The preprocessing process is formulated as follows:\n\n$$\ny = \uff08x - mean\uff09 \\times scale,\n$$\n\nwhere `x` represents the input.\n\nThe input of the official yolov5 is RGB image. Each value will be multiplied by `1/255`. Mean and scale are `0.0, 0.0, 0.0` and `0.0039216, 0.0039216, 0.0039216` respectively.\n\nThe model conversion command:\n\n``` shell\nmodel_transform.py \\\n    --model_name yolov5s \\\n    --model_def ../yolov5s.onnx \\\n    --input_shapes [[1,3,640,640]] \\\n    --mean 0.0,0.0,0.0 \\\n    --scale 0.0039216,0.0039216,0.0039216 \\\n    --keep_aspect_ratio \\\n    --pixel_format rgb \\\n    --output_names 350,498,646 \\\n    --test_input ../image/dog.jpg \\\n    --test_result yolov5s_top_outputs.npz \\\n    --mlir yolov5s.mlir\n```\n\nMain arguments of `model_transform.py` (for complete information please check the technical reference manual):\n\n| **Argument**           | Required\uff1f | **Description**            |\n| ------------------- |  :-:  | ------------------- |\n| model_name          | Yes    | Model name          |\n| model_def           | Yes    | Model definition file (`.onnx`,`.pt`,`.tflite` or `.prototxt`) |\n| model_data          | No    | Specify the model weight file, required when it is caffe model (corresponding to the '.caffemodel' file) |\n| input_shapes        | No    | The shape of the input, such as `[[1,3,640,640]]` (a two-dimensional array), which can support multiple inputs |\n| resize_dims         | No    | The size of the original image to be adjusted to. If not specified, it will be resized to the input size of the model |\n| keep_aspect_ratio   | No    | Whether to maintain the aspect ratio when resize. False by default. It will pad 0 to the insufficient part when setting |\n| mean                | No    | The mean of each channel of the image. The default is 0.0,0.0,0.0                    |\n| scale               | No    | The scale of each channel of the image. The default is 1.0,1.0,1.0                    |\n| pixel_format        | No    | Image type, can be rgb, bgr, gray or rgbd              |\n| output_names        | No    | The names of the output. Use the output of the model if not specified, otherwise use the specified names as the output |\n| test_input          | No    | The input file for validation, which can be an image, npy or npz. No validation will be carried out if it is not specified |\n| test_result         | No    | Output file to save validation result                                         |\n| excepts             | No    | Names of network layers that need to be excluded from validation. Separated by comma                      |\n| debug               | No    | if open debug, immediate model file will keep; or will remove after conversion done |\n| mlir                | Yes    | The output mlir file name (including path)                                       |\n\n\nAfter converting to mlir file, a `${model_name}_in_f32.npz` file containing preprocessed input will be generated.\n\n\n## MLIR to F16 bmodel\n\nConvert the mlir file to the F16 bmodel by the following command:\n\n``` shell\nmodel_deploy.py \\\n  --mlir yolov5s.mlir \\\n  --quantize F16 \\\n  --processor bm1684x \\\n  --test_input yolov5s_in_f32.npz \\\n  --test_reference yolov5s_top_outputs.npz \\\n  --model yolov5s_1684x_f16.bmodel\n```\n\nMain arguments of `model_deploy.py` (for complete information please check the technical reference manual):\n\n| **Argument**           | Required\uff1f | **Description**                       |\n| ------------------- | :-: | ----------------------------- |\n| mlir                | Yes    | Mlir file                                             |\n| quantize            | Yes    | Quantization type (F32/BF16/F16/INT8)                     |\n| processor           | Yes    | The platform that the model will use.      |\n| calibration_table   | No    | The quantization table path. Required when it is INT8 quantization                 |\n| tolerance           | No    | Tolerance for the minimum similarity between MLIR quantized and MLIR fp32 inference results |\n| correctnetss        | No    | Tolerance for the minimum similarity between simulator and MLIR quantized inference results. 0.99,0.90 by default |\n| excepts             | No    | Names of network layers that need to be excluded from validation. Separated by comma |\n| debug               | No    | if open debug, immediate model file will keep; or will remove after conversion done |\n| model               | Yes    | Name of output model file (including path)                                  |\n| dynamic             | No     | dynamic codegen for to support dynamic shape                                |\n\n## MLIR to INT8 bmodel\n\nBefore converting to the INT8 model, you need to run calibration to get the calibration table. The number of input data is about 100 to 1000 according to the situation.\n\nThen use the calibration table to generate a symmetric int8 bmodel. It is generally not recommended to use the asymmetric one if the symmetric one already meets the requirements, because\nthe performance of the asymmetric model will be slightly worse than the symmetric model.\n\nHere is an example of the existing 100 images from COCO2017 to perform calibration:\n\n``` shell\nrun_calibration.py yolov5s.mlir \\\n  --dataset ../COCO2017 \\\n  --input_num 100 \\\n  -o yolov5s_cali_table\n```\n\n\nExecute the following command to convert to the INT8 symmetric quantized model:\n\n``` shell\nmodel_deploy.py \\\n  --mlir yolov5s.mlir \\\n  --quantize INT8 \\\n  --calibration_table yolov5s_cali_table \\\n  --processor bm1684x \\\n  --test_input yolov5s_in_f32.npz \\\n  --test_reference yolov5s_top_outputs.npz \\\n  --tolerance 0.85,0.45 \\\n  --model yolov5s_1684x_int8.bmodel\n```\n\n## Results Comparison\n\nThis project has a yolov5 sample written in python (path:  `python/samples/detect_yolov5.py`) for object detection. Read the code to learn how the model is used:\n  1. preprocess the input\n  2. model inference to get output\n  3. post-process the output\n\nThe following code is used to verify the output of onnx/f32/int8 model respectively:\n\n* ONNX model:\n\n``` shell\ndetect_yolov5.py \\\n  --input ../image/dog.jpg \\\n  --model ../yolov5s.onnx \\\n  --output dog_origin.jpg\n```\n\n\n* F16 bmodel:\n\n``` shell\ndetect_yolov5.py \\\n  --input ../image/dog.jpg \\\n  --model yolov5s_1684x_f16.bmodel \\\n  --output dog_f16.jpg\n```\n\n* INT8 **symmetric quantized** bmodel:\n\n``` shell\ndetect_yolov5.py \\\n  --input ../image/dog.jpg \\\n  --model yolov5s_1684x_int8.bmodel \\\n  --output dog_int8.jpg\n```\n\n\nOutputs of different models are compared below:\n\n![](./docs/quick_start/assets/yolov5s.png)\n\n\n\n# Auxiliary Tools\n\n## Model Inference Tool `model_runner.py`\n\nSupports bmodel/mlir/pytorch/onnx/tflite/caffe.\n\n``` shell\nmodel_runner.py \\\n  --input resnet18_in_f32.npz \\\n  --model resnet18_1684x_f32.bmodel \\\n  --output resnet18_output.npz\n```\n\n## Tool for `bmodel`\n\nThe `bmodel` file can be viewed and edited by `model_tool`:\n\n```\n  model_tool\n    --info model_file : show brief model info\n    --print model_file : show detailed model info\n    --extract model_file : extract one multi-net bmodel to multi one-net bmodels\n    --combine file1 .. fileN -o new_file: combine bmodels to one bmodel by filepath\n    --combine_dir dir1 .. dirN -o new_dir: combine bmodels to one bmodel by directory path\n    --dump model_file start_offset byte_size out_file: dump binary data to file from bmodel\n```\n\nFor example, to get basic information of `bmodel`:\n\n``` shell\nmodel_tool --info resnet18_1684x_f32.bmodel\n```\n\n\n\n# Related Links\n\n* [Official Network](https://tpumlir.org)\n* [Discourse](https://ask.tpumlir.org)\n* [Videos](https://space.bilibili.com/1829795304/channel/collectiondetail?sid=734875)\n",
    "bugtrack_url": null,
    "license": "2-Clause BSD",
    "summary": "Machine learning compiler based on MLIR for Sophgo TPU v1.14-g9f8d4d4-20241231",
    "version": "1.14",
    "project_urls": {
        "Homepage": "https://github.com/sophgo/tpu-mlir"
    },
    "split_keywords": [
        "python3.10",
        " unbuntu22.04",
        " linux",
        " tpu-mlir"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "a1f1cda3e3aa15d90aeca6b609990da00da5e60e99534da46b9e0577eb64d92e",
                "md5": "866d7b8b4c267a0f3ca76f9ec336727e",
                "sha256": "633e51dc8e69191babcb0652327ec2997c53f7199ef8d49231cb9b74a244f789"
            },
            "downloads": -1,
            "filename": "tpu_mlir-1.14-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "866d7b8b4c267a0f3ca76f9ec336727e",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<3.11,>=3.10",
            "size": 206968822,
            "upload_time": "2024-12-31T09:17:02",
            "upload_time_iso_8601": "2024-12-31T09:17:02.030602Z",
            "url": "https://files.pythonhosted.org/packages/a1/f1/cda3e3aa15d90aeca6b609990da00da5e60e99534da46b9e0577eb64d92e/tpu_mlir-1.14-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-31 09:17:02",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "sophgo",
    "github_project": "tpu-mlir",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "tpu-mlir"
}
        
Elapsed time: 0.93127s