0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

OpenCV中的图像的计算

深度学习自然语言处理 来源:深度学习自然语言处理 作者:云时之间 2020-11-03 17:45 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

今天我们一起学习的是OpenCV中的图像的计算,在图像计算中,分为像素级运算和代数运算这两大类,今天我们借助OpenCV中的函数一起来看看这些运算。

一:图像的像素级运算

像素级运算中非常常用的就是点运算,之前的文章中说过的让一张图片反转颜色其实就是点运算来实现的。点运算我们一般将其分为三大类:

线性点运算、非线性点运算、映射表点运算

点运算有以下的几个特点:

1:点运算针对图像中的每一个像素灰度,独立地进行灰度值的改变,换句话说,点运算实际上是一种在灰度程度上进行的变换,这是前提。

2:输出图像中每个像素点的灰度值,仅取决于相应输入像素点的值

3:点运算不改变图像内的空间关系

4:从像素到像素的操作

5:点运算可完全由灰度变换函数或灰度映射表确定

具体的例子可以参照之前的文章进行试验,这里不再赘述


二:代数运算

代数运算最常见的是加、减、乘、除这四类,整个代数运算对图片的要求挺高的,首先要尺寸大小相同,然后图片的体积不能太大,如果太大运算起来很费时间。

1. 加法

加法运算的计算公式如下:

C(x,y) = A(x,y) + B(x,y)

其实就是将A,B两张图片每个像素值相加得到一张新的图片,图像加法在图像合成方面用的比较广泛。假如我们将两个图像f(x,y)和h(x,y)进行以下处理:

g(x,y) = 0.5f(x,y) + 0.5h(x,y)

这样图像会得到类似二次曝光的效果

将这个公式进行推广:

g(x,y) = αf(x,y) + βh(x,y) 其中α+β= 1

然后合理的调节α,β的值,我们可以将两张图片进行合成,并且效果很不错

接下来我们使用OpenCV来进行一下操作:

在OpenCV中提供了一些图片进行试验:

找到你相应的安装OpenCV的路径,然后按照图片进行查找即可:

在这里我们选择其中的LinuxLogo和WindowsLogo进行运算,我们定义一个函数,按照以下调用即可:

结果如下:

2. 减法

C(x,y) = A(x,y) - B(x,y)

减法我们可以看做是加法的反例,减法主要用来去除不需要的叠加性图案

或者检测同一场景两幅图像之间的变化。

调用方法如下:

让我们看看结果:

3. 乘法

C(x,y) = A(x,y)×B(x,y) 乘法主要用在图像的局部显示,同时可以用二值蒙板图像与原图像做乘法,通常来说就是加滤镜。。。 OpenCV中乘除法的操作方法:

结果如下:

这里说一下为什么不写一下除法,因为每个像素点取值0-255,一相除以后没有多少数值了,所呈现出来的图像也没有什么有效信息,所以我们一般不怎么使用除法。
三:逻辑运算(求反、异或、或、与) 1)求反的定义 g(x,y) = R - f(x,y) R为f(x, y)的灰度级。 可以应用在: 获得一个图像的负像 获得一个子图像的补图像 2)异或运算的定义 g(x,y) = f(x,y) or h(x,y) 主要应用举例 获得相交子图像 3)与运算的定义 g(x,y) = f(x,y) and h(x,y) 主要应用 求两个子图像的相交子图 在OpenCV中的操作如下:

得到的结果如下:


四:尾巴 在上边的一些操作中,可以看到我基本没有写代码,直接调用OpenCV即可,如今的代码库多种多样,开源的数不胜数,可以说让我们进入了傻瓜编程阶段,并且在OpenCV中,越来越多的函数命名更加直接,极大地简化了我们的操作,我们可以有更多的精力放在算法优化上,而不是在写无穷无尽的程序。其实数字图像处理本身的算法理论很简单,但是一但实际操作起来,问题反而不少,各位希望可以多找几幅图像尝试一下,自己分析一下,相信会有更多的收获! 在中华文化里,鼠乃十二生肖之首,进入鼠年就代表着开始新一轮生肖纪年,也寓意着新的开端,给大家提前拜一个早年!奋斗创造历史,实干成就未来,希望和大家在新的一年里一起努力,共同成长,也感谢大家的支持!

责任编辑:xj

原文标题:【CV学习笔记】图像的计算

文章出处:【微信公众号:深度学习自然语言处理】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 图像
    +关注

    关注

    2

    文章

    1095

    浏览量

    42157
  • 计算
    +关注

    关注

    2

    文章

    458

    浏览量

    39836
  • CV
    CV
    +关注

    关注

    0

    文章

    54

    浏览量

    17473

原文标题:【CV学习笔记】图像的计算

文章出处:【微信号:zenRRan,微信公众号:深度学习自然语言处理】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    零成本钢铁侠手套!树莓派+OpenCV 秒变手势遥控器!

    大家好,这是一个树莓派和OpenCV的连载专题。使用树莓派与OpenCV实现姿态估计和面部特征点追踪使用树莓派与OpenCV实现面部和运动追踪的云台系统使用树莓派和OpenCV实现手部
    的头像 发表于 08-16 16:16 882次阅读
    零成本钢铁侠手套!树莓派+<b class='flag-5'>OpenCV</b> 秒变手势遥控器!

    如何使用树莓派与OpenCV实现面部和运动追踪的云台系统?

    大家好,这是一个树莓派和OpenCV的连载专题。使用树莓派与OpenCV实现姿态估计和面部特征点追踪使用树莓派与OpenCV实现面部和运动追踪的云台系统使用树莓派和OpenCV实现手部
    的头像 发表于 08-14 17:45 957次阅读
    如何使用树莓派与<b class='flag-5'>OpenCV</b>实现面部和运动追踪的云台系统?

    【GM-3568JHF开发板免费体验】OpenCV开发环境安装和计数程序开发

    、 Android 等系统上运行,并通过Python接口简化操作。 sudo apt install libopencv-dev python3-opencv 四、OpenCV图像识别测试 使用python3
    发表于 08-09 13:30

    ElfBoard技术贴|如何在【RK3588】ELF 2开发板安装openCV4以及第三方库contrib

    在嵌入式应用开发领域,OpenCV凭借其丰富的功能成为开发者处理计算机视觉任务的首选工具。Buildroot为开发者提供了便捷的嵌入式系统构建环境,其默认集成的OpenCV版本为4.5.4。然而实际
    的头像 发表于 08-05 11:03 4306次阅读
    ElfBoard技术贴|如何在【RK3588】ELF 2开发板<b class='flag-5'>中</b>安装<b class='flag-5'>openCV</b>4以及第三方库contrib

    itop-3568开发板机器视觉opencv开发手册-图像绘制-画线

    demo11_line.py 然后向该文件添加以下内容: 第 1 行和第 2 行分别导入了 opencv 和 numpy 库; 第 3 行使用 zeros()函数创建一个 512x512 的黑色图片; 第 4 行使
    发表于 06-04 10:38

    基于LockAI视觉识别模块:C++使用图像的统计信息

    图像处理,统计信息可以帮助我们了解图像的特性,例如区域内的像素分布、颜色转换以及特定区域的分析。本文将介绍基于LockAI视觉识别模块如何提取兴趣区域(ROI)、转换颜色通道、计算
    发表于 05-08 10:31

    基于LockAI视觉识别模块:C++图像的基本运算

    图像处理,理解图像的基本操作是掌握计算机视觉技术的关键。本文章将介绍 基于LockAI视觉识别模块下OpenCV
    发表于 05-06 16:56

    基于LockAI视觉识别模块:C++图像的基本运算

    图像处理,理解图像的基本操作是掌握计算机视觉技术的关键。本文章将介绍基于LockAI视觉识别模块下OpenCV
    的头像 发表于 05-06 16:20 529次阅读
    基于LockAI视觉识别模块:C++<b class='flag-5'>图像</b>的基本运算

    基于LockAI视觉识别模块:C++图像采集例程

    本文主要演示如何使用LockAI视觉识别模块进行视频流的读取,同时使用Edit模块进行图像传输。基础知识讲解1.1OpenCV简介OpenCV(OpenSourceComputerVisionLibra
    的头像 发表于 04-30 18:23 557次阅读
    基于LockAI视觉识别模块:C++<b class='flag-5'>图像</b>采集例程

    基于LockAI视觉识别模块:C++图像采集例程

    Vision Library)是一个开源的计算机视觉库,提供丰富的图像处理和视频捕获功能。通过其VideoCapture类,开发者可以轻松调用摄像头设备并获取视频流。 1.2 VideoCapture
    发表于 04-30 10:52

    快速部署!米尔全志T527开发板的OpenCV行人检测方案指南

    计算HOG特征。HOG特征是一个一维向量,其中每个元素表示图像特定位置和方向的梯度强度。 训练SVM分类器:使用HOG特征作为输入,训练SVM分类器。SVM分类器将学习区分行人和非行人。 评估模型
    发表于 04-11 18:14

    使用VirtualLab Fusion中分布式计算的AR波导测试图像模拟

    | 摘要 在这个用例,一个完整的FOV测试图像(在x和y方向分别采样101个角度,总共有10,201个角度)通过波导设备传播。一个具有数百个严格光栅评估的基本模拟大约需要7秒。这导致整个图像的估计
    发表于 04-10 08:48

    AI模型部署边缘设备的奇妙之旅:如何在边缘端部署OpenCV

    1 简介 Opencv(Open Source Computer Vision Library)是一个基于开源发行的跨平台计算机视觉库,它实现了图像处理和计算机视觉方面的很多通用算法,
    发表于 12-14 09:31

    AI模型部署边缘设备的奇妙之旅:如何在边缘端部署OpenCV

    1简介Opencv(OpenSourceComputerVisionLibrary)是一个基于开源发行的跨平台计算机视觉库,它实现了图像处理和计算机视觉方面的很多通用算法,已成为
    的头像 发表于 12-14 09:10 1262次阅读
    AI模型部署边缘设备的奇妙之旅:如何在边缘端部署<b class='flag-5'>OpenCV</b>

    【AI实战项目】基于OpenCV的“颜色识别项目”完整操作过程

    OpenCV是一个广受欢迎且极为流行的计算机视觉库,它因其强大的功能、灵活性和开源特性而在开发者和研究者备受青睐。学习OpenCV主要就是学习里面的
    的头像 发表于 12-09 16:42 1894次阅读
    【AI实战项目】基于<b class='flag-5'>OpenCV</b>的“颜色识别项目”完整操作过程