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 7831c337c2
!9565 remove unique optype attr
4 years ago
..
examples added some descriptions of the parameters in ./transfer_learning/README_CN.md and ./train_lenet/README_CN.md 4 years ago
include add npu 4 years ago
java/java fix the minddata lite build, keep the third package compiled in the same way 4 years ago
minddata add code 4 years ago
nnacl !10042 [ms][lite][cpu]x86 算子sse优化 4 years ago
schema remove unique outtype attr 4 years ago
src !9565 remove unique optype attr 4 years ago
test !9565 remove unique optype attr 4 years ago
tools remove unique outtype attr 4 years ago
CMakeLists.txt rename pkg simple 4 years ago
README.md update model inference time data 4 years ago
README_CN.md update model inference time data 4 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 r1.1, 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 7.569
inception_v3 4 44.869
mobilenet_v1_10_224 4 6.320
mobilenet_v2_10_224 4 4.679
resnet_v2_50 4 30.375