加入收藏 | 设为首页 | 会员中心 | 我要投稿 开发网_开封站长网 (http://www.0378zz.com/)- 科技、AI行业应用、媒体智能、低代码、办公协同!
当前位置: 首页 > 大数据 > 正文

如何用10行代码实现目标检测

发布时间:2021-08-15 10:45:06 所属栏目:大数据 来源:互联网
导读:导语 人工智能的一个重要领域是计算机视觉。计算机视觉是计算机和软件系统能够识别和理解图像和场景的科学。计算机视觉还包括图像识别、目标检测、图像生成、图像超分辨率等多个方面。由于大量的实际用例,对象检测可能是计算机视觉最深刻的方面。 如何用10
导语
人工智能的一个重要领域是计算机视觉。计算机视觉是计算机和软件系统能够识别和理解图像和场景的科学。计算机视觉还包括图像识别、目标检测、图像生成、图像超分辨率等多个方面。由于大量的实际用例,对象检测可能是计算机视觉最深刻的方面。
如何用10行代码完成目标检测
目标检测是指计算机和软件系统在图像/场景中定位目标并识别每个目标的能力。目标检测已经广泛应用于人脸检测、车辆检测、行人计数、网络图像、安全系统和无人驾驶汽车。在许多领域的实践中,对象检测也有许多方法可以使用。像其他的计算机技术一样,对象检测的广泛的创造性和惊人的用途肯定会来自计算机程序员和软件开发人员的努力。
这次要介绍的一个叫做ImageAI的项目,它一个python库,让程序员和软件开发人员只需几行代码就可以轻松地将最先进的计算机视觉技术集成到他们现有的和新的应用程序中。
ImageAI安装工作
要使用ImageAI执行对象检测,您需要做的就是:
鸿蒙官方战略合作共建——HarmonyOS技术社区
在计算机系统上安装Python
安装ImageAI及其依赖项
下载对象检测模型文件
运行示例代码(只有10行)
那么我们现在开始:
从官方Python语言网站下载并安装Python 3。
通过pip安装:TensorFlow,OpenCV, Keras, ImageAI
pip3 install tensorflow 
pip3 install opencv-python 
pip3 install keras 
pip3 install imageai --upgrade 
3)通过此文章中的链接下载用于对象检测的RetinaNet模型文件:
https://towardsdatascience.com/object-detection-with-10-lines-of-code-d6cb4d86f606
运行程序
太好了。我们现在已经安装了依赖项,可以编写第一个对象检测代码了。创建一个Python文件并给它起一个名字(例如,FirstDetection.py),然后将下面的代码写进去。将要检测的RetinaNet模型文件图像复制到包含python文件的文件夹中。
from imageai.Detection import ObjectDetection  
import os 
 execution_path =os.getcwd()  
detector = ObjectDetection()  
detector.setModelTypeAsRetinaNet()  
detector.setModelPath( os.path.join(execution_path , "resnet50_coco_best_v2.0.1.h5"))  
detector.loadModel()  
detections = detector.detectObjectsFromImage( input_image=os.path.join(execution_path , "image.jpg"), output_image_path=os.path.join(execution_path , "imagenew.jpg")) 
 for eachObject in detections:  
print(eachObject["name"] , " : " ,  
eachObject["percentage_probability"] ) 
需要注意的是,如果你在运行遇到这个错误:
ValueError: Unable to import backend : theano python mymodel.py 
那么你可以尝试:
import osos.environ['KERAS_BACKEND'] = 'tensorflow'from  
imageai.Detection import ObjectDetection 
然后运行代码并等待结果打印在控制台中。一旦结果打印到控制台中,转到您的FirstDetection.py所在的文件夹,您将发现保存了一个新图像。看看下面的两个图像样本和检测后保存的新图像。
检测前:
如何用10行代码完成目标检测
检测后:
如何用10行代码完成目标检测
数据结果
我们可以看到程序会打印输出一些各个物体的概率数据:
person : 55.8402955532074
person : 53.21805477142334
person : 69.25139427185059
person : 76.41745209693909
bicycle : 80.30363917350769
person : 83.58567953109741
person : 89.06581997871399
truck : 63.10953497886658
person : 69.82483863830566
person : 77.11606621742249
bus : 98.00949096679688
truck : 84.02870297431946
car : 71.98476791381836
可以看出来程序可以对图片中的以下目标进行检测:
人,自行车,卡车,汽车,公交车。
大家可以直接将自己希望检测的照片放到程序里面运行看看效果。
原理解释
现在让我们解释一下10行代码是如何工作的。
from imageai.Detection import ObjectDetectionimport osexecution_path  
= os.getcwd() 
在上面的3行代码中,我们在第一行导入了ImageAI对象检测类,在第二行导入了python os类,并定义了一个变量来保存python文件、RetinaNet模型文件和图像所在的文件夹的路径。
detector = ObjectDetection()detector.setModelTypeAsRetinaNet()detector.setModelP 
ath( os.path.join(execution_path , "resnet50_coco_best_v2.0.1.h5"))detector.loadModel()detections =  
detector.detectObjectsFromImage(input_image=os.path.join(execution_pa 
th , "image.jpg"), output_image_path=os.path.join(execution_path ,  
"imagenew.jpg")) 
在上面的代码中,我们定义对象检测类在第一线,将模型类型设置为RetinaNet在第二行,设置模型路径的路径在第三行RetinaNet模型,该模型加载到对象检测类在第四行,然后我们称为检测函数,解析输入图像的路径和输出图像路径在第五行。
for eachObject in detections:    print(eachObject["name"] , " : "      
, eachObject["percentage_probability"] ) 
在上面的代码中,我们在第一行迭代了detector.detectObjectsFromImage函数返回的所有结果,然后在第二行打印出图像中检测到的每个对象的模型名称和百分比概率。

(编辑:开发网_开封站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读