Hi3861使用NNOM实现人工智能神经网络之MNIST

系统 OpenHarmony
每当我们学习一门新的语言时,所有的入门教程官方都会提供一个典型的例子——“Hello World”。而在机器学习中,入门的例子称之为MNIST。

​想了解更多关于开源的内容,请访问:​

​51CTO 开源基础软件社区​

​https://ost.51cto.com​

1、什么是NNOM

请查看之前的帖子:https://ost.51cto.com/posts/12287

2、什么是MNIST

每当我们学习一门新的语言时,所有的入门教程官方都会提供一个典型的例子——“Hello World”。而在机器学习中,入门的例子称之为MNIST。

MNIST是一个简单的视觉计算数据集,它是像下面这样手写的数字图片:

MNIST 经常被用来做为分类任务的入门数据库使用。在这个简单的例子里面,我们也用它来试试数据归类。

3、移植和编译

移植NNOM库的方法,在之前已经有说明。

$(wildcard $(LIBPATH)/nnom/src/backends/*.c) \
$(wildcard $(LIBPATH)/nnom/src/core/*.c) \
$(wildcard $(LIBPATH)/nnom/src/layers/*.c) \
  • 1.
  • 2.
  • 3.

同时移植了mnist-simple下面的两个.h文件。

#include "lib/nnom/examples/mnist-simple/image.h"
#include "lib/nnom/examples/mnist-simple/weights.h"
  • 1.
  • 2.

核心的几个函数。

const char codeLib[] = "@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\\|()1{}[]?-_+~<>i!lI;:,\"^`'.   ";
void print_img(int8_t * buf)
{
    for(int y = 0; y < 28; y++) 
    {
        for (int x = 0; x < 28; x++) 
        {
            int index =  69 / 127.0 * (127 - buf[y*28+x]); 
            if(index > 69) index =69;
            if(index < 0) index = 0;
            DEBUG_printf("%c",codeLib[index]);
            DEBUG_printf("%c",codeLib[index]);
        }
        DEBUG_printf("\n");
    }
}
// Do simple test using image in "image.h" with model created previously. 
void mnist(int index)
{
    uint32_t tick, time;
    uint32_t predic_label;
    float prob;
    DEBUG_printf("\nprediction start.. \n");
    tick = hi_get_milli_seconds();
    // copy data and do prediction
    memcpy(nnom_input_data, (int8_t*)&img[index][0], 784);
    nnom_predict(model, &predic_label, &prob);
    time = hi_get_milli_seconds() - tick;
    //print original image to console
    print_img((int8_t*)&img[index][0]);
    DEBUG_printf("Time: %d tick\n", time);
    DEBUG_printf("Truth label: %d\n", label[index]);
    DEBUG_printf("Predicted label: %d\n", predic_label);
    DEBUG_printf("Probability: %d%%\n", (int)(prob*100));
}
void nn_stat()
{
    model_stat(model);
    printf("Total Memory cost (Network and NNoM): %d\n", nnom_mem_stat());
}

  • 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.

4、MNIST使用

我是在Micropython下使用的,其实主要的几个函数,如下,可以自行移植测试。

STATIC mp_obj_t machine_ai_nnom_test(mp_obj_t self_in,mp_obj_t data_in) {
    int num = mp_obj_get_int(data_in);    
    // create and compile the model 
    model = nnom_model_create();
    // dummy run
    model_run(model);
    mnist(num);
    nn_stat();
    return mp_const_none;
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.

不同的num值,代表候选的要识别的数字的字节图。比如8,存储的字节符合是这样的。

因为不方便输入手写数字,只能通过这种字符的形式进行测试。

5、总结

这是比较简单的例子,对系统的要求的比较低,识别的时间也很短。同时,也可以自己训练模型,进行分析。但该部分不是本文的重点,敢兴趣的同学,可以自行去github上,进行深入的学习。下一篇,会针对KWS的功能测试,实现实时音频输入关键词识别的demo的移植和演示。

​想了解更多关于开源的内容,请访问:​

​51CTO 开源基础软件社区​

​https://ost.51cto.com​​。

责任编辑:jianghua 来源: 鸿蒙社区
相关推荐

2020-12-21 08:00:00

人工智能深度学习神经网络

2017-04-06 18:34:16

人工智能

2022-03-15 15:00:59

Hi3861Pin接口鸿蒙

2022-03-02 14:53:34

人工智能神经网络

2023-05-09 14:24:32

大数据人工智能

2022-11-30 07:12:06

2021-09-24 12:00:40

人工智能AI神经网络

2020-10-16 09:50:37

Hi3861WiFi热点

2023-05-26 16:07:14

Hi3861Wifi模块

2015-05-11 10:58:04

神经网络人工智能忆阻器

2023-11-15 16:12:41

人工智能机器学习深度学习

2020-10-12 09:36:04

鸿蒙

2018-07-03 16:10:04

神经网络生物神经网络人工神经网络

2022-03-07 15:05:58

HTTPHi3861数据解析

2020-10-14 09:41:02

Hi3861GPIO点灯

2021-02-02 15:52:17

鸿蒙HarmonyOS应用开发

2017-03-16 14:34:25

人工智能神经网络

2018-04-25 09:07:41

人工智能神经网络

2018-02-06 15:40:50

2020-11-06 10:15:16

HiBurn
点赞
收藏

51CTO技术栈公众号