数字图像处理(12):灰度二值化

  • 灰度像素:在 RGB 颜色模型下,图像中每个像素颜色的 R、G、B 三种基色的分量值相等的像素。
  • 由灰度像素组成的灰度图像只能表现256中颜色(或亮度),通常把灰度图像中像素的亮度称为灰度值。
  • 灰度化处理:是指把彩色图像转化为灰色图像的处理过程,以下为经过灰度处理后的图像。(三原色亮度相同)

(1)灰度二值化处理

图像处理的灰度二值化是图像处理中的一种重要技术,它可以将灰度图像转化为二值图像,以便于后续的处理分析;二值图像每个像素只有两个可能的值(通常是0和255)的图像,其中0表示黑色,255表示白色。因此二值图像呈现出明显的黑白效果。

(2)阈值和应用

在灰度二值化过程中,需要选择一个阈值,将灰度像素中的像素值和阈值进行比较,如果像素值大于阈值,则该像素设置为白色,反之为黑色。

灰度二值化在图像处理中由许多应用,例如:文字识别、条形码识别、图像分割,通过灰度二值化,可以将图像中的目标区域与背景区域分离开来,方便后续处理分析,同时,由于二值图像存储空间较小,因此可以减少图像处理过程中的计算量和存储成本。

(3)阈值的选取

  • 固定阈值:选择127(灰度值范围的一半)作为阈值T
  • 平均值阈值:将整张图片的灰度平均值作为二值化的阈值T
  • 双峰法:基于图像灰度直方图的二值化方法,在图像的灰度直方图中,如果物体的灰度分布比较有规律,背景和目标在图像直方图各自形成一个波峰,那么选择双峰之间的波谷灰度值作为阈值T(双峰法只适用于目标和背景的灰度值在直方图中形成两个明显的波峰的情况,如果直方图中的波峰不明显或者存在多个波峰,则双峰法可能无法取得理想的二值化效果)

(4)matlab代码实现

复制代码
% 1. 读取图像
input_path = 'D:\FPGA\Image processing\4_gray_binary\img_matlab\1_1920x1080.bmp';
output_dir = 'D:\FPGA\Image processing\4_gray_binary\img_matlab\';
img_s = imread(input_path);

% 获取图像尺寸
[height, width, ~] = size(img_s);

% 创建一个新图像
grayimg = zeros(height, width, 3, 'uint8');

% 灰度加权平均法
for i = 1:height
    for j = 1:width
        gray = 0.30 * double(img_s(i, j, 1)) + 0.59 * ...
               double(img_s(i, j, 2)) + 0.11 * double(img_s(i, j, 3));
        grayimg(i, j, :) = uint8(gray);
    end
end

% 转换为单通道灰度图
img = grayimg(:, :, 1);

% 应用5种不同的阈值方法
th1 = imbinarize(img, 127/255); % 普通二值化
th2 = ~imbinarize(img, 127/255); % 反向二值化
th3 = img; % 截断二值化
th3(th3 > 127) = 127;
th4 = img; % 低阈值零处理
th4(th4 < 127) = 0;
th5 = img; % 高阈值零处理
th5(th5 >= 127) = 0;

% 创建图像标题数组
titles = {'原始灰度图', '普通二值化', '反向二值化', '截断二值化', '低阈值零处理', '高阈值零处理'};
images = {img, th1, th2, th3, th4, th5};
filenames = {'1_原始灰度图.bmp', '2_普通二值化.bmp', '3_反向二值化.bmp', ...
             '4_截断二值化.bmp', '5_低阈值零处理.bmp', '6_高阈值零处理.bmp'};

% 直接保存单张图片,不显示
for i = 1:6
    imwrite(images{i}, fullfile(output_dir, filenames{i}));
end

% 创建并显示总览图
figure('Name', '图像二值化处理结果对比', 'NumberTitle', 'off', ...
       'Position', [100, 100, 1200, 800]);
for i = 1:6
    subplot(2, 3, i);
    imshow(images{i});
    axis image;
    title(titles{i}, 'FontSize', 12, 'FontName', '宋体');
end

% 保存总览图但不关闭窗口
saveas(gcf, fullfile(output_dir, '总览图.bmp'));

disp('所有图片已保存完成!总览图将保持显示。');

(5)测试普通二值化实验现象:

相关推荐
与代码不die不休13 分钟前
RTX5060显卡torch和torch_radon库安装避坑指南(仅linux系统)
linux·图像处理·python·深度学习
热心不起来的市民小周18 分钟前
100种动物语义分割数据集(A100-Seg)
python·深度学习·计算机视觉
FPGA小徐23 分钟前
FPGA数字信号处理(一)数字混频实现详解|NCO/DDS原理、有符号数避坑、直流滤除工程实战
fpga开发
盼小辉丶1 小时前
OpenCV-Python实战(28)——OpenCV计算摄影从HDR图像融合到全景拼接
python·opencv·计算机视觉
Deitymoon1 小时前
RV1126——交叉编译 SDL_TTF库并渲染文字
计算机视觉·音视频·rv1126·osd
Passionate.Z2 小时前
基于FPGA的CLAHE自适应限制对比度直方图均衡算法硬件verilog实现
图像处理·嵌入式硬件·算法·fpga开发·fpga
Szime15 小时前
AD9694 国产替代方案:四通道高速 ADC 在通信与雷达项目中的选型参考
单片机·嵌入式硬件·fpga开发
埃科光电16 小时前
应用分享丨告别测量盲区!锂电极片刻槽检测新方案
图像处理·计算机视觉·视觉检测·相机
code_pgf17 小时前
mllm训练过程中有效地利用辅助监督信号来减少幻觉的方法
人工智能·深度学习·计算机视觉
armwind18 小时前
openISP学习11-BNF — Bilateral Noise Filtering(双边滤波降噪)
图像处理·计算机视觉