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

相关推荐
有Li1 小时前
分割任意组织:用于医学图像分割的单样本参考引导免训练自动点提示方法|文献速递-深度学习医疗AI最新文献
论文阅读·深度学习·计算机视觉
終不似少年遊*2 小时前
机器学习方法实现数独矩阵识别器
人工智能·python·opencv·机器学习·计算机视觉·矩阵
硅谷秋水4 小时前
TASTE-Rob:推进面向任务的手-目标交互视频生成,实现可通用的机器人操作
人工智能·深度学习·机器学习·计算机视觉·机器人·交互
孚为智能科技4 小时前
集装箱残损识别系统如何检测残损?它的识别率能达到多少?
大数据·图像处理·人工智能·计算机视觉·视觉检测
jndingxin6 小时前
OpenCV CUDA模块图像变形------对图像进行 尺寸缩放(Resize)操作函数resize()
人工智能·opencv·计算机视觉
luofeiju6 小时前
数字图像处理与OpenCV初探
c++·图像处理·python·opencv·计算机视觉
清醒的兰6 小时前
OpenCV 多边形绘制与填充
图像处理·人工智能·opencv·计算机视觉
luozhonghua20006 小时前
opencv opencv_contrib vs2020 源码安装
人工智能·opencv·计算机视觉
吴声子夜歌6 小时前
OpenCV——图像金字塔
人工智能·opencv·计算机视觉
吴声子夜歌6 小时前
OpenCV——图像基本操作(三)
人工智能·opencv·计算机视觉