冈萨雷斯《数字图像处理》学习总结及感悟:第一章 绪论 百闻不如一见

Aidan075
• 阅读 1681

冈萨雷斯《数字图像处理》学习总结及感悟:第一章 绪论 百闻不如一见

一、引言

好几月前开始自学OpenCV-Python,但老猿以前没接触过图像基础知识,数学知识基本上也都忘光了,因此在自学OpenCV-Python过程中遇到了很多困难。OpenCV-Python虽然网上资料丰富,但对于一个缺乏图像处理基础知识的人还是远远不够,导致进展非常缓慢。

为了弥补基础知识的不足,特地下载了冈萨雷斯(Rafael C. Gonzalez)编著的《数字图像处理》(Digital Image Processing)第三版的中文译本和英文原本电子书对照学习,准备好好补补基础知识。

为了供老猿类似情况的同好能快速理解图像处理基础知识,老猿将学习后的关键知识和感悟整理后通过博文发布出来,另外在记录知识的同时对部分中文版的翻译进行了老猿认为的改善(红体字表示),供各位有类似情况的同好参考,也可以节约大家的学习时间。

二、知识概要:百闻不如一见

开篇第一句话:One picture is worth more than ten thousand words 中文版翻译成:百闻不如一见 老猿的感觉:用得非常贴切,翻译得神!

数字图像处理方法源于两个应用领域:改善图像信息以便于人们理解和解释、处理图像用于进行图像存储、传递以及形成便于机器感知理解的表现形式

2.1、定义

数字图像:一幅图像可定义为一个二维函数f(x,y),其中x和y是空间(平面)坐标,而在任何一对空间坐标(x,y)处的幅值对应为函数值f(x,y),该幅值称为图像在该点处的强度或灰度级。当x,y和灰度值f是有限的离散数值时,我们称该图像为数字图像。•数字图像处理:借助计算机进行数字图像的处理。•像素:构成数字图像的元素称为像素,每个元素都由代表位置的坐标和代表幅值的数值组成。像素又可以称为图画元素、图片元素,对应英文单词为:picture elements, image elements、pels、pixels

2.2、数字图像处理的应用领域

•空间探测:1964年美国“徘徊者7号”卫星传送了月球图像,使用计算机对航天器电视摄像机拍摄图像的各种畸变进行了校正,这是图像复原和增强方法的基础。•医学、生物学:X光照片、CT影像•地球资源遥感监测•天文学观察•考古学:复原图片•物理学:高能等离子图像、电子显微镜图像•国防及工业领域•机器感知:OCR图片文字识别、工业机器人感知、军事目标自动识别、指纹自动处理、血样分类、天气预报云图识别等

2.3、数字图像成像类型

视觉是人类最高级的感知,但人类的感知仅限于电磁波谱的视觉波段,而成像机器几乎可以覆盖从伽马射线到无线电波的整个电磁波谱。它们可以对非人类所习惯的那些图像源进行加工,这些图像源包括超声波、电子显微镜和计算机产生的图像。因而,数字图像处理涉及很宽泛的各种各样的应用领域。

图像的生成需要成像的各种能量,最常见的生成图像的能量是电磁波,另外还有声波、超声波和电子。

电磁波为各种波长传播的正弦波,是无质量的粒子流,每个粒子包含一束能量以光速传播,每束能量称为一个光子。根据光子的能量(单位电子伏特)对电磁波谱进行分组如下:冈萨雷斯《数字图像处理》学习总结及感悟:第一章 绪论 百闻不如一见

根据生成图像的能源来划分,可以将数字图像成像机制分成如下:

•伽马射线成像:主要用于核医学和天文观测,如医学上的PET(positron emission tomography,正电子仿射断层)影像•X射线成像:用于医学检测(x光照片、血管造影、CT等)、工业检测、天文学观察•紫外线成像:用于平板印刷、工业检测、显微镜(荧光显微镜)、激光、生物成像、天文观测•可见光成像:这是最常见的,如相机,也可以用于显微镜、天文学、遥感、工业检测•红外成像:用途类似于可见光,只是不同的物体适用不同波长的可见光或红外光•微波成像:如雷达•无线电波成像:主要用于医学和天文学,如核磁共振MRI成像•声波成像:主要用于地质勘察、工业和医学应用•超声波成像:主要用于制造业和医学•电子显微镜成像:用于生物学、工业检测、物理学、天文学等,如透射电子显微镜TEM、扫描电子显微镜SEM•计算机成像:用计算机根据一定算法生成图像,如三维建模

在书中,作者花了比较大的篇幅详细介绍了这些数字成像应用的案例,看了这些案例对于感性理解数字成像还是很有帮助的。

2.4、数字图像处理研究的范围

数字图像相关的处理涉及很多层面,从简单的图像对比度增强到图像识别再到计算机视觉,从简单图像处理到AI,涉及的领域跨度很大,并且没有明显的界限,但这一广袤的范围并不全都属于数字图像处理研究的范围。

一种常见的方法是将数字图像处理到计算机视觉这一广袤的范围划分成低级、中级、高级三个阶段:

1.低级处理:涉及图像的初级操作,如降噪处理、对比度增强、锐化处理,其特征是输入、输出都是图像;2.中级处理:输入为图像,但输出是从图像中提取的特征,如边缘、轮廓、物体标识的识别3.高级处理:识别图像整体、与视觉相关的认知。

在《数字图像处理》一书中,将数字图像处理界定为:

•输入和输出都是图像的处理•从图像中提取特征•图像中各个目标的识别

书中以OCR图像文字识别为例,对图像进行预处理(图像对比度增强等)、分割字符、识别分割的每个字符等都是属于数字图像处理的范围,但将文字组成的句子进行语义识别则不属于数字图像处理范围。

2.5、数字图像处理基本步骤

数字图像处理基本步骤如下:

1.图像获取(Image acquisition);主要用于获得数字图像,包含图像预处理如图像缩放。图像获取首先要进行图像感知(image sensing),图像感知首先需要一个对希望成像的目标辐射(radiated,老猿认为包括反射、透射两种)能量很敏感的物理设备用于收集能量,然后需要一个数字化器部件(digitizer),用于将感知的不同能量输出成数字。2.图像增强(Image enhancement):对图像进行某种操作使得结果图像比原始图像更适合特定应用的处理,图像增强是主观的,因为必须符合后续应用的需要3.图像复原(Image restoration):图像复原与增强一样也是改进的图像外观,但图像复原是依据图像退化( image degradation)的数学模型或概率模型来进行的比较客观化的处理。 老猿补充说明:图像退化是图像在形成、记录、处理和传输过程中,由于成像系统、记录设备、传输介质和处理方法的不完善,导致图像质量的下降。图像复原是将图像退化的过程模型化,并据此采取相反的过程以得到原始的图像(保证噪声最小)4.彩色图像处理(Color image processing):对彩色图像基于彩色图像的模型和数字领域色彩处理的方式进行的处理5.小波变换(Wavelets):小波是以不同分辨率描述图像的基础,在本章节没有展开介绍,老猿拷贝一网上的介绍:小波变换是将图像信号分解为由原始小波位移和缩放之后的一组小波。小波在图像处理里被称为图像显微镜,原因在于它的多分辨率分解能力可以将图片信息一层一层分解剥离开来。剥离的手段就是通过低通和高通滤波器。6.图像压缩(Compression):用于节省存储和传输带宽的手段7.形态学处理(Morphological processing):形态学处理用于提取图像分量,可以参考《https://blog.csdn.net/LaoYuanPython/article/details/109556425 OpenCV-Python图像形态变换概述及morphologyEx函数介绍[1]》8.分割(Segmentation) :将图像划分为图像的组成部分或组成对象,分割越准确,后续的图像识别越成功9.表示与描述(Representation and description):表示确认将图像的数据确定为一个边界还是一个完整区域,选择一种表述仅是将原始数据转换成适合后续计算机处理的形式的一部分,描述又称为特征选择(feature selection),它是基于一些感兴趣的量化信息的结果或者不同对象彼此区分的基本特征的基础上进行的属性提取处理。10.识别(Recognition) :是基于一个图像对象的描述给其赋予一个标识的处理,如识别图像中的车辆。

对于以上步骤与本书的目录结构对应关系如下:冈萨雷斯《数字图像处理》学习总结及感悟:第一章 绪论 百闻不如一见

2.6、图像处理系统构成

冈萨雷斯《数字图像处理》学习总结及感悟:第一章 绪论 百闻不如一见

三、感想

作为全书的第一章,本章介绍了数字图像的概念、数字图像处理的起源、应用领域、研究范围、基本步骤和通用的系统构成。

阅读本章,老猿有如下一些杂乱的感想:

•首先使得我们了解了美国等国的先行者们比我们早了很多年进行数字图像处理,并且将其应用在广泛的领域,确实比我们领先了很多年,基础知识研究很杂实•数字图像的应用领域很宽广,在现代科技处理、国计民生中有不可替代的重要作用•本书写作质量真是非常的高,案例很丰富还非常贴近实际,作者的知识面和人脉都很广,光一个绪论就写得提纲挈领,内容详尽,不愧为经典•中译本整体翻译尚可,但有些细节还有待改善,但两个电子版对照来看,中译本的图像案例很多都比原版差很多,甚至差到影响对讲述内容的理解,因此就算不看原版文字,图像案例最好还是用原版的•数字图像处理需要学习的知识很多,笔者自己还没入门,还需要更多时间去学习, 加油!

四、部分术语英汉对照

除了在总结部分已经添加了中英文对照的术语外,将部分前面没有对照的重要术语在此列出,希望于大家有益:

•Digital Image Processing:数字图像处理•spatial (plane) coordinates:空间(平面)坐标•intensity:强度•gray level:灰度级、灰级、灰度值•amplitude:幅值、幅度•photon:光子•gamma ray:伽马射线•electromagnetic energy spectrum:电磁能谱•acoustic:声学•ultrasonic:超声波•electronic:电子•visual bands of the spectrum:可见光谱•Electromagnetic waves:电磁波•visual band:可见光波段•infrared band:红外波段

五、小结

本文简明扼要地归纳总结了冈萨雷斯《数字图像处理》第一章绪论涉及的基础知识,通过中英文对照方式对该章中译本翻译的知识进行了部分改善并以斜体字方式体现。通过对本章知识的总结,有助于各位与老猿相同基础的同好快速了解数字图像处理的基础概念、数字图像处理的起源、应用领域、研究范围、基本步骤和通用的系统构成等知识。同时通过部分关键术语的中英文对照,有助于提高阅读者的数字图像处理英语知识。

本文转转自微信公众号老猿Python原创https://mp.weixin.qq.com/s/XzDpTYV5wogihVdzr8vNrQ,如有侵权,请联系删除。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Karen110 Karen110
3年前
图像灰度与灰阶的纠结:gray level/scale译文释义
一、引言进行图像处理的人,对灰度一词一定非常熟悉,老猿以前没接触过图像基础知识,数学知识基本上也都忘光了,因此在自学OpenCVPython过程中遇到了很多困难。为了弥补基础知识的不足,特地下载了冈萨雷斯(RafaelC.Gonzalez)编著的《数字图像处理》(DigitalImageProcessing)第三版的中文译本和英文原本电子书对照学
Wesley13 Wesley13
3年前
4cast
4castpackageloadcsv.KumarAwanish发布:2020122117:43:04.501348作者:KumarAwanish作者邮箱:awanish00@gmail.com首页:
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这