基于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.
相关推荐
灰子学技术18 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
二十雨辰18 小时前
[python]-AI大模型
开发语言·人工智能·python
Yvonne爱编码18 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚18 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
你这个代码我看不懂19 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言
pas13619 小时前
41-parse的实现原理&有限状态机
开发语言·前端·javascript
琹箐19 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
晚霞的不甘19 小时前
CANN 在工业质检中的亚像素级视觉检测系统设计
人工智能·计算机视觉·架构·开源·视觉检测
Monly2119 小时前
Java:修改打包配置文件
java·开发语言
我命由我1234520 小时前
Android 广播 - 静态注册与动态注册对广播接收器实例创建的影响
android·java·开发语言·java-ee·android studio·android-studio·android runtime