资料介绍
这篇文章是我从事ISP研究数年来的一些经验总结,没有用到深奥的理论知识,有的只是根据实际状况来处理的一些常规方法,以及曾经犯过的错误总结。我想把ISP function的原理用简单浅显的语言描述出来,希望对初学者有所帮助。这里的ISP主要是指从CMOS sensor输出的bayer pattern,到转换成通用的YUV或者YCbCr格式的过程,通常用于USB摄像头/监控摄像头/手机/平板等芯片设计中。
在IC设计中,受限于处理速度,像素级的ISP算法都相对简单,只会用到加/减/乘/比较等基本运算,通常不会用到除法、指数、对数、平方根、三角函数等复杂运算。以1080p 30fps的视频为例,像素处理速度为1080*1920*30=62M pixel/s,每个pixel都需要非常多的基本运算,用pipeline的方式实现连续高速计算。像除法,指数运算或者三角函数,则较多的时钟周期才能完成一次计算,因此不适用于ISP的像素级处理,在算法设计中要尽量避免这些复杂运算。ISP中也有针对整幅图像处理的运算(非像素级),例如白平衡AWB,自动曝光AE和自动对焦AF,这些算法比较灵活,处理速度要求不高,通常由CPU来处理的,任何复杂运算都可以用,只要CPU性能足够。
研究ISP算法是一件充满乐趣的事情,原因在于ISP算法没有标准答案,任何ISP算法都没有一个标准协议,每个人都可以自由发挥自己的想象力,目的只有一个,让人眼看得舒服,大家看着好,才是真的好。每个人的想象力各不相同,算法复杂度也是无穷尽,评价ISP算法的优劣,主要就是一个性价比:在一定复杂度要求的条件下,达到最好的图像质量。在学习ISP相关的paper的时候,要关注的重点是算法的原理,或者说出发点,而不是计算公式,因为公式中通常都是复杂运算,难以实际用起来,在理解了原理之后,可以找近似的替代算法来达到相近的效果。
从视觉感受来分,我把ISP大致分成亮度,色彩和细节三个部分。亮度是指对图像整体的亮度调整,涉及到的算法有自动曝光Auto Exposure,黑电平校正Black Level Correction,镜头阴影校正Lens Shading Correction,Gamma,High Dynamic Ranger等。涉及到色彩的有白平衡Auto White Balance,色彩校正Color Correction Matrix,饱和度Saturation,色相Hue等。细节的算法主要的去噪Denoise,插值interpolation,缩放zoom,边缘增强edge enhance等。还有一些其他相对特殊的算法,例如自动对焦Auto Focus,防闪烁anti-flick等。一个简化的ISP算法框架如下图。
Figure 0.1 ISP简单框架
ISP各个基本算法是相对独立的,但是在整体效果呈现上,又是相互关联的。举例来说,Lens Shading Correction这个算法把要图像四周的拉亮,这就导致图像四周的Noise比较大, 而Noise较大的话,edge enhance就要对四周的像素做特殊处理,使得Noise不会被放大,这会导致图像中心相对清晰,四周相对模糊。经常调校ISP的人,对此可能深有体会。诸多ISP算法模块,内在是有一些确定的逻辑关系的,上图中的框架结构,有些顺序是可以改变,有些则不可以改变, 有些改变会导致算法复杂度提升。ISP算法中有不少特性是相互对立矛盾的,例如清晰度和噪声,AWB中的稳定度和精确度,AE中的收敛稳定性和收敛速度等,这些对立的特性,就像天平的两端,需要根据客户需求或者实际应用场景去做平衡。
对ISP的研究学习过程,既有符合构想预期的情况,也有充满意外的时候,同时感叹一下人眼或者说人脑的高复杂度和高灵敏度。ISP的各种数学运算,最终是要让CMOS sensor感应到的图像,转化模拟成人眼/人脑感受到的图像,通过不断的学习和尝试,让各种ISP模块中的数学计算,能够得出期望的图像效果,或者从图像效果反推出算法中的原因所在。一个有经验的ISP算法研究工程师,就是建立起数学计算和图像效果之间的映射关系。
接下来,我将从图像format开始,然后再从图像亮度,色彩和细节三个方面来一一介绍ISP中各个function。
在IC设计中,受限于处理速度,像素级的ISP算法都相对简单,只会用到加/减/乘/比较等基本运算,通常不会用到除法、指数、对数、平方根、三角函数等复杂运算。以1080p 30fps的视频为例,像素处理速度为1080*1920*30=62M pixel/s,每个pixel都需要非常多的基本运算,用pipeline的方式实现连续高速计算。像除法,指数运算或者三角函数,则较多的时钟周期才能完成一次计算,因此不适用于ISP的像素级处理,在算法设计中要尽量避免这些复杂运算。ISP中也有针对整幅图像处理的运算(非像素级),例如白平衡AWB,自动曝光AE和自动对焦AF,这些算法比较灵活,处理速度要求不高,通常由CPU来处理的,任何复杂运算都可以用,只要CPU性能足够。
研究ISP算法是一件充满乐趣的事情,原因在于ISP算法没有标准答案,任何ISP算法都没有一个标准协议,每个人都可以自由发挥自己的想象力,目的只有一个,让人眼看得舒服,大家看着好,才是真的好。每个人的想象力各不相同,算法复杂度也是无穷尽,评价ISP算法的优劣,主要就是一个性价比:在一定复杂度要求的条件下,达到最好的图像质量。在学习ISP相关的paper的时候,要关注的重点是算法的原理,或者说出发点,而不是计算公式,因为公式中通常都是复杂运算,难以实际用起来,在理解了原理之后,可以找近似的替代算法来达到相近的效果。
从视觉感受来分,我把ISP大致分成亮度,色彩和细节三个部分。亮度是指对图像整体的亮度调整,涉及到的算法有自动曝光Auto Exposure,黑电平校正Black Level Correction,镜头阴影校正Lens Shading Correction,Gamma,High Dynamic Ranger等。涉及到色彩的有白平衡Auto White Balance,色彩校正Color Correction Matrix,饱和度Saturation,色相Hue等。细节的算法主要的去噪Denoise,插值interpolation,缩放zoom,边缘增强edge enhance等。还有一些其他相对特殊的算法,例如自动对焦Auto Focus,防闪烁anti-flick等。一个简化的ISP算法框架如下图。
Figure 0.1 ISP简单框架
ISP各个基本算法是相对独立的,但是在整体效果呈现上,又是相互关联的。举例来说,Lens Shading Correction这个算法把要图像四周的拉亮,这就导致图像四周的Noise比较大, 而Noise较大的话,edge enhance就要对四周的像素做特殊处理,使得Noise不会被放大,这会导致图像中心相对清晰,四周相对模糊。经常调校ISP的人,对此可能深有体会。诸多ISP算法模块,内在是有一些确定的逻辑关系的,上图中的框架结构,有些顺序是可以改变,有些则不可以改变, 有些改变会导致算法复杂度提升。ISP算法中有不少特性是相互对立矛盾的,例如清晰度和噪声,AWB中的稳定度和精确度,AE中的收敛稳定性和收敛速度等,这些对立的特性,就像天平的两端,需要根据客户需求或者实际应用场景去做平衡。
对ISP的研究学习过程,既有符合构想预期的情况,也有充满意外的时候,同时感叹一下人眼或者说人脑的高复杂度和高灵敏度。ISP的各种数学运算,最终是要让CMOS sensor感应到的图像,转化模拟成人眼/人脑感受到的图像,通过不断的学习和尝试,让各种ISP模块中的数学计算,能够得出期望的图像效果,或者从图像效果反推出算法中的原因所在。一个有经验的ISP算法研究工程师,就是建立起数学计算和图像效果之间的映射关系。
接下来,我将从图像format开始,然后再从图像亮度,色彩和细节三个方面来一一介绍ISP中各个function。
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- 揭开高性能多路复用数据采集系统面纱
- 揭开医疗警报设计的神秘面纱,第1部分:IEC60601-1-8标准要求
- 揭开运放电路神秘面纱:如何选型运放?
- 数字信号处理-时域离散随机信号处理 35次下载
- 基于FPGA和DSP的机载图形显示系统 36次下载
- AN40-揭开开关电容器过滤的神秘面纱
- MT-001: 揭开公式(SNR = 6.02N + 1.76dB)的神秘面纱
- Matlab图形处理的函数详细资料说明 6次下载
- MATLAB的图形处理多个实用程序实例免费下载 15次下载
- 如何从Linux中探讨Ⅵ编辑器的教学问题 9次下载
- 基于DirectFB和Cairo的图形处理 2次下载
- 一文看懂DDR布线背后的大学问 0次下载
- 南京邮电大学数字信号处理大纲 0次下载
- 南京邮电大学考研数字信号处理真题 7次下载
- 图形处理器的流执行模型
- 信号分析和信号处理必须遵循的原则 544次阅读
- 信号分析和信号处理的基本方法有哪些 1469次阅读
- 信号分析和信号处理的区别 444次阅读
- 图形均衡器电路图分享 5139次阅读
- 开关背后隐藏着的学问 290次阅读
- 一颗8位的51单片机是如何处理32位数据的? 1632次阅读
- GPU在雷达信号处理算法中的优势 820次阅读
- 雷达信号处理:FPGA还是GPU? 1944次阅读
- 基于TS101S芯片实现雷达信号处理系统的应用设计 2494次阅读
- 浅谈差分处理和信号分析 1967次阅读
- 揭开天线的面纱,剥开天线的外衣 5266次阅读
- 图形处理器在电脑上的哪个地方 1.5w次阅读
- 揭开Zynq Z-7000从SPI接口挂载的flash启动的神秘面纱 1.4w次阅读
- 图形处理器和显卡什么区别和联系 2.6w次阅读
- 揭开实时以太网神秘的面纱 1590次阅读
下载排行
本周
- 1电子电路原理第七版PDF电子教材免费下载
- 0.00 MB | 1490次下载 | 免费
- 2单片机典型实例介绍
- 18.19 MB | 93次下载 | 1 积分
- 3S7-200PLC编程实例详细资料
- 1.17 MB | 27次下载 | 1 积分
- 4笔记本电脑主板的元件识别和讲解说明
- 4.28 MB | 18次下载 | 4 积分
- 5开关电源原理及各功能电路详解
- 0.38 MB | 10次下载 | 免费
- 6基于AT89C2051/4051单片机编程器的实验
- 0.11 MB | 4次下载 | 免费
- 7基于单片机和 SG3525的程控开关电源设计
- 0.23 MB | 3次下载 | 免费
- 8基于单片机的红外风扇遥控
- 0.23 MB | 3次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 2PADS 9.0 2009最新版 -下载
- 0.00 MB | 66304次下载 | 免费
- 3protel99下载protel99软件下载(中文版)
- 0.00 MB | 51209次下载 | 免费
- 4LabView 8.0 专业版下载 (3CD完整版)
- 0.00 MB | 51043次下载 | 免费
- 5555集成电路应用800例(新编版)
- 0.00 MB | 33562次下载 | 免费
- 6接口电路图大全
- 未知 | 30320次下载 | 免费
- 7Multisim 10下载Multisim 10 中文版
- 0.00 MB | 28588次下载 | 免费
- 8开关电源设计实例指南
- 未知 | 21539次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935053次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537791次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420026次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233046次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191183次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183277次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138039次下载 | 免费
评论
查看更多