基于FPGA的图像直方图均衡化处理verilog实现,包含tb测试文件和MATLAB辅助验证

目录

1.算法运行效果图预览

2.算法运行软件版本

3.部分核心程序

4.算法理论概述

5.算法完整程序工程


1.算法运行效果图预览

FPGA的仿真图如下:

将数据导入MATLAB,对比结果如下:

2.算法运行软件版本

MATLAB2022a

vivado2019.2

3.部分核心程序

复制代码
`timescale 1ns / 1ps
//
// Company: 
// Engineer: 
// 
// Create Date: 2023/01/19 01:47:15
// Design Name: 
// Module Name: im2bw
// Project Name: 
// Target Devices: 
// Tool Versions: 
// Description: 
// 
// Dependencies: 
// 
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
// 
//

module im_hist(
			input i_clk,	 
			input i_rst,	 
			 
			input i_image_en,
			input i_image_end,
			input[7:0] i_image,			
 
			output o_en_eq,
			output[7:0] o_image_eq			
		);
		

wire      en_hist;
wire[7:0] w_hist;	
//直方图
hist hist_u(		
.i_clk      (i_clk),
.i_rst      (i_rst),
.i_image    (i_image[7:0]),
.i_image_en (i_image_en),
.i_image_end(i_image_end),
.o_hist_en  (en_hist),
.o_hist     (w_hist)
);		
 
//均衡输出
hist_eq	hist_eq_u(		
.i_clk      (i_clk),
.i_rst      (i_rst),
.i_hist_en  (en_hist),
.i_hist     (w_hist[7:0]),
.i_image_en (i_image_en),
.i_image    (i_image[7:0]),
.o_image_en (o_en_eq),
.o_image    (o_image_eq)
);		

endmodule

0X_036m

4.算法理论概述

图像直方图均衡化是一种图像处理技术,旨在改善图像的全局对比度,通过重新分配图像的像素值,使得图像的直方图更加均匀。对于灰度的分布更加平滑,图像的视觉效果更佳。这一过程特别适用于那些整体偏暗或偏亮、对比度不足的图像。

原理

  1. 灰度直方程分布: 首先,计算原图的灰度直方程H(r),它表示每个灰度级的像素数。对于8位图像,灰度级从0到2555,H(i)表示灰度i的像素数。

  2. 累积分布: 接下来,计算累积分布H'(r),对H累加和,反映每个灰度累积像素数,直到当前灰度。

  3. 映射变换: 基于H',对每个像素灰度i映射到新的灰度j,使得新映射后的直方程更均匀。映射函数查找表实现此映射变换。

  4. FPGA实现: 在硬件上,FPGA可编程增益器设置为每个通道的增益,对应映射表的增益系数。这样,原图像的每个像素经PGA后,通过查表映射到新的灰度,实现均衡化。

5.算法完整程序工程

OOOOO

OOO

O

相关推荐
简简单单做算法8 小时前
基于PSO粒子群优化的VMD-LSTM时间序列预测算法matlab仿真
算法·matlab·lstm·时间序列预测·pso·vmd-lstm·pso-vmd-lstm
zzc92111 小时前
无线通信网络拓扑推理采样率实验(数据生成)
python·matlab·拓扑·无线通信网络拓扑推理·wcna·tpi
bubiyoushang88815 小时前
MATLAB实现图像纹理特征提取
人工智能·算法·matlab
jllllyuz2 天前
基于GA遗传优化的PID控制器最优控制参数整定matlab仿真
matlab
PN杰3 天前
Matlab解决无法读取路径中的空格
开发语言·matlab·dsp开发
简简单单做算法3 天前
基于NOMP和降维字典的杂波空时功率谱稀疏恢复算法matlab仿真
matlab·nomp·降维字典·杂波空时功率谱·稀疏恢复
机器学习之心4 天前
光伏功率预测 | BP神经网络多变量单步光伏功率预测(Matlab完整源码和数据)
人工智能·神经网络·matlab
爱学习的capoo4 天前
matlab自控仿真【第一弹】❀传递函数和输出时域表达式
开发语言·matlab
HarrietLH5 天前
Matlab实现任意伪彩色图像可视化显示
图像处理·计算机视觉·matlab
沅_Yuan5 天前
基于 CNN-SHAP 分析卷积神经网络的多分类预测【MATLAB】
神经网络·matlab·分类·cnn·shap可解释性