人工智能——移动摄影技术

目录

      封面

1 .移动计算摄影简介

2.手机相机的硬件限制

2.1 传感器尺寸和镜头孔径

2.2 噪声和动态范围

2.3 景深

2.4 变焦

2.5 色彩欠采样

3 .相机图像处理流水线

3.1 相机传感器

3.2 相机流水线

5.拓展

1 .移动计算摄影简介

现代数字摄影的进度始终伴随着图像传感器和图像处理算法的发展。胶片摄影的时代从20世纪30年代开始,在近50年的时间里占据了整个摄影界的主导地位。第一台商用数码相机出现在90年代初,但其价格昂贵得让人望而却步,这些早期的设备当然也未能占据很大的市场。但在1993年引入的CMOS(互补金属氧化物半导体)图像传感器促进了所谓的“芯片上的相机”的发展,这种革命性的传感器使更便宜的设备成为可能。在之后的时间里,相机中的传感器、光学部件和软件算法等技术的进度,逐步提高了数字摄像机的成像质量。

2007年推出的iPhone是移动设备发展的分水岭,改变了手机和相机技术的发展历程。不过,早期的手机上的相机(或者称之为移动相机)还远不如当时任何价格可比的卡片相机。2010年是移动相机的关键,随着4G无线通信和高分辨率屏幕显示器的普及,使得用户能够在移动设备上欣赏到自己拍摄的照片,而且值得将照片分享给更多人。

一般的手机相机镜头筒非常小,捕捉到的所有图像都是扭曲的。对应现实世界,手机拍到的图像形状几乎都有偏差。大多数人可能不会注意到或在意这一点,因为他们已经习惯了 Instagram 上的自拍。但如果能改善这些畸变就好了。

iPhone 和其他相机将越来越多地搭载带有 3D 传感器的后置摄像头。这些传感器由鲁门特姆控股(Lumentum Holdings)和其他芯片供应商等公司制造,通过计算发出光束从物体上反射回来的时间来测量手机周围环境的深度。“飞行时间法”(time-of-flight)等技术可以让手机详细测量周围环境的三维结构。

2.手机相机的硬件限制

理想情况下,智能手机相机将提供与单反相机相同的摄影性能。然而,智能手机相机有几个显著的缺点,因为它首要地要被集成在手机的狭小空间里。下图显示了一个手机相机与一个典型的单反相机优缺点对比。

手机相机的图像传感器和镜头都明显比单反相机上的要小。然而,虽然智能手机的物理硬件是被限制的,但智能手机可以获得比单反更多的计算能力。简单来说,与典型的单反相机相比,手机相机的镜头进光量要比单反镜头的进光量低两个数量级;与此同时,手机相机拥有大约高两个数量级的计算能力。因此,在手机相机上对有着更多限制的成像硬件进行额外的算法处理是不可避免的。接下来,我们简要介绍手机相机的几个关键限制。

2.1 传感器尺寸和镜头孔径

智能手机相机最明显的限制是其传感器和光学镜头的尺寸。现代智能手机传感器的尺寸约为5x4毫米,而许多单反相机使用全画幅36x24毫米的传感器。除了传感器尺寸较小外,与单反相机上使用的镜头相比,手机相机的光学镜头要小得多,可调节性也较小。因此,绝大多数手机相机使用固定孔径和固定焦距的光学镜头,这便导致许多手机厂商不得不使用两个或多个不同焦距的相机,以达到满足各种不同场景的使用需求。

2.2 噪声和动态范围

图像噪声可以定义为图像像素强度的不必要的随机变化。除了由于电子中的热振动引起的随机波动外,另一个不可避免的噪声(散粒噪声)则是由光的离散性质引起。在较小的光学孔径和传感器尺寸下,智能手机相机获得进光量和达到传感器表面的光量远小于单反相机。因此,智能手机相机通常需要对信号进行更高的增益放大。这种增益通过ISO控制来实现,但更高的增益也会引入更大的噪声。因此,在传感器上产生的智能手机相机图像噪声明显比用DSLR传感器捕获的图像噪声更加明显。

动态范围的定义为像素光电二极管在最大增益下的满阱电荷与其读噪声的比值。满阱电荷很大程度上取决于像素大小,因此动态范围也与像素大小直接相关。单反相机的像素尺寸约为4微米,而智能手机相机像素的尺寸则是1.5微米或更小。智能手机相机具有小得多的满阱电荷,因此能在每个光电二极管上产生的电流也大幅减少。因此,单反相机可以有效地将像素量化为 4096(12位)到16384(14位)数值。而典型的智能手机相机传感器仅限于每像素1024(10位)的像素值。

2.3 景深

景深(DoF)定义了能够清晰成像的物体的距离范围。景深可以通过相机的焦距和光圈来控制。光圈越大,景深越浅。在摄影中,如果我们要特别的拍摄人物肖像,通常希望系统有一个狭窄的景深,在对人物清晰成像的同时模糊背景。手机相机的光圈小,景深比较大,无法达到拍摄人像时背景有很好的模糊效果。为了克服这一问题,大多数智能手机现在提供了一个人造的背景模糊功能,被称为数字bokeh。

2.4 变焦

为了满足消费者的需求,智能手机的设计趋向于越来越薄。这种设计严重限制了智能手机相机的厚度也限制镜头的有效焦距,从而限制了手机相机的光学变焦能力。为了克服这个问题,现代智能手机厂家通常采用具有不同焦距和视野的多个相机模组的组合方案,使手机相机整体的变焦能力能从超广角到超长焦范围内进行变焦。另外,在光学设计中通过折叠设计来有效焦距,以突破相机厚度有限带来的对焦距和变焦能力的限制。

2.5 色彩欠采样

无论是智能手机相机还是单反相机,图像传感器的每个像素上都会有一个色彩滤波片,如下图所示。这类似于人眼有三类不同的锥细胞,分别用来感知短波长、中波长或长波长的光。当然,无论对于任何相机,最终目标都是每个像素要全包含RGB三个颜色值。因此,图像处理时便需要一个插值过程(称为demoasic)来将传感器的欠采样色彩信息转换为每个像素都具有RGB三通道色彩值的图像。此外,图像传感器上使用的RGB颜色阵列与基于人眼感知的CIE XYZ色彩空间并不完全对应。因此,相机拍摄图像的色彩的丰富程度往往也是有限的,并且与其所使用的颜色阵列滤波片强相关。

3 .相机图像处理流水线

从图像传感器输出的数据,经过我们称之为流水线的一系列处理步骤,最终生成适于人眼观看的或者高质量的“照片”。相机系统有一个专用芯片,称为图像信号处理器(ISP),它在毫秒级时间范围内对每幅图像执行上述图像处理流水线。

3.1 相机传感器

我们首先来了解下图像传感器。摄像机传感器由按二维网格排布的光电二极管组成。光电二极管将光信号转化为电子。一个光电二极管通常对应着图像中的单个像素。为了产生彩色图像,光电二极管上会被放置RGB颜色滤波片。一种典型的颜色滤波阵列(CFA)排列为拜耳图案,如上图所示的放置在传感器顶部的彩色瓷砖的马赛克。相机图像处理流水线中的一个关键步骤是通过根据周围像素的RGB颜色对每个像素的RGB值进行插值来进行demosaic。对RGB光的感应能力与特定传感器的制造和模型相关。因此,相机图像处理流水线中的一个关键步骤是将传感器的RGB值转换为与设备无关的感知颜色空间。直接从传感器输出马赛克格式的图像通常被成为拜耳图像或拜耳帧,或者简单地称之为RAW图。

3.2 相机流水线

上图是一个典型的相机图像处理流水线的具体实现步骤。这里面的许多步骤对于不同的ISP厂家都有特定的实现算法。当然即使使用相同的ISP硬件,两个不同的相机厂家也会由于调整和修改ISP中的相关参数和算法,而产生出完全不同风格和质量的图像。流水线中每个处理步骤的作用如下:

传感器原始图像获取:当前一帧的原始图像传递给ISP时,相机会根据场景亮度、所需的快门速度和光圈,调整ISO增益因子,之后光信号被转换为电信号输出拜耳图像。传感器的拜耳图像被认为是未处理的图像,通常被称为原始图像。拜耳图像每个像素位置有且仅有R或G或B值。这些原始RGB值对应颜色滤波阵列对光谱的灵敏度,而不是直接对应人眼感知的颜色空间。

原始图像预处理: 原始传感器图像通常会被归一化到0至1 。许多相机都有一个叫黑电平的参数用以表示最小的像素值。按说在无光环境下,传感器输出的像素值应该是0,但实际上由于传感器的某些特性,此时输出的像素值是一个很小的值,这个值就是黑电平。黑电平跟传感器的特性相关,同时摄像头ISO和增益这些设置也会影响黑电平的值。在图像处理流水线中,黑电平首先要从原始图像中减去,同时我们也能获得一个与黑电平对应的白电平,表示像素的最大值。如果没有其他特殊的处理,减去黑电平后图像的最小值和最大值会被归一化到0至1。

预处理阶段还纠正传感器上的缺陷像素。缺陷像素在生产的时候会被预校准并被标记所在的位置。始终输出高像素值(热像素)或零值(死像素/坏点)均被称为缺陷像素。缺陷像素可以通过使用它们相邻像素点的值进行插值修复。

随后,镜头阴影矫正(LSC, Lens Shading Correction)会被用来纠正由于达到传感器的光线不均匀导致的图像亮度不均匀的影响。下图展示了经过LSC之前,相机实际捕获的图像。到达传感器的光线从中心到边缘会逐渐减少,导致亮度也逐渐降低。具有径向校正属性的LSC被用来纠正这种亮度非均匀降低的问题。LSC参数一般由镜头厂家预先标定,在实际使用中再根据不同场景亮度,增益水平和用于白平衡的估计场景光照进行轻微调整即可。

去马赛克:去马赛克算法将单通道原始图像转换为三通道全尺寸RGB图像。去马赛克时每个像素缺失的色彩值会根据CFA中相邻像素中对应的色彩值进行插值获得。下图是去马赛克过程的一个示例。下图中我们需要估计出放大部分的一个红色像素点的绿色和蓝色的颜色值。以估计绿色颜色值为例,我们首先根据相邻红色像素值与待估计红色像素值的相似性,计算出所有相邻像素点的权重值;再结合权重值与相邻绿色像素值通过插值估算出待求像素的绿色颜色值。在这个过程中使用权重掩码有助于避免场景边缘的模糊问题。下图只是一种简单和通用的方法,而大多数去马赛克算法都是其独特性。去马赛克算法通常也执行高亮值的裁剪、锐化和一些初始的降噪等操作。

白平衡:白平衡是为了模仿人类视觉系统对不同场景光照能够自动适应颜色的能力而进行的。白平衡常被称为类似人类视觉系统的颜色恒常性。简单来说,颜色恒常性说的是白色的物体无论在日光下,还是霓虹灯环境下,人类视觉系统均会将其认为为白色物体。白平衡需要估计传感器的RGB颜色滤波器对场景光照的响应。这种响应可以通过记录传感器对常见照明(例如日光、白炽灯和荧光等)光谱的响应来在工厂中进行预标定。这些预标定的结果通常会作为白平衡预设的光照环境供用户选择。一种更常见的选择是使用相机自身的自动白平衡(AWB)算法,该算法直接从获取的图像中估计传感器对光照环境的RGB响应。下图说明了一个典型的白平衡处理过程。

无论是通过预设还是AWB功能,一旦得到在当前场景光照下传感器的RGB值,我们便可以将每个颜色通道所有的像素值除以其对应的RGB光照值来对图像进行调整。

色彩空间变换:经过白平衡处理后,图像仍处于传感器相关的RGB色彩空间中。色彩空间变换将图像从与传感器相关的RAW域RGB色彩空间转换为与设备无关的感知色彩空间,其能够与CIE 1931 XYZ色彩空间建立直接的联系。部分相机使用宽色域的ProPhoto RGB色彩空间,它能够显示出90%以上能被人眼感知的色

色彩处理:图像处于感知色彩空间后,相机就可以使用专用的色彩处理的方式来增加图像的视觉美感。在单反相机上,用户在选择照片风格(如生动,景物,肖像和标准等)时,便是在进行色彩处理,每种风格对应着不同的色彩处理方式。色彩处理通常会通过一个3D查找表(3D LUT)将输入的ProPhoto RGB值映射到所希望的色彩空间RGB值。下图是一个典型的色彩处理的过程,其中也包括一个1D LUT的色调映射。有时色彩处理会被用于特定的一些色彩用于增强皮肤的色调。建立3D LUT是一个很耗时的工作,通常由比较有经验的ISP调试专家来完成。针对不同地域用户的喜好,相机厂家经常会使用不同的色彩处理参数。例如,亚洲和拉丁美洲的用户比欧洲和北美的用户更偏向生动风格的图片。

色调映射:色调映射是一个应用于各个颜色通道,调整图像色调值的1D LUT。色调映射有两个目的。一个是与色彩处理一起调整图片的美学表现,通常通过提升对比度的方式来进行。另一个是将RAW域RGB的10-14bit的像素值压缩到8-10bit的大小。这种调整类似于人眼对不同场景亮度的适应能力。下图是一个典型的1D LUT的色调映射过程。

降噪:降噪算法是提升图片的视觉观感质量的一个关键措施。对图像降噪的时候,要控制好图像噪声与图像细节的平衡。过大幅度的降噪将会导致图像模糊,但过小幅度的降噪则无法有效地去除视觉上的噪声观感。降噪算法通常要考虑多个因素,包括图像的ISO增益和曝光设置。有些ISP流水线会将降噪放在色彩空间变换之后,有些会放在其之前,也有在色彩空间变换前后都进行降噪处理的。ISP通常会提供多种降噪算法供相机厂家选择使用。

输出色彩空间变换:经过前面一系列的处理流程,图像的RGB值此时对应一个广色域的ProPhoto色彩空间。然而,现代显示设备只能产生有限的颜色范围。因此,广色域图像还需被转换为适应显示设备的窄色域图像。最常见的色彩空间是标准RGB(sRGB)。AdobeRGB和Display-P3 ,有时也会被使用。输出色彩空间变换通常使用叫做“Gamma”的色彩映射操作,它通常是一个幂律函数,目的是把广色域的像素值转变为与设备的显示曲线匹配的像素值。

5.拓展:

去年,德国慕尼黑工业大学(Technical University of Munich)和佳能公司(Canon, Inc.)的研究人员表示,用一张图片就可以推断出被另一个物体遮挡的场景中有什么。它被称为“分层深度图像”,可以通过从照片中删除一个对象来创建新的场景,显示相机从未见过的背景,但这是通过图像计算得到的。该方法使用了许多神经网络应用中常见的编码-解码器方法来估计场景的深度,以及“生成对抗网络”(GAN)来构造场景中在拍摄照片时从未实际出现在视野中的部分。

各种新的研究在不断涌现,并将在下一代配备 3D 传感器的智能手机相机上呈现井喷之势。这些研究将会带来惊人的成果。通过平衡镜头上的线条畸变创建出平行线,我们可能会得到超分辨率的建筑图片。

未来,在推进机器学习技术之路,还会经历一个意义重大的阶段。我们有可能放弃使用三维传感器,仅用卷积神经网络(CNN)来推断物体在空间中的坐标。这将节省在手机中安装传感器的费用。

注:本文所有内容来自网络查阅学习,受益非凡。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/308844.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iPhone 13 Pro 更换『移植电芯』和『超容电池』体验

文章目录 考虑换电池Ⅰ 方案一Ⅱ 方案二 总结危险 Note系列地址 简 述: 首发买的iPhone 13P &#xff08;2021.09&#xff09;&#xff0c;随性使用一年出头&#xff0c;容量就暴跌 85%&#xff0c;对比朋友一起买的同款&#xff0c;还是95%。这已经基本得一天两充 >_<&a…

命令模式-举例

开关和电灯之间并不存在直接耦合关系&#xff0c;在命令模式中&#xff0c;发送者与接收者之间引入了新的命令对象&#xff0c;将发送者的请求封装在命令对象中&#xff0c;再通过命令对象来调用接收者的方法。 命令模式的主要缺点如下&#xff1a; 使用命令模式可能会导致某…

[足式机器人]Part4 南科大高等机器人控制课 CH12 Robotic Motion Control

本文仅供学习使用 本文参考&#xff1a; B站&#xff1a;CLEAR_LAB 笔者带更新-运动学 课程主讲教师&#xff1a; Prof. Wei Zhang 课程链接 &#xff1a; https://www.wzhanglab.site/teaching/mee-5114-advanced-control-for-robotics/ 南科大高等机器人控制课 Ch12 Robotic …

m3u8网络视频文件下载方法

在windows下&#xff0c;使用命令行cmd的命令下载m3u8视频文件并保存为mp4文件。 1.下载ffmpeg&#xff0c;访问FFmpeg官方网站&#xff1a;https://www.ffmpeg.org/进行下载 ffmpeg下载&#xff0c;安装&#xff0c;操作说明 https://blog.csdn.net/m0_53157282/article/det…

scanf函数返回值占位符详解,%*,%[]的应用

前言 scanf函数可以说是我们一开始就会接触的函数了&#xff0c;但在最近复习时我又找到而来一些之前不甚了解或是块要遗忘的知识&#xff0c;特作此篇。 一.返回值 我们之前提到了scanf返回值被忽略的问题&#xff1a; scanf函数返回值被忽略-CSDN博客 那么scanf的返回值…

PIC项目(9)——基于PIC16F877A的环境光照检测系统

1.课题背景 近年来&#xff0c;城市光污染问题逐渐显现。白天&#xff0c;玻璃幕墙、釉面砖墙、磨光大理石和各种涂料等装饰反射光线&#xff0c;明晃刺眼&#xff1b;夜晚&#xff0c;商场、酒店、超市楼顶的广告牌、电子屏、霓虹灯炫烂夺目。面对这样的光污染&#xff0c;人们…

关于Omlox定位标准(一)——omlox hub

关于Omlox定位标准 Omlox是世界上第一个开放的定位标准&#xff0c;旨在实现灵活的实时定位解决方案&#xff0c;&#xff0c;可以使用来自各个制造商的单元。“omlox"一词源自拉丁词汇"omni”&#xff08;无处不在&#xff09;和"locus"&#xff08;位置…

使用element中el-cascader级联选择器动态懒加载以及回显 (单选)

<template><!-- 新增||修改弹框 --><el-dialog :close-on-click-modal"false" :close-on-press-escape"false" :title"title" :visible.sync"open"width"800px" append-to-body><el-form ref"for…

仓库申请报错:Cannot access gated repo for url https://huggingface.co/api

这个报错主要是使用huggingface里面的仓库的模型或其他文件需要提供访问权利&#xff0c; 1.需要有自己的huggingface账号&#xff08;没有则创建&#xff09; 2.右上角点进个人中心&#xff0c;然后找到Access Tokens&#xff0c; 3.设置新的或者Tokens&#xff0c;设置为读…

Linux之缓冲区的理解

目录 一、问题引入 二、缓冲区 1、什么是缓冲区 2、刷新策略 3、缓冲区由谁提供 4、重看问题 三、缓冲区的简单实现 一、问题引入 我们先来看看下面的代码&#xff1a;我们使用了C语言接口和系统调用接口来进行文件操作。在代码的最后&#xff0c;我们还使用fork函数创建…

牛客网面试题知识点记录-02

1.collection接口 2.在构造方法中调用方法A,若方法A被子类重写&#xff0c;则会先调用子类的方法A。举例如下题&#xff1a; 此时会输出null&#xff0c;调用顺序为&#xff1a;子类初始化&#xff0c;但是子类实现了Base&#xff0c;会先执行Base的构造方法&#xff0c;构造…

【C语言数组传参】规则详解

目录 数组传参介绍 数组传参规则 数组传参的实参 特殊情况一&#xff1a;sizeof&#xff08;数组名&#xff09; 特殊情况二&#xff1a;&数组名 数组传参的形参 数组传参使用数组名作为形参接收 形参如果是⼀维数组 形参如果是⼆维数组 数组传参使用指针作为形参…