当前位置: 首页 > news >正文

ISP Pipeline

系列文章目录


文章目录

  • 系列文章目录
  • 前言
  • 一、RAW域
  • 二、RGB域
  • 三、YUV域
  • 总结


前言


一、RAW域

  1. 黑电平校正(BLC)
  2. 数字增益调整(DGain)
  3. 自动白平衡(AWB)
  4. 局部色调映射(LTM)
  5. 坏点修复(DPC)
  6. 几何色差校正(GCAC)
  7. 去马赛克(Demosaic)

1电平校正(BLC - Black Level Correction)
通过对传感器输出的 RAW 数据进行黑电平校正,去除图像传感器带来的固定偏移噪声。

主要目的是消除传感器的偏置电压,确保图像的暗部细节正常。
2. 数字增益调整(DGain - Digital Gain)
对经过黑电平校正后的图像应用数字增益,特别是在低光环境中可以增强图像亮度。

此增益用于提高传感器的响应,放大图像信号,但同时会放大噪声。
3.自动白平衡(AWB - Auto White Balance)
根据图像的颜色信息调整红、绿、蓝三个通道的增益,使图像中白色的显示更加自然。
调整每个颜色通道的增益来平衡颜色,确保图像的色彩呈现准确。
4局部色调映射(LTM - Local Tone Mapping)
根据局部亮度对图像进行色调映射,提升图像的动态范围,增加亮部和暗部细节的表现。

主要用于增强图像对比度,改善局部区域的亮度。
5.坏点修复(DPC - Defective Pixel Correction)
修复传感器中的坏点(如死亡像素),通过邻近像素的插值填充坏点。

目的是去除图像中由于传感器缺陷引起的黑点或亮点。
6.几何色差校正(GCAC - Geometrical Chromatic Aberration Correction)
校正镜头引入的色差,特别是图像边缘区域的色彩错位现象。

校正因镜头光学特性引入的色彩不对齐问题,避免图像边缘模糊和色彩失真。
7.去马赛克(Demosaic)
将 Bayer 格式的图像数据转换为完整的 RGB 图像。Bayer 格式中每个像素只有一种颜色,通过去马赛克算法填充其他颜色的信息。

这是将原始的单通道 Bayer 图像数据转换为 RGB 三通道数据的关键步骤。

二、RGB域

颜色校正矩阵(CCM)
(可选)伽马校正
(可选)RGB 去噪与抖动处理
(可选)去雾处理

1. 颜色校正矩阵(CCM - Color Correction Matrix)

颜色校正矩阵用于修正由于传感器色彩响应不一致导致的颜色失真。通过应用一个 3x3 的颜色转换矩阵,将图像中的红、绿、蓝通道进行线性变换,使得图像的颜色更加准确。
这一步通常在 RGB 数据生成后立即应用,以确保图像的色彩更贴近自然真实的场景。

2. (可选)伽马校正(Gamma Correction)

伽马校正用于调整图像的亮度响应曲线,使图像在显示设备上呈现出更自然的亮度分布。人眼对亮度的感知是非线性的,伽马校正通过对亮度的非线性调整,增强图像的亮暗对比,避免过亮或过暗的区域丢失细节。
伽马校正是一个可选步骤,根据具体的应用需求,是否需要进行亮度调整。

RGB域的处理顺序通常是在生成 RGB 数据后立即进行的颜色校正矩阵(CCM),然后可以选择性地应用伽马校正、去噪、抖动和去雾处理。这些步骤旨在提高图像的色彩准确性、对比度和清晰度,确保图像在显示设备上呈现出最佳效果。

3. (可选)RGB 去噪与抖动处理(RGB Dithering and Noise Reduction)

这一步通常包括对图像进行去噪处理,以及在量化过程中加入抖动处理以避免色带现象。抖动处理通过在颜色量化中加入小的随机噪声,平滑色阶过渡区域,减少量化引起的视觉失真。
去噪处理会减少图像中的随机噪声,使图像更加干净

4. (可选)去雾处理(Dehaze)

去雾处理用于提升在有雾霾或大气散射影响下的图像对比度。该步骤可以通过分析图像的亮度直方图,增强图像的局部对比度,改善在远景或恶劣天气下的视觉效果。
去雾处理可选用于特定场景需求,比如户外或者监控系统中。

三、YUV域

颜色空间转换(CSC)
对比度提升与缩放(CDS)
锐化处理(Sharpen)
YUV 3D 降噪(YUV 3DNR)
图像缩放(Scaling)
YUV 抖动处理(YUV Dithering)

1. 颜色空间转换(CSC - Color Space Conversion)

将 RGB 颜色空间转换为 YUV 颜色空间。这是 YUV 处理的第一步,RGB 三个通道分别表示红、绿、蓝的颜色信息,而 YUV 则将亮度(Y)和色度(U、V)分离开来,更适合用于压缩与传输。
颜色空间转换的主要目的是为了兼顾压缩效率和视觉效果,YUV 格式在视频传输中应用广泛。

2. 对比度提升与缩放(CDS - Contrast Enhancement and Scaling)

在此步骤中,图像会进行对比度调整,提升亮暗对比,使得细节更加明显。此外,该步骤还可能包含缩放操作,将图像调整到目标分辨率。
对比度调整能够增强图像的视觉冲击力,提升暗部和亮部区域的细节表现。
缩放是为了匹配后续处理或显示需求。

3. 锐化处理(Sharpen)

在此步骤中,图像的边缘细节会被增强,使得图像看起来更加清晰。锐化处理通过增强边缘的对比度,使边界更加分明,提升图像的清晰度。
这一步常用于减少图像模糊,尤其是在缩放后,细节可能会丢失或变得模糊。

4. YUV 3D 降噪(YUV 3DNR - 3D Noise Reduction)

这是降噪操作,通常在视频处理中使用,通过结合时域和空间域的信息来去除图像噪声。YUV 3DNR 处理会综合多个帧的信息,减少噪声同时保持运动区域的清晰度。
该步骤特别适合减少视频帧中的动态噪声,以及在多帧图像中去除随时间变化的噪声。

5. 图像缩放(Scaling)

对图像进行多分辨率缩放,生成不同尺寸的 YUV 图像,以满足不同的应用场景。这一步根据需求缩小或放大图像。
缩放处理可以生成适用于不同设备的图像,例如为高分辨率屏幕提供高清图像,也可以为低分辨率设备生成小尺寸图像。

6. YUV 抖动处理(YUV Dithering)

抖动处理通过在颜色量化过程中加入噪声,以减少色彩量化导致的颜色带现象。此步骤将颜色转换过程中可能出现的平滑区域进行处理,使色彩过渡更加自然。
抖动处理对于图像和视频的视觉质量非常重要,尤其是在低位深度的色彩空间中。


总结

  1. 黑电平校正(BLC)
  2. 数字增益调整(DGain)
  3. 自动白平衡(AWB)
  4. 局部色调映射(LTM)
  5. 坏点修复(DPC)
  6. 几何色差校正(GCAC)
  7. 去马赛克(Demosaic)
  8. 颜色校正矩阵(CCM)
  9. (可选)伽马校正
  10. (可选)RGB 去噪与抖动处理
  11. (可选)去雾处理
  12. 颜色空间转换(CSC)
  13. 对比度提升与缩放(CDS)
  14. 锐化处理(Sharpen)
  15. YUV 3D 降噪(YUV 3DNR)
  16. 图像缩放(Scaling)
  17. YUV 抖动处理(YUV Dithering)

相关文章:

ISP Pipeline

系列文章目录 文章目录 系列文章目录前言一、RAW域二、RGB域三、YUV域总结 前言 一、RAW域 黑电平校正(BLC)数字增益调整(DGain)自动白平衡(AWB)局部色调映射(LTM)坏点修复&#xf…...

< IDE编程环境配置>

IDE编程环境配置 LIB,DLL区别 我们在写项目时会链接(调用)第3方库,或者比如在vs的解决方案solution创建项目project时,不仅可以开发可执行程序exe(可单独运行)(windows/控制台 应用…...

Golang | Leetcode Golang题解之第448题找到所有数组中消失的数字

题目&#xff1a; 题解&#xff1a; func findDisappearedNumbers(nums []int) (ans []int) {n : len(nums)for _, v : range nums {v (v - 1) % nnums[v] n}for i, v : range nums {if v < n {ans append(ans, i1)}}return }...

【Spring Boot 入门三】Spring Boot与数据库集成 - 构建数据驱动的应用

一、引言 在之前的文章中&#xff0c;我们已经对Spring Boot有了初步的认识&#xff0c;了解了如何构建第一个Spring Boot应用&#xff0c;以及如何通过配置文件来掌控应用的设置。这些知识为我们进一步探索Spring Boot与数据库的集成奠定了坚实的基础。 数据库是现代应用的核…...

Web 服务器与动态脚本语言通信的接口协议有哪些

Web 服务器与动态脚本语言通信的接口协议主要有以下几种&#xff1a; 一、FastCGI&#xff08;Fast Common Gateway Interface&#xff09; 特点&#xff1a;使用持久进程处理请求&#xff0c;减少了进程启动和关闭的开销&#xff0c;提高了性能和可扩展性。多个请求可由同一个…...

ESXI识别服务器磁盘,虚拟机显示无效

ESXI识别服务器磁盘&#xff0c;虚拟机显示无效 系统意外断电识别不到磁盘的情况下可以管理-》硬件-》搜索磁盘名称&#xff0c;选择切换直通&#xff0c;则虚拟机正常。...

【C++】 vector 迭代器失效问题

【C】 vector 迭代器失效问题 一. 迭代器失效问题分析二. 对于vector可能会导致其迭代器失效的操作有&#xff1a;1. 会引起其底层空间改变的操作&#xff0c;都有可能是迭代器失效2. 指定位置元素的删除操作--erase3. Linux下&#xff0c;g编译器对迭代器失效的检测并不是非常…...

【Spring基础3】- Spring的入门程序

目录 3-1 Spring的下载3-2 Spring的 jar 包3-3 第一个 Spring程序第一步&#xff1a;添加spring context的依赖&#xff0c;pom.xml配置如下第二步&#xff1a;添加junit依赖第三步&#xff1a;定义bean&#xff1a;User第四步&#xff1a;编写spring的配置文件&#xff1a;bea…...

golang学习笔记22-面向对象(四):接口【重要】

本节也是GO核心部分&#xff0c;很重要。 注&#xff1a;由于导包语句已经在19讲&#xff08;笔记19&#xff1a;面向对象的引入&#xff09;展示过了&#xff0c;所以这里就不展示了。 一、定义与实现 (1)接口中可以定义一组方法&#xff0c;但不需要实现&#xff0c;不需要…...

SpringBoot技术栈:打造下一代网上租赁系统

第2章 关键技术简介 2.1 Java技术 Java是一种非常常用的编程语言&#xff0c;在全球编程语言排行版上总是前三。在方兴未艾的计算机技术发展历程中&#xff0c;Java的身影无处不在&#xff0c;并且拥有旺盛的生命力。Java的跨平台能力十分强大&#xff0c;只需一次编译&#xf…...

Vue-Lecture1-Notes

渐进式框架 Vue 被称为“渐进式框架”&#xff0c;是因为它允许开发者根据项目的需求逐步引入和使用其功能&#xff0c;而不需要一次性使用整个框架。简单来说&#xff0c;Vue 提供了从简单到复杂的功能层次&#xff0c;可以灵活选择使用。 按需使用&#xff1a;Vue 的核心功能…...

网上租赁系统开发:SpringBoot实践与应用

第2章 关键技术简介 2.1 Java技术 Java是一种非常常用的编程语言&#xff0c;在全球编程语言排行版上总是前三。在方兴未艾的计算机技术发展历程中&#xff0c;Java的身影无处不在&#xff0c;并且拥有旺盛的生命力。Java的跨平台能力十分强大&#xff0c;只需一次编译&#xf…...

User-Agent在WebMagic爬虫中的重要性

对于需要从网站上抓取数据的开发者来说&#xff0c;WebMagic是一个强大的工具。它是一个简单灵活的Java爬虫框架&#xff0c;用于抓取网页数据。在爬虫技术中&#xff0c;User-Agent&#xff08;用户代理&#xff09;是一个关键的HTTP请求头&#xff0c;它告诉服务器关于客户端…...

如何解决 Docker 下载 mcr.microsoft.com 镜像慢的办法

一、介绍 MCR(Miscrosoft Container Registry) 加速器&#xff0c;助你在中国大陆急速下载 netcore 相关的 docker 镜像。二、解决办法。     1、如何使用       至少三种方法进行加速&#xff1a;         使用 docker-mcr &#xff08;推荐&#xff09;  …...

网络编程,端口号,网络字节序,udp

前面一篇我们讲了网络的基础&#xff0c;网络协议栈是什么样的&#xff0c;数据如何流动传输的&#xff1b;接下来这篇&#xff0c;我们将进行实践操作&#xff0c;真正的让数据跨网络进行传输&#xff1b; 1.网络编程储备知识 1.1 初步认识网络编程 首先我们需要知道我们的…...

Android入门

下载Android studio&#xff0c;创建第一个项目 模板可以选择empty views Activity 在这个界面可以修改&#xff0c;使用语言&#xff0c;项目名字&#xff0c;存储路径以及适用版本 完成后&#xff0c;得到一个最初始的Android 项目&#xff0c;红色标记的两个文件&#xf…...

二叉树深搜专题篇

目录 计算布尔二叉树的值 求根节点到叶节点数字之和 二叉树剪枝 验证二叉搜索树 二叉搜索树中第K小的元素 二叉树的所有路径 计算布尔二叉树的值 题目 思路 这道题其实是比较简单的&#xff0c;对二叉树来一次后序遍历即可&#xff0c;当遇到叶子结点直接返回叶子节点中…...

堆【数据结构C语言版】【 详解】

目录-笔记整理 一、思考二、堆概念与性质三、堆的构建、删除、添加1. 构建2. 删除3. 添加 四、复杂度分析4.1 时间复杂度4.2 空间复杂度 五、总结 一、思考 设计一种数据结构&#xff0c;来存放整数&#xff0c;要求三个接口&#xff1a; 1&#xff09;获取序列中的最值&#…...

初识React

在最新写需求的时候&#xff0c;我遇到了一个需求&#xff0c;这个需求改后端改的不算多&#xff0c;而且也比较简单&#xff0c;但是在改前端的时候&#xff0c;很复杂。因为我们这个项目用的是React做前端的&#xff0c;而我对于前端知识没有了解&#xff0c;所以理解很多代码…...

VUE 开发——AJAX学习(三)

一、async函数和await async和await关键字让我们可以用一种更简洁的方式写出基于Promise的异步行为&#xff0c;而无需刻意地链式调用Promise async写在函数声明的前面&#xff1b;在async函数内&#xff0c;使用await关键字&#xff0c;获取Promise对象“成功状态”结果值 &…...

从仿真卡死到波形完美:手把手调试Verilog Testbench时钟的那些坑

从仿真卡死到波形完美&#xff1a;手把手调试Verilog Testbench时钟的那些坑 数字电路仿真中&#xff0c;时钟信号就像交响乐团的指挥棒&#xff0c;一个微小的节奏错误就可能导致整个系统失序。刚接触Verilog仿真的工程师们&#xff0c;往往会在时钟生成这个看似简单的环节栽跟…...

Audacity音频编辑教程:免费开源音频处理软件的完整使用指南

Audacity音频编辑教程&#xff1a;免费开源音频处理软件的完整使用指南 【免费下载链接】audacity Audio Editor 项目地址: https://gitcode.com/GitHub_Trending/au/audacity Audacity是一款功能强大的免费开源音频编辑软件&#xff0c;支持录音、剪辑、混音和音频效果…...

别再折腾Windows了!用Mac或Linux搞定ACM LaTeX模板的字体难题(附保姆级配置流程)

跨平台LaTeX写作&#xff1a;为什么macOS和Linux是ACM模板的最佳选择 第一次接触ACM LaTeX模板的研究人员&#xff0c;往往会在字体兼容性问题上耗费大量时间——特别是Windows用户。当你反复尝试安装Libertine字体、解决各种编译错误时&#xff0c;是否想过问题可能出在操作系…...

Cadence 17.4导出Gerber文件保姆级避坑指南(附TMC2300电机驱动板实战)

Cadence 17.4导出Gerber文件保姆级避坑指南&#xff08;附TMC2300电机驱动板实战&#xff09; 第一次用Cadence Allegro 17.4导出Gerber文件的新手&#xff0c;大概率会在某个环节卡住——要么是钻孔文件莫名报错&#xff0c;要么是板厂反馈光绘层对不齐。这种挫败感我太熟悉了…...

Wireshark解密不止于IPSec:一份TLS/SSL、HTTPS、SSH等常见加密协议的解密指南

Wireshark解密不止于IPSec&#xff1a;一份TLS/SSL、HTTPS、SSH等常见加密协议的解密指南 当你面对一个加密的网络流量时&#xff0c;是否曾感到无从下手&#xff1f;无论是调试HTTPS API调用、分析SSH连接问题&#xff0c;还是研究QUIC协议的行为&#xff0c;加密流量总是像一…...

KV缓存优化在语音大模型中的挑战与AudioKV解决方案

1. KV缓存管理在大型语言模型中的核心挑战在Transformer架构的大型语言模型&#xff08;LLM&#xff09;推理过程中&#xff0c;KV&#xff08;Key-Value&#xff09;缓存技术通过存储历史注意力键值对来避免重复计算&#xff0c;这项优化使得自回归生成的计算复杂度从O(n)降低…...

Intelli开源智能代理框架:从核心概念到生产部署全解析

1. 项目概述&#xff1a;Intelli 是什么&#xff0c;以及它为何值得关注最近在开源社区里&#xff0c;一个名为intelligentnode/Intelli的项目开始引起不少开发者的注意。乍一看这个标题&#xff0c;你可能会有点困惑&#xff1a;Intelli&#xff1f;是某种新的智能代理框架&am…...

三步解决Zotero中文文献管理难题:茉莉花插件完整指南

三步解决Zotero中文文献管理难题&#xff1a;茉莉花插件完整指南 【免费下载链接】jasminum A Zotero add-on to retrive CNKI meta data. 一个简单的Zotero 插件&#xff0c;用于识别中文元数据 项目地址: https://gitcode.com/gh_mirrors/ja/jasminum 你是否在使用Zot…...

从「LLM 使用者」到「LLM 驾驭者」:小白程序员必备的大模型核心知识体系与实战指南(收藏版)

本文将从底层原理、工程落地、应用优化三个维度&#xff0c;系统拆解大语言模型的核心知识体系&#xff0c;既保证技术深度&#xff0c;又用通俗的语言和实战案例降低理解门槛&#xff0c;适合所有想要从「LLM 使用者」进阶为「LLM 驾驭者」的读者。 一、LLM 核心原理入门&…...

DDSP与神经音频合成:AI如何复刻经典合成器音色

1. 项目概述&#xff1a;当AI遇见经典合成器如果你和我一样&#xff0c;是个对复古合成器声音着迷&#xff0c;同时又对现代AI技术充满好奇的音乐制作人或开发者&#xff0c;那么最近在GitHub上出现的martinic/DrMixAISynth项目&#xff0c;绝对值得你花上一个下午的时间好好研…...