推广 热搜:   公司  快速  中国  企业    行业  设备  上海  未来 

AI与Python - 计算机视觉

   日期:2025-01-01     移动:http://keair.bhha.com.cn/mobile/quote/5872.html

计算机视觉涉及使用计算机软件和硬件建模和复制人类视觉。在本章中,您将详细了解这一点。

计算机视觉是一门学科,根据场景中存在的结构的属性,研究如何从其2d图像重建,中断和理解3d场景。

计算机视觉层次结构

计算机视觉分为以下三个基本类别 -

  • 低级视觉 - 它包括用于特征提取的过程图像。

  • 中级视觉 - 包括物体识别和3D场景解释

  • 高级视觉 - 包括活动,意图和行为等场景的概念性描述。

图像处理研究图像到图像的变换。图像处理的输入和输出都是图像。

计算机视觉是从图像中构建对物理对象的明确,有意义的描述。计算机视觉的输出是对3D场景中的结构的描述或解释。

应用

计算机视觉在以下领域中得到应用 -

机器人
  • 本地化 - 自动确定机器人位置

  • 导航

  • 障碍避免

  • 装配(挂孔,焊接,喷漆

  • 操纵(例如PUMA机器人操纵器

  • 人机交互(HRI:与人交互和服务的智能机器人

医学
  • 分类和检测(例如病变或细胞分类和肿瘤检测

  • 2D / 3D分割

  • 3D人体器官重建(MRI或超声

  • 视觉引导机器人手术

安全
  • 生物识别技术(虹膜,指纹,面部识别
  • 监视 - 检测某些可疑活动或行为
运输
  • 自动驾驶汽车
  • 安全性,例如驾驶员警惕监控
工业自动化应用
  • 工业检查(缺陷检测
  • 部件
  • 条形码和包装标签阅读
  • 对象排序
  • 文件理解(例如OCR

对于使用Python的计算机视觉,您可以使用名为OpenCV(开源计算机视觉)的流行库。它是一个编程功能库,主要针对实时计算机视觉。它是用C ++编写的,其主要接口是用C ++编写的。您可以借助以下命令安装此软件包 -

 

这里X代表您机器上安装的Python版本以及您拥有的win32或64位。

如果您使用的是anaconda环境,请使用以下命令安装OpenCV -

 
 

大多数CV应用程序需要将图像作为输入并将图像作为输出生成。在本节中,您将学习如何借助OpenCV提供的功能读取和写入图像文件。

OpenCV函数用于读取,显示,写入图像文件

OpenCV为此提供以下功能 -

  • imread)函数 - 这是读取图像的函数。OpenCV imread)支持各种图像格式,如PNG,JPEG,JPG,TIFF等。

  • imshow)函数 - 这是在窗口中显示图像的功能。窗口自动适合图像大小。OpenCV imshow)支持各种图像格式,如PNG,JPEG,JPG,TIFF等。

  • imwrite)函数 - 这是写入图像的函数。OpenCV imwrite)支持各种图像格式,如PNG,JPEG,JPG,TIFF等。

此示例显示了用于以一种格式读取图像的Python代码 - 在窗口中显示它并以其他格式写入相同的图像。考虑以下步骤 -

如图所示导入OpenCV包 -

 

现在,要读取特定图像,请使用imread)函数 -

 

要显示图像,请使用imshow)函数。您可以在其中查看图像的窗口名称为image_flower。

 
 
 

输出True表示图像已成功写入.png文件也位于同一文件夹中。

 

注意 - 函数destroyallWindows)只是破坏我们创建的所有窗口。

在OpenCV中,图像不是使用传统的RGB颜色存储的,而是以相反的顺序存储,即以BGR顺序存储。因此,读取图像时的默认颜色代码是BGR。所述cvtColor)中的图像从一个颜色代码转换为其他颜色转换功能。

考虑此示例将图像从BGR转换为灰度。

如图所示导入OpenCV包 -

 

现在,要读取特定图像,请使用imread)函数 -

 

现在,如果我们使用imshow)函数看到这个图像,那么我们可以看到这个图像在BGR中。

 
 
 
 
 

人们在看到粗略的草图后,可以很容易地识别出许多物体类型和姿势。这就是边缘在人类生活以及计算机视觉应用中发挥重要作用的原因。OpenCV提供了一个非常简单有用的函数Canny)来检测边缘。

以下示例显示了边缘的清晰标识。

导入OpenCV包如图所示 -

 

现在,要读取特定图像,请使用imread)函数。

 

现在,使用Canny)函数检测已读取图像的边缘。

 

现在,要显示带边的图像,请使用imshow)函数。

 

这个Python程序将使用边缘检测创建一个名为edges_penguins.jpg的图像。

人脸检测是计算机视觉的迷人应用之一,使其更加真实和未来。OpenCV具有执行面部检测的内置工具。我们将使用Haar级联分类器进行人脸检测。

哈尔Cascade数据

我们需要数据来使用Haar级联分类器。您可以在我们的OpenCV包中找到这些数据。安装OpenCv后,您可以看到文件夹名称haarcascades。不同的应用程序会有.xml文件。现在,将它们全部复制以供不同使用,然后粘贴到当前项目下的新文件夹中。

 

现在,使用HaarCascadeClassifier检测面部 -

 

现在,要读取特定图像,请使用imread)函数 -

 

现在,将其转换为灰度,因为它会接受灰色图像 -

 

现在,使用face_detection.detectMultiScale,执行实际的面部检测

 

现在,在整个脸部周围画一个矩形 -

 
 
 

眼睛检测是计算机视觉的另一个迷人应用,它使其更加真实和未来。OpenCV有一个内置的工具来执行眼睛检测。我们将使用Haar级联分类器进行眼睛检测。

 

现在,使用HaarCascadeClassifier检测面部 -

 

现在,要读取特定图像,请使用imread)函数

 

现在,将其转换为灰度,因为它会接受灰色图像 -

 

现在借助eye_cascade.detectMultiScale,执行实际的人脸检测

 

现在,在整个脸部周围画一个矩形 -

本文地址:http://keair.bhha.com.cn/quote/5872.html    康宝晨 http://keair.bhha.com.cn/ , 查看更多

特别提示:本信息由相关用户自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。


相关最新动态
推荐最新动态
点击排行
网站首页  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  粤ICP备2023022329号