痛并快乐的YOLO初体验
1、前言
最近因为需要研究视频的物体识别和行为识别,上网了解了一下,YOLO是目前实时视频物体识别的应用最广泛的算法。
因此,作为小白的我,也准备体验一下YOLO算法的效果。
先上网了解了一下YOLO算法的背景资料,有V1,V2,V3,V4四个版本,其中V4版本虽然创新不多,但对工业应用很有价值,引用网上的总结:速度差不多的精度碾压,精度差不多的速度碾压!(刚刚看到,V5版本也出来的,这是什么节奏!!!)
我的想法,V2和V3相对成熟,先体验一下。
当初想得很简单,按照网上的先行者的网文,依葫芦画瓢,照做一遍。然而,真实过程远非如此简单,中间碰到各种问题,可以说,是一把辛酸泪!
先将一些容易踩坑之处和经验教训写出来,分享一下。
2、YOLO V2的痛苦体验
YOLO V2的安装,我参考的是:https://blog.csdn.net/xubuhui/article/details/88877571。
准备工作,安装下列环境:
python 3.5 or 3.6 or 3.7 ;
Anaconda ;
Tensorflow(cpu or gpu 均可);
openCV
下载darkflow代码,并执行安装;
测试体验。
详细过程,我就不展开了,几点经验教训:
1)关于Python版本,要求3.5 or 3.6 or 3.7。
这是因为tensorflow算法包的要求。
踩坑1:一开始,我没有重视,看到Python3的最新版本3.8.3,心想版本高些总会不错吧,安装了,结果后来出现问题。还得重新安装Python 3.7.7。
2)关于Anaconda。
Anaconda是Python环境的包管理工具。
安装了Anaconda后,创建了适合tensorflow环境,则所有操作都应该在Anaconda环境下执行,用AnaConda Prompt命令行工具,或AnaConda Navigator可视化图形界面工具都可以。但是一定不要用操作系统自带的CMD工具。
踩坑2:我使用win+R,输入cmd,显示命令行工具。执行下列语句:
python --version
显示的python版本号,是之前安装的2.7。
由于一开始没有理解Anaconda的用法,折腾了好久,包括设置path,调整先后次序,当时版本是可以了,但是后来安装darkflow时又有其它问题,最后还将python 2.7给卸载了。
Anaconda正确的使用姿势:
(1)先创建一个匹配python版本的环境,如tensorflow,使用python 3.7.7。
conda create -n tensorflow python=3.7.7
(2)使用前,先激活环境。
conda activate tensorflow
(3)可以使用pip,或install,或执行python脚本。
#执行pip
pip install cython
#install
conda install tensorflow
#执行python,使用py或python指令,执行python脚本setup.py
py setup.py build_ext --inplace
更进一步,可以上网查询AnaConda指令大全。
3)关于网速。
这点特别重要!!!如有可能,最好使用大学VPN来下载。
踩坑3:
A:安装tensorflow算法包,随机断开,重复多次,一直没成功,隔天正常,才安装成功。
B:从https://github.com/thtrieu/darkflow下载darkflow的Download zip文件,失败;使用git clone也随机断开。隔天正常,才下载成功。
4)关于安装darkflow
(1)首先,必须在AnaConda环境下,激活之前创建的tensorflow环境,来执行下列语句:
python setup.py build_ext --inplace
踩坑4:
我先前安装引用的网文的做法,在win10的cmd环境下,执行,总是报错:
ModuleNotFoundError: No module named 'Cython'
这个折腾了好久。
(2)其次,需要VS2015 C++环境。
否则提示:
访问失败:...\\Microsoft Visual Studio 14.0\\VC\\PlatformSDK\\lib
由于我好久没用VC了,之前只装了C#,补充安装,看着处于卡死状态,不放心,索性卸载重装了一次。结果,也许是网速问题,奇慢无比,重装VS2015,花了10几个小时。彻底无语!
5)关于安装tensorflow算法包的版本
好不容易通过darkflow的安装,生成了cy_yolo2_findboxes.cp37-win_amd64.pyd等几个文件,在测试体验时,又出问题。
由于我之前安装的tensorflow算法包的版本是2.1.0,而darkflow要求的tensorflow 版本是1.4,于是还是不成。
想想,yolo v2版本反正不如v3,不如直接搞v3吧。最终,yolo v2没有体验成功,放弃了。
3、YOLO V3的体验
关于YOLO V3的官网:https://pjreddie.com/darknet/yolo/。
V3版本最终成功体验了,中间也出现了一些问题,需要注意的地方:
1)代码下载
不能使用:git clone https://github.com/pjreddie/darknet,这会在后面导致下列问题:
couldn’t open file: data/coco.names
正确做法,直接输入https://github.com/pjreddie/darknet网址,download zip文件。网上说这是因为Windows系统和Linux系统编码的不同可能会导致一些错误。
2)make需要安装gcc环境
安装cygwin时,必须勾选:make和g++。(如果没有,则需要补充安装,默认是skip,即不安装)。
否则,make时,提示make指令错误,或gcc错误。
make成功后,生成了darknet.exe文件。
3)图片的检测命令:
下面例子中,yolov3.weights到yolo官网下载,我用的是416*416,test.jpg是网上搞得图片。
darknet.exe detect cfg/yolov3.cfg yolov3.weights test.jpg
成功,执行后,生成一个predictions.jpg文件。
这样初步体验OK了,也可以用视频文件。
痛并快乐的YOLO初体验的更多相关文章
- wxWidgets刚開始学习的人导引(3)——wxWidgets应用程序初体验
wxWidgets刚開始学习的人导引全文件夹 PDF版及附件下载 1 前言2 下载.安装wxWidgets3 wxWidgets应用程序初体验4 wxWidgets学习资料及利用方法指导5 用wx ...
- Unit1-窝窝初体验
全文共3179字,推荐阅读时间10~15分钟. 文章共分四个部分: 作业分析 评测相关 重构策略 初体验感受 作业分析 第一次作业 第一次作业要求我们实现一个简单的幂函数求导工具,没有乘积和复合的情况 ...
- Spring核心原理之IoC容器初体验(2)
本文节选自<Spring 5核心原理> 1 IoC与DI基本概念 IoC(Inversion of Control,控制反转)就是把原来代码里需要实现的对象创建.依赖,反转给容器来帮忙实现 ...
- .NET平台开源项目速览(15)文档数据库RavenDB-介绍与初体验
不知不觉,“.NET平台开源项目速览“系列文章已经15篇了,每一篇都非常受欢迎,可能技术水平不高,但足够入门了.虽然工作很忙,但还是会抽空把自己知道的,已经平时遇到的好的开源项目分享出来.今天就给大家 ...
- Xamarin+Prism开发详解四:简单Mac OS 虚拟机安装方法与Visual Studio for Mac 初体验
Mac OS 虚拟机安装方法 最近把自己的电脑升级了一下SSD固态硬盘,总算是有容量安装Mac 虚拟机了!经过心碎的安装探索,尝试了国内外的各种安装方法,最后在youtube上找到了一个好方法. 简单 ...
- Spring之初体验
Spring之初体验 Spring是一个轻量级的Java Web开发框架,以IoC(Inverse of Control 控制反转)和 ...
- Xamarin.iOS开发初体验
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKwAAAA+CAIAAAA5/WfHAAAJrklEQVR4nO2c/VdTRxrH+wfdU84pW0
- 【腾讯Bugly干货分享】基于 Webpack & Vue & Vue-Router 的 SPA 初体验
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57d13a57132ff21c38110186 导语 最近这几年的前端圈子,由于 ...
- 【Knockout.js 学习体验之旅】(1)ko初体验
前言 什么,你现在还在看knockout.js?这货都已经落后主流一千年了!赶紧去学Angular.React啊,再不赶紧的话,他们也要变out了哦.身旁的90后小伙伴,嘴里还塞着山东的狗不理大蒜包, ...
随机推荐
- java面试一日一题:如何设计一款垃圾回收器
问题:如果让你设计一个垃圾回收器,你会考虑哪些问题 分析:该问题主要考察对java中垃圾回收器的理解,要理解怎么回收:一款好的垃圾回收器有哪些衡量指标 回答要点: 主要从以下几点去考虑, 1.垃圾回收 ...
- SimpleDateFormat线程不安全的5种解决方案!
1.什么是线程不安全? 线程不安全也叫非线程安全,是指多线程执行中,程序的执行结果和预期的结果不符的情况就叫做线程不安全. 线程不安全的代码 SimpleDateFormat 就是一个典型的线程不 ...
- python爬虫——拉钩网python岗位信息
之前爬取的网页都是采用"GET"方法,这次爬取"拉勾网"是采取了"POST"的方法.其中,"GET"和"POS ...
- 日常Bug排查-系统失去响应-Redis使用不当
日常Bug排查-系统失去响应-Redis使用不当 前言 日常Bug排查系列都是一些简单Bug排查,笔者将在这里介绍一些排查Bug的简单技巧,同时顺便积累素材_. Bug现场 开发反应线上系统出现失去响 ...
- ssh-的搭建和使用
ssh的作用 : 可实现远程客户端登录服务器并对服务器的文件进行操作 ssh服务器的安装 farsight@ubuntu:~$ sudo apt-get install openssh-server ...
- Map 实现类之一:HashMap
Map 实现类之一:HashMapHashMap是 Map 接口 使用频率最高的实现类.允许使用null键和null值,与HashSet一样,不保证映射的顺序.所有的key构成的集合是Set:无 ...
- [bug] 安装MySQL8.0.15 失败,提示This application requires Visual Studio 2015 x64 Redistributable
参考 https://blog.csdn.net/weixin_44092289/article/details/88045666
- [bug] Linux下执行.sh命令出现-bash: ./bin/start.sh: /bin/bash^M: bad interpreter: No such file or directory
参考 https://www.cnblogs.com/aeolian/p/10614284.html
- [ML] 高德软件的路径规划原理
路径规划 Dijkstra s:起点:S:已知到起点最短路径的点:U:未知到起点最短路径的点 Step 1:S中只有起点s,从U中找出路径最短的 Step 2:更新U中的顶点和顶点对应的路径 重复St ...
- [Linux] Linux C编程一站式学习 Part.1
C语言入门 程序基本概念 程序和编程语言 C语言--(编译器)--汇编语言--(汇编器)--机器语言(目标代码 / 可执行代码) 可移植 / 平台无关:平台指计算机体系结构或操作系统,或二者的组合.不 ...