数字图像处理(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)测试普通二值化实验现象:

相关推荐
Donvink8 分钟前
Transformers在计算机视觉领域中的应用【第3篇:Swin Transformer——多层次的Vision Transformer】
人工智能·深度学习·目标检测·计算机视觉·transformer
合合技术团队2 小时前
合合信息智能图像处理技术,让你的设备更智能
图像处理·人工智能·aigc
亦枫Leonlew7 小时前
三维测量与建模笔记 - 5.3 光束法平差(Bundle Adjustment)
笔记·计算机视觉·三维重建·光束法平差
爱研究的小牛9 小时前
Runway 技术浅析(七):视频技术中的运动跟踪
人工智能·深度学习·计算机视觉·目标跟踪·aigc
GOTXX9 小时前
修改训练策略,无损提升性能
人工智能·计算机视觉·目标跟踪
阿赵3D9 小时前
图片预处理技术介绍4——降噪
图像处理·1024程序员节·降噪
∑狸猫不是猫12 小时前
数字图像处理(13):图像裁剪
图像处理·fpga开发
Tronlongtech15 小时前
RK3568 + OpenCV 会碰撞出什么火花?案例详解:2-1 基于OpenCV的画线实验
人工智能·opencv·计算机视觉
码码哈哈0.017 小时前
Stable Diffusion介绍
人工智能·计算机视觉·stable diffusion
Anin蓝天(北京太速科技-陈)17 小时前
160-两路14位400Msps AD,两路16位400Msps DA FMC子卡模块
嵌入式硬件·fpga开发