YOLO实践应用之搭建开发环境(Windows系统、Python 3.8、TensorFlow2.3版本)

简介: 基于YOLO进行物体检测、对象识别,先和大家分享如何搭建开发环境,会分为CPU版本、GPU版本的两种开发环境,本文会分别详细地介绍搭建环境的过程。主要使用TensorFlow2.3、opencv-python4.4.0、Pillow、matplotlib 等依赖库。

前言

 基于YOLO进行物体检测、对象识别,先和大家分享如何搭建开发环境,会分为CPU版本、GPU版本的两种开发环境,本文会分别详细地介绍搭建环境的过程。

主要使用TensorFlow2.3、opencv-python4.4.0、Pillow、matplotlib 等依赖库。


搭建环境参数

系统:Windows       编程语言:Python 3.8          

深度学习框架:TensorFlow 2.3        整合开发环境:Anaconda        开发代码IDE:PyCharm

推荐理由:1)Anaconda +PyCharm,能适应较多的开发环境,比如,创建一个TensorFlow2.3的环境,创建一个TensorFlow1.5的环境,是不会相互影响的,而且切换很方便。相对来说VScode在环境配置和切换就差一些了,尽管我也挺喜欢VScode的。

2)使用Python语言相对C、C++更好上手,易于理解。


 一、安装Anaconda

  大家到官网下载Windows 版本的Anaconda,选择电脑的位数(32位 / 64位):目前最新默认使用Python 3.8了,没关系的,等下我们可以创建一个独立的conda开发环境,安装Python 3.6就好啦。

Free Download | Anaconda

image.gif编辑

在网页中拉到底下,即可看到上图页面;比如,电脑系统是Windows的64位,选择红色框框的;如果是32位的,选择红框下一个。下载好后,其是一个可执行文件,例如:Anaconda3-2020.07-Windows-x86_64.exe。

双击可执行文件,进行安装,过程安装引导安装即可;(同意,下一步)

需要注意:添加环境变量的需要勾上√,如果默认使用PYthon3.8的第二个勾上,

image.gif

后面默认直至安装完成。


二、安装TensorFlow

 这里是在Anaconda中安装TensorFlow 2.3的,大家可以想象Anaconda为一个资源管理器,在支持PYthon3 的基础上,安装许多深度学习用到的包或依赖库,然后封装成一个独立的开发环境;最好后在PyCharm直接使用封装好的开发环境。

首先在应用程序中打开“Anaconda Prompt(naconda3)”:

image.gif

大家先选择一下,是安装CPU环境,还是GPU环境,建议尽量安装GPU环境,这样做YOLO的物体检测、目标识别时会更快和流畅。先看下是否符合GPU环境的要求:

GPU 前提条件:电脑中有显卡,NVIDIA品牌;而且在windows中的显卡驱动的版本 >=418.96

1)如果满足这个条件的朋友,恭喜你可以布置GPU加速环境,训练神经网络时可以用到GPU进行加速。

2)如果不满足这个条件的朋友,先去看看我这边博客:一篇文章清晰了解NVIDAI显卡驱动(包括:CUDA、CUDA Driver、CUDA Toolkit、CUDNN、NCVV) 这里面有介绍较旧的显卡(例如我的旧电脑是GTX950M),安装较新版本的显卡驱动(445.87版本);从而实现使用GTX950M显卡进行加速神经网络训练等。新电脑的显卡是GTX1660了。

3)如果电脑没显卡,或不想使用GPU加速的朋友,可以跳过布置GPU加速环境

1、YOLO开发环境——CPU版本

1)新建一个名为 YOLO3-CPU-TensorFlow2 的开发环境,使用PYthon3.8

conda create  -n YOLO3-CPU-TensorFlow2  python=3.8

image.gif

安装过程询问y / n; 输入y 同意安装

image.gif

等待安装完成即可。

2)进入刚才创建的环境

conda activate YOLO3-CPU-TensorFlow2

3)安装TensorFlow2.3.1

pip install tensorflow==2.3.1   -i https://mirrors.aliyun.com/pypi/simple/

这里等待安装完成即可; 分析-i https://mirrors.aliyun.com/pypi/simple/  是指定国内的软件源来下载,这样比较快。

image.gif

4)验证是否环境安装成功

进入Python环境:

python

输入命令导入TensorFlow库:import tensorflow as tf

查看其版本:tf.__version__

image.gif


2、YOLO开发环境——GPU版本

前提条件:电脑中有显卡,NVIDIA品牌;而且在windows中的显卡驱动的版本 >=418.96

1)新建一个名为 YOLO3-GPU-TensorFlow2 的环境,使用PYthon3.8

conda create  -n YOLO3-GPU-TensorFlow2  python=3.8

安装过程询问y / n; 输入y 同意安装

等待安装完成即可。

2)进入刚才创建的环境

conda activate YOLO3-GPU-TensorFlow2

3)安装TensorFlow2.3.1

pip install tensorflow-gpu==2.3.1   -i https://mirrors.aliyun.com/pypi/simple/

这里等待安装完成即可; 分析 -i https://mirrors.aliyun.com/pypi/simple/ 是指定国内的软件源来下载,这样比较快。

image.gif

等待安装完成;

image.gif

下面安装英伟达的cudatoolkit、和英伟达深度学习软件包cudnn

a)安装英伟达的cudatoolkit 10.1版本

conda install cudatoolkit=10.1

image.gif

安装过程需要选择y,等待安装完成。

b)安装英伟达深度学习软件包7.6版本

conda install cudnn==7.6.*

image.gif

如果上面cudatoolkit、cudnn两条语句顺利安装没报错,恭喜你啊,布置GPU加速环境成功啦。

4)验证是否环境安装成功

进入Python环境:

python

输入命令导入TensorFlow库:import tensorflow as tf

查看其版本:tf.__version__

image.gif

完成啦!!


三、安装PyCharm

我们到官方下载社区版的PyCharm,无需在网上找破解版的;

Download PyCharm: Python IDE for Professional Developers by JetBrains

image.gif

然后来到下图页面:

image.gif

下载好后是一个可执行文件,例如:pycharm-community-2020.1.exe

双击可执行文件进行安装,默认安装即可,需要注意的下图:

image.gif

然后等待安装完成后,需要重启电脑哦。


四、安装YOLO3用到的依赖库

主要安装python版本的OpenCV、Keras、Pillow、matplotlib;建议大家根据下面的命令进行安装,下面的依赖库指定的版本是通过测试的。其中 -i https://pypi.mirrors.ustc.edu.cn/simple 主要是指定pip 为国内软件源安装,提升安装速度。

下面依赖库安装通常是没什么问题的,就不截图安装过程了

pip install opencv-python==4.4.0.44 -i https://mirrors.aliyun.com/pypi/simple/

pip install Pillow -i https://mirrors.aliyun.com/pypi/simple/

pip install matplotlib -i  https://mirrors.aliyun.com/pypi/simple/


五、配置PyCharm开发环境

1)打开PyCharm,新建工程;

image.gif

2)然后选择 1 工程所放目录路径;2 点击查看详情配置; 3点击选择创建的开发环境

image.gif

3)设置开发环境,使用之前在Anaconda创建好的环境:YOLO3-GPU-Tensoflow2

image.gif

点击OK,然后点击create。

image.gif


测试环境

新建一个python文件,编写测试程序:

测试代码:

import  tensorflow as tf
tensorflow_version = tf.__version__
#以下两行代码适合有“布置GPU环境的”
gpu_available = tf.test.is_gpu_available()
print("tensorflow version:", tensorflow_version, "\tGPU available:", gpu_available)
#以下一行代码适合没有“布置GPU环境的”,纯CPU版本的
#print("tensorflow version:", tensorflow_version)
a = tf.constant([1.0, 2.0], name="a")
b = tf.constant([1.0, 2.0], name="b")
result = tf.add(a, b, name="add")
print(result)

image.gif

运行结果:

image.gif

能看到YOLO的开发环境搭建成功了,恭喜啊。

先看一下LOYOv3 的效果:YOLOv3物体/目标检测之实战篇(Windows系统、Python3、TensorFlow2版本)

1)有四只小猫被检测出来:

使用浅蓝色的框框,把小猫的所在位置框出来,并在框框上方注释标签(类别 置信度)。比如第一只小猫检测出的标签是cat ,置信度是0.95,即有95%的把握认为是cat 猫。

image.gif

2)一只小狗和一只小猫同时被检测出来:

小猫被检测出是cat,1.00;有100%的把握认为是cat 猫;

小狗被检测出是dog,0.97;有97%的把握认为是cat 猫;

image.gif

3)在复杂的十字路口,有许多行人和车辆被检测出来了:

大家可以看到大部分的行人、小汽车和公交车是被检测出来了,存在小部分没有被检测出来;如果是做特定场景的目标检测,建议大家后续采购特定场景的数据,重新训练网络,生成稳定且高精度的模型,保存权重文件,便于后续使用。

image.gif

希望对你有帮助,如果发现文章有误,欢迎指出。

相关实践学习
在云上部署ChatGLM2-6B大模型(GPU版)
ChatGLM2-6B是由智谱AI及清华KEG实验室于2023年6月发布的中英双语对话开源大模型。通过本实验,可以学习如何配置AIGC开发环境,如何部署ChatGLM2-6B大模型。
相关文章
|
5月前
|
存储 分布式计算 大数据
基于Python大数据的的电商用户行为分析系统
本系统基于Django、Scrapy与Hadoop技术,构建电商用户行为分析平台。通过爬取与处理海量用户数据,实现行为追踪、偏好分析与个性化推荐,助力企业提升营销精准度与用户体验,推动电商智能化发展。
|
5月前
|
机器学习/深度学习 大数据 关系型数据库
基于python大数据的台风灾害分析及预测系统
针对台风灾害预警滞后、精度不足等问题,本研究基于Python与大数据技术,构建多源数据融合的台风预测系统。利用机器学习提升路径与强度预测准确率,结合Django框架实现动态可视化与实时预警,为防灾决策提供科学支持,显著提高应急响应效率,具有重要社会经济价值。
|
5月前
|
机器学习/深度学习 大数据 关系型数据库
基于python大数据的青少年网络使用情况分析及预测系统
本研究基于Python大数据技术,构建青少年网络行为分析系统,旨在破解现有防沉迷模式下用户画像模糊、预警滞后等难题。通过整合多平台亿级数据,运用机器学习实现精准行为预测与实时干预,推动数字治理向“数据驱动”转型,为家庭、学校及政府提供科学决策支持,助力青少年健康上网。
|
机器学习/深度学习 人工智能 算法
猫狗宠物识别系统Python+TensorFlow+人工智能+深度学习+卷积网络算法
宠物识别系统使用Python和TensorFlow搭建卷积神经网络,基于37种常见猫狗数据集训练高精度模型,并保存为h5格式。通过Django框架搭建Web平台,用户上传宠物图片即可识别其名称,提供便捷的宠物识别服务。
1226 55
|
机器学习/深度学习 人工智能 算法
鸟类识别系统Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+ResNet50算法模型+图像识别
鸟类识别系统。本系统采用Python作为主要开发语言,通过使用加利福利亚大学开源的200种鸟类图像作为数据集。使用TensorFlow搭建ResNet50卷积神经网络算法模型,然后进行模型的迭代训练,得到一个识别精度较高的模型,然后在保存为本地的H5格式文件。在使用Django开发Web网页端操作界面,实现用户上传一张鸟类图像,识别其名称。
710 12
鸟类识别系统Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+ResNet50算法模型+图像识别
|
机器学习/深度学习 数据采集 数据可视化
TensorFlow,一款由谷歌开发的开源深度学习框架,详细讲解了使用 TensorFlow 构建深度学习模型的步骤
本文介绍了 TensorFlow,一款由谷歌开发的开源深度学习框架,详细讲解了使用 TensorFlow 构建深度学习模型的步骤,包括数据准备、模型定义、损失函数与优化器选择、模型训练与评估、模型保存与部署,并展示了构建全连接神经网络的具体示例。此外,还探讨了 TensorFlow 的高级特性,如自动微分、模型可视化和分布式训练,以及其在未来的发展前景。
1091 5
|
机器学习/深度学习 人工智能 TensorFlow
基于TensorFlow的深度学习模型训练与优化实战
基于TensorFlow的深度学习模型训练与优化实战
666 3
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的【垃圾识别系统】实现~TensorFlow+人工智能+算法网络
垃圾识别分类系统。本系统采用Python作为主要编程语言,通过收集了5种常见的垃圾数据集('塑料', '玻璃', '纸张', '纸板', '金属'),然后基于TensorFlow搭建卷积神经网络算法模型,通过对图像数据集进行多轮迭代训练,最后得到一个识别精度较高的模型文件。然后使用Django搭建Web网页端可视化操作界面,实现用户在网页端上传一张垃圾图片识别其名称。
582 0
基于Python深度学习的【垃圾识别系统】实现~TensorFlow+人工智能+算法网络
|
机器学习/深度学习 人工智能 算法
【手写数字识别】Python+深度学习+机器学习+人工智能+TensorFlow+算法模型
手写数字识别系统,使用Python作为主要开发语言,基于深度学习TensorFlow框架,搭建卷积神经网络算法。并通过对数据集进行训练,最后得到一个识别精度较高的模型。并基于Flask框架,开发网页端操作平台,实现用户上传一张图片识别其名称。
635 0
【手写数字识别】Python+深度学习+机器学习+人工智能+TensorFlow+算法模型

推荐镜像

更多