![深度学习图像识别技术:基于TensorFlow Object Detection API和OpenVINO? 工具套件](https://wfqqreader-1252317822.image.myqcloud.com/cover/997/38485997/b_38485997.jpg)
2.7 安装TensorFlow Object Detection API框架
2.7.1 TensorFlow Object Detection API简介
TensorFlow Object Detection API是一个在TensorFlow基础上开发出来的用于计算机视觉领域实现在图像中检测并定位多个目标物体的软件框架。
基于TensorFlow Object Detection API开源软件框架,开发者可以快速地创建、训练和部署目标检测模型(Object Detection Model),如图2-47所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/59_02.jpg?sign=1739293212-BwtVAhwbOozq1UiVFbBG3FtADJSaCtAl-0-e30439c26082d76e400c9d3cee6a3850)
图2-47 TensorFlow Object Detection API开源软件框架
2.7.2 下载并安装
TensorFlow Object Detection API的下载安装步骤如下。
第一步,建立一个用于TensorFlow训练的文件夹目录结构,将所有基于TensorFlow训练的相关文件集中到一起,方便文件管理。
请读者新建一个文件夹tf_train,文件夹的名字可以根据自己的命名习惯来取。本书推荐tf_train。tf是TensorFlow的通用简称,train表明该文件夹用于管理训练相关的文件。
在tf_train文件夹下,创建一个名字为addons的文件夹,用于存放附加组件或其他软件工具;再创建一个名字为workspaces的文件夹,用于存放每一个具体项目的文件,如图2-48所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/60_01.jpg?sign=1739293212-oIWxrVcghiuOItkUDYVzXJ1uroYY1Krz-0-cb63733c57c7ff5f2bad639bdcade238)
图2-48 tf_train文件夹
第二步,在tf_train文件夹中的空白处单击右键,在右键菜单中单击Git Bash Here,启动Git Bash。
由于TensorFlow Object Detection API的master分支不断在更新,为了保证读者能复现本书的操作,本书使用的TensorFlow Object Detection API的版本分支(Branch)是r1.13.0,链接为https://github.com/tensorflow/models/tree/r1.13.0。
在Git Bash中输入git clone命令,并加入参数-b r1.13.0,告诉git克隆r1.13.0分支。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/60_02.jpg?sign=1739293212-nDF4MXnT4qZvQt38QEhUVQqgK7FGzg88-0-a8b5d061e1928c02e8346b8b74083291)
下载TensorFlow Object Detection API的相关软件源代码,如图2-49所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/60_03.jpg?sign=1739293212-3gpooH81w8AfYRg2BRB9SPTNQwRbg7uy-0-c2af8cceb03f286253b54a67e3aaf123)
图2-49 下载TensorFlow Object Detection API的软件源代码
下载完毕后可以得到一个models文件夹,请把models文件夹全部复制到tf_train文件夹下,这样文件夹结构如图2-50所示,完成TensorFlow Object Detection API的下载和安装。注意:若git下载速度太慢,请从本书提供的360云盘中获取。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/60_04.jpg?sign=1739293212-HeehS9eM03G3pJJZ50l6vcsYgFg8nTgv-0-5181c5ac415b493192edc839ebcd38f0)
图2-50 复制models到tf_train
2.7.3 安装依赖的python软件包
TensorFlow Object Detection API框架依赖的Python软件包见表2-2。
表2-2 依赖软件包及其用途
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/61_01.jpg?sign=1739293212-WX28689JIaGTBtGZInpZ6wXjsUimIBTe-0-469350e1c2ac13d433e1682376924f9e)
从Windows“开始”菜单启动Anaconda Navigator,在Environments选项卡处单击tf_gpu,先激活虚拟环境tf_gpu;然后再单击tf_gpu右边的绿色箭头,在弹出菜单中选择Open Terminal,然后在弹出的命令行终端中输入命令:
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/61_02.jpg?sign=1739293212-PQc158Su7U09GZdaGQU7RC0cVovcyu5k-0-a237474f324573572a83e5e67f84ab32)
完成TensorFlow Object Detection API框架依赖的Python软件包的安装,运行结果如图2-51所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/61_03.jpg?sign=1739293212-lTDy02J8VOnyqFVoB1tFMA4APLJnRqGX-0-6121571957c134269254b0c24775f5fd)
图2-51 安装依赖软件包
2.7.4 配置环境变量
为了让Python能找到TensorFlow Object Detection API依赖的软件模块,需要给Python的模块搜索路径变量PYTHONPATH添加三个路径,如下所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/62_01.jpg?sign=1739293212-AiNu0XV6D7PtjkPiWpUwusOJZkWex2Pp-0-430f2bb84ee535f4bddf4afd6623abf6)
将<PATH_TO_TF>替换为tf_train文件夹所在的绝对路径,例如,本书中tf_train文件夹所在的绝对路径是D:\,那么就把<PATH_TO_TF>替换为D:\,替换结果如下。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/62_02.jpg?sign=1739293212-v2iWLMEDq3hZJDSCfrBWLEBo9JE0MxlJ-0-82c60c37786c30487d9de7c6db60c2a3)
通常情况下,Windows的系统变量中是没有PYTHONPATH的,需要用户新建一个,具体步骤如下。
第一步,在Windows任务栏的搜索框中输入“环境变量”,接着在搜索结果中单击“编辑系统环境变量”,启动“环境变量”窗口,如图2-52所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/62_03.jpg?sign=1739293212-4LdIehcGkxHaRyKIlUss57L3OI7ow65P-0-39740a651798c169f5f8571412bc7c9b)
图2-52 启动“环境变量”窗口
第二步,在“环境变量”窗口单击“新建”按钮,然后在弹出的“新建系统变量”窗口的“变量名”输入栏中输入“PYTHONPATH”;在“变量值”输入栏中输入:
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/63_01.jpg?sign=1739293212-mBrMVU6VPnZMsQniPffMT0t9uH6Ai2BT-0-bfdcb3b484c479510082c652ed57178d)
最后单击“确定”按钮,完成环境变量配置工作,如图2-53所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/63_02.jpg?sign=1739293212-ekqnoSw8a5kRdLPYJYtEHRkdVP0o1G1r-0-fcd271c2c41f8f724a769e0641a5ec10)
图2-53 设置PYTHONPATH变量
2.7.5 安装COCO API
TensorFlow Object Detection API默认评估指标是Pascal VOC,若希望使用COCO评估指标,则需要安装pycocotools,具体步骤如下。
第一步,下载并安装Visual C++ 2015编译工具visualcppbuildtools_full.exe,下载链接为https://go.microsoft.com/fwlink/?LinkId=691126。
第二步,在addons文件夹的空白处单击右键,在右键菜单中单击Git Bash Here,启动Git Bash,然后在Git Bash中输入命令:
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/64_01.jpg?sign=1739293212-qrJSZV1zHdKXiYzSZv3SQf5SQhTJdzeC-0-78532f4f6697e1f93c7624a1163c7fb7)
下载cocoapi源代码,如图2-54所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/64_02.jpg?sign=1739293212-RNCnuXJgins38JYevK8fsJbB5owj7FI2-0-cc1dd1eaf3573782659fd32c1f63a122)
图2-54 下载cocoapi源代码
下载完毕后,文件夹目录结构如图2-55所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/64_03.jpg?sign=1739293212-5c0unZkvNTJ49zyUovqpOr8jQeRAWDsi-0-d9c418767cf4ab559426799257aa9cb9)
图2-55 cocoapi的目录结构
第三步,在Windows任务栏的搜索框中输入“Anaconda Prompt(Anacona3)”,在搜索结果中右键单击Anaconda Prompt(Anacona3),在右键菜单中选择“以管理员身份运行”,启动Anaconda命令行终端,如图2-56所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/65_01.jpg?sign=1739293212-m19kpGV31ECZqKuBtSH9fHLxwSc8dxWh-0-83223579104b0c1053bed030ddb8ea92)
图2-56 以管理员身份运行Anaconda Prompt
然后输入命令:
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/65_02.jpg?sign=1739293212-wcDGyBSaK3wMIAfTKzX0ZreJ1ewclQOv-0-acb1b8ad00df627bd04a8bcd95875f1c)
激活tf_gpu虚拟环境,并输入命令“d:”,进入d盘,再输入命令:
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/65_03.jpg?sign=1739293212-F17Ot9Py3gAnbwAbrbsBtYH0sXtSkOPP-0-88d3d5316e38ffbbfb53ae4862b743f4)
进入PythonAPI文件夹,最后输入命令:
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/65_04.jpg?sign=1739293212-oB5wSw2KYUtStIgGPQcw1ftw7cVygu7E-0-67dc140c9f0a5e6730dfc1731e7c148b)
完成COCO API的安装,如图2-57所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/65_05.jpg?sign=1739293212-E1q3wS4xNru8DP5eS8WKAttLHIYPlekf-0-e14d45d0c13d6ff1d602916125a0b70b)
图2-57 安装COCO API完成
第四步,在安装好COCO API的命令行终端里输入命令“python”,启动Python环境,然后输入语句“import pycocotools”,若import成功,则说明COCO API安装成功,如图2-58所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/66_01.jpg?sign=1739293212-kVYDwxKpTjNHEmSAIbOzvdxbNwr6aXyB-0-ff8f46089a48219fb155f60e968cd5ed)
图2-58 import pycocotools成功
2.7.6 编译proto文件
Tensorflow Object Detection API框架使用protobuf工具来配置模型和训练参数。protobuf工具在2.5.2节用命令conda install tensorflow-gpu=1.13.1安装TensorFlow时,被conda附带安装过了,可以用命令conda list查看确认。
在运行Tensorflow Object Detection API框架前,必须编译proto文件。请进入models\research文件夹(D:\tf_train\models\research),在文件夹地址栏中输入“cmd”,启动Windows命令行终端,然后输入命令:
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/66_02.jpg?sign=1739293212-ovh72KISMQsugsfn03RqpbqhClPg5cRs-0-5069a87ec4d0f7368c42c84c27da17c0)
激活tf_gpu虚拟环境,最后输入命令:
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/66_03.jpg?sign=1739293212-G9ERSPhsmXvYbTzkwlKrid2RcBbG41zY-0-1a25d751a31891402cf42a9b4a3c918b)
完成对proto文件的编译,如图2-59所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/66_04.jpg?sign=1739293212-WZoPDitOaTWmA0215UYxPpAXxdSCTMb1-0-b5769f5e8ac61b5008789d074e2d52ad)
图2-59 编译proto文件
2.7.7 测试安装
至此,TensorFlow Object Detection API框架及其依赖项就安装完毕了,接下来的工作是测试其是否已经安装成功,具体步骤如下。
第一步,从TensorFlow预训练模型库
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/67_01.jpg?sign=1739293212-FTDYaIzydst5Z1AHx6tZrvqsv1F4Ttkg-0-16eaa49dfc49a0fa16f87032ad9e85ce)
中下载模型ssd_inception_v2_coco,如图2-60所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/67_02.jpg?sign=1739293212-5ZhzD7VoHQz9dhRyB34R0ojID9znUcEV-0-e58770cf65eedf0e46d422897471247f)
图2-60 ssd_inception_v2_coco
第二步,模型下载后,得到文件ssd_inception_v2_coco_2018_01_28.tar.tar,直接将其解压,如图2-61所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/67_03.jpg?sign=1739293212-lFbLWlHsVZL9O8YOrluc0msz86cYwZw9-0-46615d1a926db90f94d17ffcc7534e89)
图2-61 解压ssd_inception_v2_coco_2018_01_28.tar.tar
第三步,将解压缩出来的文件夹ssd_inception_v2_coco_2018_01_28复制到D:\tf_train\models\research\object_detection文件夹中,如图2-62所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/68_01.jpg?sign=1739293212-bSAl6IQo2ceKrsTgCTsejRARWrOE0wXo-0-f84dcd4fcb950900eb14a8b28b8835af)
图2-62 复制文件夹ssd_inception_v2_coco_2018_01_28
第四步,将本书附带的object_detection_example_1.py(从本书提供的360云盘中获取)复制到object_detection文件夹。
第五步,修改D:\tf_train\models\research\object_detection\utils文件夹中的visualization_utils.py文件。请将visualization_utils.py文件的第26行import matplotlib;matplotlib.use ('Agg') 注释掉,如图2-63所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/68_02.jpg?sign=1739293212-eiNwIOb4m3Edn0MQtAcUpVH918rWS9xf-0-cb0bc03f8045f5494df4a512017efb74)
图2-63 注释掉import matplotlib;matplotlib.use ('Agg')
第六步,进入object_detection文件夹,在文件夹地址栏中输入“cmd”,启动Windows命令行终端,然后输入命令“conda activate tf_gpu”,激活tf_gpu虚拟环境,最后输入命令“python object_detection_example_1.py”,如图2-64所示。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/69_01.jpg?sign=1739293212-hkZ71WSdXuZqrk9795QHPgObgSKf1T3k-0-a6f56b359165f9f0541fb819cb5ecf60)
图2-64 运行object_detection_example_1.py
若弹出如图2-65所示两张识别成功的图片,说明TensorFlow Object Detection API框架及其依赖项已经安装成功,可以支持训练自己的目标检测模型了。
![](https://epubservercos.yuewen.com/31903E/20255828801879906/epubprivate/OEBPS/Images/69_02.jpg?sign=1739293212-Yompn4uQXPRqD81P6r2VB4RJQ5k59dQc-0-90486a81d31d05976bab82a9050160dd)
图2-65 object_detection_example_1.py运行结果