在ncnn上把玩mobileNet_ncnn mobilenet-程序员宅基地

技术标签: 机器学习  ncnn  mobilenet  

ncnn是腾讯优图最近开源的适合移动端的深度学习框架。mobileNet是谷歌在2017年4月份发表的论文MobileNets: Efficient Convolutional Neural Networks for Mobile Vision Applications中提出的网络。由于引入了depthwise convolution,mobileNet的模型非常小,1000类的分类模型只有16.9M,很适合在移动端部署。本文尝试在Mac上用ncnn来运行mobileNet。

1. 下载并编译ncnn

git clone https://github.com/Tencent/ncnn
cd ncnn
mkdir build && cd build
cmake ..
make -j
make install

编译完成后在ncnn/build/tools 目录下,可以看到已经生成了 caffe2ncnn和ncnn2mem这两个可执行文件。caffe2ncnn可的作用是将caffe模型生成ncnn 模型,ncnn2mem可对模型进行加密。

2. 下载MobileNet的caffe模型和配置文件

可从https://github.com/shicai/MobileNet-Caffe中下载,下载后得到mobilenet_deploy.prototxt和mobilenet.caffemodel两个文件。

3. 旧版caffe模型转新版caffe模型

因为ncnn只支持转换新版的caffe模型,所以需要先把第二步下载的caffe模型转换为新版的caffe模型。新版caffe框架中自带了转换的工具,使用姿势如下。

$ ~/caffe/build/tools/upgrade_net_proto_text mobilenet_deploy.prototxt mobilenet_deploy_new.prototxt
$ ~/caffe/build/tools/upgrade_net_proto_binary mobilenet.caffemodel mobilenet_new.caffemodel

4. 新版caffe模型转ncnn模型

在第一步生成的ncnn/build/tools目录下用caffe2ncnn来转换新版的mobileNet模型。

$./caffe2ncnn mobilenet_deploy_new.prototxt mobilenet_new.caffemodel mobilenet.param mobilenet.bin

注意生成的ncnn格式的模型中,.param可以理解为网络的配置文件,.bin可以理解为网络的参数(各种权重)文件。
若需要对模型进行加密,可用如下命令

 $./ncnn2mem mobilenet.param mobilenet.bin mobilenet.id.h mobilenet.mem.h

最后可生成 mobilenet.param.bin 这样的二进制加密文件。ncnn对加密和非加密两种文件的读取方式不一样。

//load非加密的ncnn模型
ncnn::Net net;
net.load_param("mobilenet.param");
net.load_model("mobilenet.bin");
//load加密的ncnn模型
ncnn::Net net;
net.load_param_bin("mobilenet.param.bin");
net.load_model("mobilenet.bin");

5. 开工:使用Xcode编写代码运行

使用Xcode新建一个工程,并把第一步中编译完成的ncnn库导入工程中。编译完成的ncnn lib在ncnn/build/install目录下。
配置好ncnn库后,可以借鉴example下面的squeezenet.cpp代码进行mobileNet模型的部署。修改后的代码如下

static int detect_mobileNet(const cv::Mat& bgr, std::vector<float>& cls_scores)
{
    ncnn::Net mobileNet;
    mobileNet.load_param("/Users/Guigu/Documents/projects/ncnn_mobileNet/mobilenet.param");
    mobileNet.load_model("/Users/Guigu/Documents/projects/ncnn_mobileNet/mobilenet.bin");

    ncnn::Mat in = ncnn::Mat::from_pixels_resize(bgr.data, ncnn::Mat::PIXEL_BGR, bgr.cols, bgr.rows, 224, 224);

    const float mean_vals[3] = {
   103.94f, 116.78f, 123.68f};
    const float norm_vals[3] = {
   0.017f,0.017f,0.017f};
    in.substract_mean_normalize(mean_vals, norm_vals);


    ncnn::Extractor ex = mobileNet.create_extractor();
    ex.set_light_mode(true);

    ex.input("data", in);

    ncnn::Mat out;
    ex.extract("fc7", out);  //此处与squeezenet不同

    cls_scores.resize(out.c);
    for (int j=0; j<out.c; j++)
    {
        const float* prob = out.data + out.cstep * j;
        cls_scores[j] = prob[0];
    }

    return 0;
}

在main函数中调用该接口就OK了。

下面这张图是我测试的图
这里写图片描述

mobileNet识别的结果如下:

detection time: 852ms
917 = 13.889417 ( comic book)
643 = 13.157956 ( mask)
921 = 7.961194 ( book jacket, dust cover, dust jacket, dust wrapper)
Program ended with exit code: 0

细心的人可能观察到耗时比较长,原因是用Mac自带的编译器编ncnn的时候不能把openmp编进去。另外,Mac上也不能通过arm neon来加速(毕竟平台不一样嘛)。

完整的工程地址:https://github.com/Revo-Future/ncnn_mobileNet

Bonus

如果想编译源代码,可以把ncnn中src目录下的文件加上build/src下的platform.h layer_registry.h 和layer_declaration.h放到一起替换上面的ncnn lib进行源码的编译研究。

Reference:
http://blog.csdn.net/best_coder/article/details/76201275

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/computerme/article/details/77876633

智能推荐

jQuery获取和设置checkbox的checked属性小结_jquery 获取check-程序员宅基地

文章浏览阅读2.7w次,点赞8次,收藏16次。今天写静态页面,需要拿jquery去控制checkbox的check属性,开始用的attr,每次设置完成后,点开f12观察elements,后面每次,无论怎么点击checkbox,它的checked属性都是选中的,于是上网查找,得以解决,下面是是转载的内容在jquery里,有两种操作元素属性的方法,一种是attr(),另一种是prop()。attr()的属性在页面首次加载时就确定。当页面初_jquery 获取check

Qt多国语言的实现与切换(国际化)_qt怎么实现多语言切换-程序员宅基地

文章浏览阅读7.2k次,点赞3次,收藏8次。1、创建语言文件  打开.pro文件,加入以下:TRANSLATIONS+=cn.ts  工具->外部->Qt语言家->更新翻译,将生成翻译文件cn.ts2、编辑翻译文件  启动Linguist(Qt语言家),打开cn.ts,然后进行编辑,主要是将源文对应的译文填写上,最后保存3、部署翻译文件  工具->外部->Qt语言家->部署翻译,将生成_qt怎么实现多语言切换

Django的INSTALLED_APPS中应该写app名,还是AppConfig子类?-程序员宅基地

文章浏览阅读7.3k次,点赞17次,收藏22次。当你使用python manage.py startapp app01的命令创建了一个名为app01的新应用后,通常接下来要做的就是在settings.py里注册它,把它加到INSTAL..._installed_apps

Java简介,2024年最新java面试数据库试题及答案-程序员宅基地

文章浏览阅读905次,点赞20次,收藏7次。面试难免让人焦虑不安。经历过的人都懂的。但是如果你提前预测面试官要问你的问题并想出得体的回答方式,就会容易很多。此外,都说“面试造火箭,工作拧螺丝”,那对于准备面试的朋友,你只需懂一个字:刷!给我刷刷刷刷,使劲儿刷刷刷刷刷!今天既是来谈面试的,那就必须得来整点面试真题,这不花了我整28天,做了份“Java一线大厂高岗面试题解析合集:JAVA基础-中级-高级面试+SSM框架+分布式+性能调优+微服务+并发编程+网络+设计模式+数据结构与算法等”

Muduo网络库源码分析(四)EventLoopThread和EventLoopThreadPool的封装_为什么在io线程调用quit-程序员宅基地

文章浏览阅读393次。muduo的并发模型为one loop per thread+ threadpool。为了方便使用,muduo封装了EventLoop和Thread为EventLoopThread,为了方便使用线程池,又把EventLoopThread封装为EventLoopThreadPool。所以这篇博文并没有涉及到新鲜的技术,但是也有一些封装和逻辑方面的注意点需要我们去分析和理解。EventLoop_为什么在io线程调用quit

gem5 -gcn3 编译与使用_gem5 gcn3-程序员宅基地

文章浏览阅读449次。1.编译安装dependencies:sudo apt install build-essential git m4 scons zlib1g zlib1g-dev libprotobuf-dev protobuf-compiler libprotoc-dev libgoogle-perftools-dev python-dev python编译源代码:scons build/X86/gem5.opt -j92.配置简单的configuration scriptsconfigs/exampl_gem5 gcn3

随便推点

大数据之Hadoop进行文件管理_如何扩展hadoop文件系统的功能,使其具有更加强大的文件管理的功能。-程序员宅基地

文章浏览阅读568次。1.hadoop查看目标文件hadoop fs -ls /{目标文件路径}2.hadoop删除目标文件hadoop fs -rm /{目标文件路径}3.上传文件至目标路径hadoop fs -put /{本地文件路径} /{目标文件路径}4.默认hdfs会将文件保存三份,可以通过修改../hadoop/etc/hadoop/hdfs-site.xml中的dfs.repli..._如何扩展hadoop文件系统的功能,使其具有更加强大的文件管理的功能。

VBS 删除非空文件夹_vba 删除不为空的文件夹-程序员宅基地

文章浏览阅读2.6k次。以前以为必须要使用遍历,查许多网站也是这样写的,但其实不用遍历也可以的:set fso=createobject("Scripting.FileSystemObject")fso.DeleteFolder(tempPath),true这样就行了。但这语法我却是看不懂。_vba 删除不为空的文件夹

Java的继承内存分析_java 继承的内存空间理解-程序员宅基地

文章浏览阅读780次。继承内存分析1.创建对象之前,先加载方法区中object类,GrandPa类,Father类,Son类的属性和方法2.在堆里分配空间,依次开辟空间将Object类的属性,GrandPa类,Father类,Son类的属性放入3.依次从Object开始,字符串放在方法区的常量池内package com;public class TestA { public static void main(String[] args) { Son son = new Son(); _java 继承的内存空间理解

Redis(七)------redis哨兵机制的实现_查看redis端口号存储数据大小-程序员宅基地

文章浏览阅读1.6k次。前言Redis(四)------redis主从复制的实现上一节我们搭建了redis主从复制,redis主从复制主要作用读写分离和数据备份的作用。主机负责写入数据,从机负责读取数据。如果主机节点崩溃了,造成redis服务关闭,需要认为手动启动redis服务。因此我们集成哨兵模式来实现解决这个问题,实现redis的高可用作用。服务器用途redis端口号master-name备..._查看redis端口号存储数据大小

U盘引导安装centos7_centos7 u盘引导-程序员宅基地

文章浏览阅读5.7k次,点赞3次,收藏18次。利用UltraISO写入映像到U盘,然后通过U盘引导安装centos。_centos7 u盘引导

hdu 1300 (dp)-程序员宅基地

文章浏览阅读909次。PearlsTime Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 1225 Accepted Submission(s): 550Problem DescriptionIn Pearlania everybo