基于LSB匹配的隐写术MATLAB实现

一、核心算法原理

LSB匹配隐写术通过动态调整像素的最低有效位(LSB),使修改后的LSB与秘密信息比特匹配,而非强制替换。其核心步骤包括:

  1. 像素匹配:若载体像素LSB与秘密信息比特不一致,通过±1调整像素值,使LSB匹配。
  2. 动态选择方向:优先选择调整方向使像素值不超出0-255范围,减少图像失真。
  3. 统计隐蔽性:相比传统LSB替换,显著降低像素值奇偶分布的统计异常。

二、MATLAB实现代码
1. 预处理函数
matlab 复制代码
function [carrier, watermark] = preprocess(carrier_img, watermark_img)
    % 转换为灰度图像
    if size(carrier_img, 3) == 3
        carrier = rgb2gray(carrier_img);
    else
        carrier = carrier_img;
    end
    
    if size(watermark_img, 3) == 3
        watermark = rgb2gray(watermark_img);
    else
        watermark = watermark_img;
    end
    
    % 调整水印大小与载体一致
    [M, N] = size(carrier);
    watermark = imresize(watermark, [M, N]);
    
    % 二值化水印(阈值自适应)
    threshold = graythresh(watermark); % Otsu's方法
    watermark = imbinarize(watermark, threshold);
end
2. LSB匹配嵌入函数
matlab 复制代码
function stego_img = lsb_match_embed(carrier, watermark)
    [M, N] = size(carrier);
    stego_img = double(carrier);
    
    for i = 1:M
        for j = 1:N
            % 提取载体像素LSB
            carrier_bit = mod(carrier(i,j), 2);
            % 提取水印比特
            watermark_bit = watermark(i,j);
            
            % 匹配调整
            if carrier_bit ~= watermark_bit
                if stego_img(i,j) < 255
                    stego_img(i,j) = stego_img(i,j) + 1; % +1调整
                else
                    stego_img(i,j) = stego_img(i,j) - 1; % -1调整
                end
            end
        end
    end
    
    stego_img = uint8(stego_img);
end
3. 秘密信息提取函数
matlab 复制代码
function extracted_watermark = lsb_match_extract(stego_img, rows, cols)
    [M, N] = size(stego_img);
    extracted_watermark = zeros(rows, cols);
    
    for i = 1:rows
        for j = 1:cols
            % 提取LSB
            bit = mod(stego_img(i,j), 2);
            extracted_watermark(i,j) = bit;
        end
    end
end
4. 主程序测试
matlab 复制代码
% 读取载体与水印图像
carrier_img = imread('lena.jpg');
watermark_img = imread('watermark.png');

% 预处理
[carrier, watermark] = preprocess(carrier_img, watermark_img);

% 嵌入水印
stego_img = lsb_match_embed(carrier, watermark);

% 保存隐写图像
imwrite(stego_img, 'stego_image.png');

% 提取水印
extracted_watermark = lsb_match_extract(stego_img, size(watermark,1), size(watermark,2));

% 显示结果
figure;
subplot(1,3,1); imshow(carrier); title('原始载体');
subplot(1,3,2); imshow(watermark); title('原始水印');
subplot(1,3,3); imshow(extracted_watermark); title('提取水印');

三、关键技术改进
  1. 动态范围调整

    在调整像素值时,优先选择不越界的调整方向(如接近255时选择减1),避免溢出:

    matlab 复制代码
    if stego_img(i,j) < 255
        stego_img(i,j) = stego_img(i,j) + 1;
    else
        stego_img(i,j) = stego_img(i,j) - 1;
    end
  2. 自适应二值化

    使用Otsu's方法自动选择二值化阈值,提升水印对比度:

    matlab 复制代码
    threshold = graythresh(watermark);
    watermark = imbinarize(watermark, threshold);
  3. 多通道扩展

    支持RGB图像的独立通道嵌入(以红色通道为例):

    matlab 复制代码
    % 选择嵌入通道(1:R, 2:G, 3:B)
    color_channel = 1;
    carrier(:,:,color_channel) = lsb_match_embed(carrier(:,:,color_channel), watermark);

四、应用场景
  1. 数字版权保护 在社交媒体图片中嵌入作者水印,防止盗用。
  2. 隐蔽通信 通过公共图像传递加密信息(需配合加密算法)。
  3. 医疗影像标记 在CT/MRI图像中嵌入患者ID等元数据。

五、优化
  1. 抗检测增强 结合矩阵编码(如汉明码)减少修改像素数量,提升抗卡方攻击能力。

  2. 多模态扩展 支持视频隐写(逐帧处理)与音频隐写(PCM采样点LSB匹配)。

  3. 硬件加速

使用GPU并行计算加速大规模图像处理:

matlab 复制代码
stego_img_gpu = gpuArray(stego_img);
% ... GPU并行处理代码 ...
stego_img = gather(stego_img_gpu);

六、参考
  1. 何伟, 王海涛. 基于LSB匹配的数字水印算法研究J. 计算机工程, 2020.
  2. 代码 基于LSB匹配的隐写术 www.youwenfan.com/contentcsp/97471.html
  3. MathWorks官方网页: imbinarize函数说明与图像处理工具箱.
  4. 陈晓明. 空域隐写术的改进与实现D. 北京邮电大学, 2021.
相关推荐
用户712122751265 小时前
MATLAB 自动化 Excel 转 SLDD 数据字典完整方案(适配自定义 THBPackage 存储类)
matlab
ZhengEnCi1 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi1 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
韩师傅2 天前
海天线算法的前世今生
python·计算机视觉
韩师傅2 天前
当你的甲方设备过烂,要如何快速出效果?
python·计算机视觉
韩师傅2 天前
当你的甲方吐槽天空不够蓝,你应该如何应对
python·计算机视觉
兵慌码乱9 天前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
小小杨树11 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
LDR00613 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言