演示基于FPGA的视频图像去雾处理效果

我近期用FPGA开发板做了一个视频图像去雾算法模块,用于验证其能否在不进行帧缓冲的情况下实现去雾功能。

去雾算法来自一篇技术资料(私信提供篇名),其基础是近似的大气光模型。

1 算法原理概要

借助RGB直角坐标空间中的光矢量分解,将带雾像素(即原始像素)矢量分解为两部分 -- 清晰矢量(去雾后这个像素的矢量)、大气光矢量,再将大气光矢量分解为虚拟的暗平面像素矢量、增强矢量(从暗平面像素矢量末端到大气光矢量末端的矢量)。

从第N-1帧中筛选出一部分天空像素,基于天空像素矢量、中间计算得到的近似的透射函数、暗平面像素矢量,计算出由大气因素导致的全局增亮系数。

针对第N帧的每个像素,计算其近似的透射函数、本像素对应的暗平面像素、增强矢量的单位矢量,结合第N-1帧计算得到的全局增亮系数,最终计算得到去雾后这个像素的矢量。

在完整实现上述算法的基础上,我对其做了小幅度的改进。

2 演示环境

演示环境

如上图所示,FPGA开发板 的摄像头插卡(插在板子上沿左侧的双排针座上)上有摄像头,采集到的视频数据流由FPGA接收;我用VerilogHDL编写算法功能,对从摄像头提供的视频图像(480x272/60Hz)进行去雾运算,结果输出到插在FPGA开发板上的LCD屏(插在板子上沿右侧的双排针座上)予以实时对比显示,形成完整的验证闭环。

我只做了去雾模块的代码实现,摄像头、LCD的驱动模块直接调用了开发板厂商提供的demo工程。

3 视频演示

以下是效果演示视频(LCD屏左侧显示原始视频、右侧显示去雾后的视频)。

视频1:

去雾视频-1

视频2:

去雾视频-2

视频3:

去雾视频-3

LCD屏的显示分辨率比较低,加之由手机拍摄,画面有点儿糊;手不稳,抱歉(^_^)。

相关推荐
喜欢丸子头1 天前
xilinx vivado fir ip(FIR Compiler)核 ADC高采样率,FPGA工作时钟为采样率的1/4,同一个时钟周期来四个数据。
fpga开发
璞致电子1 天前
【PZ-AU15P】璞致fpga开发板 Aritx UltraScalePlus PZ-AU15P 核心板与开发板用户手册
嵌入式硬件·fpga开发·fpga·fpga开发板·xilinx开发板
红糖果仁沙琪玛1 天前
fpga iic协议
fpga开发
嵌入式-老费1 天前
Zynq开发实践(FPGA之pwm输出)
fpga开发
hexiaoyan8271 天前
光纤加速的板卡设计原理图:基于6U VPX XCVU9P+XCZU7EV的双FMC信号处理板卡
嵌入式硬件·fpga开发·光纤加速板卡·国产化板卡·xcvu9p板卡·xcvu9p
XiaoChaoZhiNeng1 天前
Altera Quartus17.1 Modelsim 库编译与仿真
fpga开发
LeonDL1682 天前
【通用视觉框架】基于Python+OpenCV+PyQt5开发的视觉框架软件,全套源码,开箱即用
图像处理·人工智能·python·opencv·pyqt5·通用视觉框架软件·机器视觉软件框架
siliconstorm.ai2 天前
开源与闭源的再对决:从Grok到中国力量,AI生态走向何方?
大数据·图像处理·人工智能·语言模型·ai作画·云计算·机器翻译
燎原星火*2 天前
FPGA复位
fpga开发
博览鸿蒙2 天前
FPGA笔试面试常考问题及答案汇总
fpga开发