You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
mindspore/mindspore/lite
mindspore-ci-bot d56ac6d378
!8074 fix static checking of lite ops
5 years ago
..
include function to print errorcode info and avoid misoperation after free model 5 years ago
internal fix static checking of lite ops 5 years ago
java/java fix java bugs 5 years ago
minddata fix lite_cv include path bug 5 years ago
nnacl fix static checking of lite ops 5 years ago
schema !7775 [MS][LITE]Fix softmax parser, fix mul bug, fix lrn bug 5 years ago
src !8010 fix int8transpose parser 5 years ago
test !8010 fix int8transpose parser 5 years ago
tools !8057 modify files for static check 5 years ago
CMakeLists.txt fix dataset lite build with convert tool 5 years ago
README.md update links for README 5 years ago
README_CN.md update links of README 5 years ago

README.md

查看中文

What Is MindSpore Lite

MindSpore lite is a high-performance, lightweight open source reasoning framework that can be used to meet the needs of AI applications on mobile devices. MindSpore Lite focuses on how to deploy AI technology more effectively on devices. It has been integrated into HMS (Huawei Mobile Services) to provide inferences for applications such as image classification, object detection and OCR. MindSpore Lite will promote the development and enrichment of the AI software/hardware application ecosystem.

MindSpore Lite Architecture

For more details please check out our MindSpore Lite Architecture Guide.

MindSpore Lite features

  1. Cooperative work with MindSpore training

    • Provides training, optimization, and deployment.
    • The unified IR realizes the device-cloud AI application integration.
  2. Lightweight

    • Provides model compress, which could help to improve performance as well.
    • Provides the ultra-lightweight reasoning solution MindSpore Micro to meet the deployment requirements in extreme environments such as smart watches and headphones.
  3. High-performance

    • The built-in high-performance kernel computing library NNACL supports multiple convolution optimization algorithms such as Slide window, im2col+gemm, winograde, etc.
    • Assembly code to improve performance of kernel operators. Supports CPU, GPU, and NPU.
  4. Versatility

    • Supports IOS, Android.
    • Supports Lite OS.
    • Supports mobile device, smart screen, pad, and IOT devices.
    • Supports third party models such as TFLite, CAFFE and ONNX.

MindSpore Lite AI deployment procedure

  1. Model selection and personalized training

    Select a new model or use an existing model for incremental training using labeled data. When designing a model for mobile device, it is necessary to consider the model size, accuracy and calculation amount.

    The MindSpore team provides a series of pre-training models used for image classification, object detection. You can use these pre-trained models in your application.

    The pre-trained model provided by MindSpore: Image Classification. More models will be provided in the feature.

    MindSpore allows you to retrain pre-trained models to perform other tasks.

  2. Model converter and optimization

    If you use MindSpore or a third-party model, you need to use MindSpore Lite Model Converter Tool to convert the model into MindSpore Lite model. The MindSpore Lite model converter tool provides the converter of TensorFlow Lite, Caffe, ONNX to MindSpore Lite model, fusion and quantization could be introduced during convert procedure.

    MindSpore also provides a tool to convert models running on IoT devices .

  3. Model deployment

    This stage mainly realizes model deployment, including model management, deployment, operation and maintenance monitoring, etc.

  4. Inference

    Load the model and perform inference. Inference is the process of running input data through the model to get output.

    MindSpore provides pre-trained model that can be deployed on mobile device example.

MindSpore Lite benchmark test result

Base on MindSpore r0.7, we test a couple of networks on HUAWEI Mate30 (Hisilicon Kirin990) mobile phone, and get the test results below for your reference.

NetWork Thread Number Average Run Time(ms)
basic_squeezenet 4 9.10
inception_v3 4 69.361
mobilenet_v1_10_224 4 7.137
mobilenet_v2_10_224 4 5.569
resnet_v2_50 4 48.691