| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1914 人关注过本帖
标题:有哪个大神能帮我看看程序哪里出问题了
只看楼主 加入收藏
微积分123
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2014-5-15
收藏
 问题点数:0 回复次数:1 
有哪个大神能帮我看看程序哪里出问题了
function dwtgl
clear all;
clc;
% 保存开始时间
start_time=cputime;
figure(1); % 读出原始图像 subplot(1,2,1);
input=imread('youyong.bmp'); imshow(input); title('原始图像'); % 读出水印
subplot(1,2,2);  
water=imread('meiyong.bmp');
imshow(water,[]);
title('水印'); % 三色分离
input=double(input);
water=double(water);
inputr=input(: , : , 1);
waterr=water(: , : , 1);
inputg=input(: , : , 2);
waterg=water(: , : , 2);
inputb=double(input(: , : , 3));
waterb=double(water(: , : , 3));    % 系数r大,增加鲁棒性,r小增加透明性
r=0.06; % 水印R的分解  
[Cwr,Swr]=wavedec2(waterr,1,'haar'); % 图像R的分解  
[Cr,Sr]=wavedec2(inputr,2,'haar'); % 水印的嵌入  
% Cr(1: size(Cwr,2)/16)=...  %       Cr(1:size(Cwr,2)/16)+r*Cwr(1:size(Cwr,2)/16);  
k=0;   
while k<=size(Cr,2)/size(Cwr,2)-1         
    Cr(1+size(Cr,2)/4+k*size(Cwr,2)/4:size(Cr,2)/4+...            
(k+1)*size(Cwr,2)/4)=Cr(1+size(Cr,2)/4+...              
k*size(Cwr,2)/4:size(Cr,2)/4+(k+1)*size(Cwr,2)/4)+...            
r*Cwr(1+size(Cwr,2)/4:size(Cwr,2)/2);        
Cr(1+size(Cr,2)/2+k*size(Cwr,2)/4:size(Cr,2)/2+...            
(k+1)*size(Cwr,2)/4)=Cr(1+size(Cr,2)/2+...            
k*size(Cwr,2)/4:size(Cr,2)/2+(k+1)*size(Cwr,2)/4)+...            
r*Cwr(1+size(Cwr,2)/2:3*size(Cwr,2)/4);        
Cr(1+3*size(Cr,2)/4+k*size(Cwr,2)/4:3*size(Cr,2)/4+...
(k+1)*size(Cwr,2)/4)=Cr(1+3*size(Cr,2)/4+...              
k*size(Cwr,2)/4:3*size(Cr,2)/4+(k+1)*size(Cwr,2)/4)+...            
r*Cwr(1+3*size(Cwr,2)/4:size(Cwr,2));         
k=k+1;     
end;            
Cr(1:size(Cwr,2)/4)=Cr(1:size(Cwr,2)/4)+r*Cwr(1:size(Cwr,2)/4);   
g=0.03      % 水印G的分解      
[Cwg,Swg]=wavedec2(waterg,1,'haar');     % 图像G的分解      
[Cg,Sg]=wavedec2(inputg,2,'haar');     % 水印的嵌入  %     
Cg(1:size(Cwg,2)/16)=...  %         
    Cg(1:size(Cwg,2)/16)+g*Cwg(1:size(Cwg,2)/16);   
k=0;      
while k<=size(Cg,2)/size(Cwg,2)-1         
    Cg(1+size(Cg,2)/4+k*size(Cwg,2)/4:size(Cg,2)/4+...            
        (k+1)*size(Cwg,2)/4)=Cg(1+size(Cg,2)/4+...            
        k*size(Cwg,2)/4:size(Cg,2)/4+(k+1)*size(Cwg,2)/4)+...            
        g*Cwg(1+size(Cwg,2)/4:size(Cwg,2)/2);        
    Cg(1+size(Cg,2)/2+k*size(Cwg,2)/4:size(Cg,2)/2+...            
        (k+1)*size(Cwg,2)/4)=Cg(1+size(Cg,2)/2+...              
        k*size(Cwg,2)/4:size(Cg,2)/2+(k+1)*size(Cwg,2)/4)+...            
        g*Cwg(1+size(Cwg,2)/2:3*size(Cwg,2)/4);        
    Cg(1+3*size(Cg,2)/4+k*size(Cwg,2)/4:3*size(Cg,2)/4+...            
        (k+1)*size(Cwg,2)/4)=Cg(1+3*size(Cg,2)/4+...            
        k*size(Cwg,2)/4:3*size(Cg,2)/4+(k+1)*size(Cwg,2)/4)+...            
        g*Cwg(1+3*size(Cwg,2)/4:size(Cwg,2));         
    k=k+1;   
end;
Cg(1:size(Cwg,2)/4)=Cg(1:size(Cwg,2)/4)+g*Cwg(1:size(Cwg,2)/4);     
b=0.12;     % 水印B的分解
    [Cwb,Swb]=wavedec2(waterb,1,'haar');
% 图像B的分解      
[Cb,Sb]=wavedec2(inputb,2,'haar');     % 水印的嵌入  
%     Cb(1:size(Cwb,2)/16)=...  
%         Cb(1:size(Cwb,2)/16)+b*Cwb(1:size(Cwb,2)/16);     
k=0;      while k<=size(Cb,2)/size(Cwb,2)-1         
    Cb(1+size(Cb,2)/4+k*size(Cwb,2)/4:size(Cb,2)/4+...            
        (k+1)*size(Cwb,2)/4)=Cb(1+size(Cb,2)/4+...              
        k*size(Cwb,2)/4:size(Cb,2)/4+(k+1)*size(Cwb,2)/4)+...            
        b*Cwb(1+size(Cwb,2)/4:size(Cwb,2)/2);        
    Cb(1+size(Cb,2)/2+k*size(Cwb,2)/4:size(Cb,2)/2+...            
        (k+1)*size(Cwb,2)/4)=Cb(1+size(Cb,2)/2+...            
        k*size(Cwb,2)/4:size(Cb,2)/2+(k+1)*size(Cwb,2)/4)+...            
        b*Cwb(1+size(Cwb,2)/2:3*size(Cwb,2)/4);         
    Cb(1+3*size(Cb,2)/4+k*size(Cwr,2)/4:3*size(Cb,2)/4+...            
        (k+1)*size(Cwr,2)/4)=Cb(1+3*size(Cb,2)/4+...              
        k*size(Cwb,2)/4:3*size(Cb,2)/4+(k+1)*size(Cwb,2)/4)+...            
        b*Cwb(1+3*size(Cwb,2)/4:size(Cwb,2));         
    k=k+1;   
end;
 Cb(1:size(Cwb,2)/4)=Cb(1:size(Cwb,2)/4)+b*Cwb(1:size(Cwb,2)/4);     % 图像的重构
    inputr=wavedec2(Cr,Sr,'haar');     
inputg=wavedec2(Cg,Sg,'haar');     
inputb=wavedec2(Cb,Sb,'haar');     % 三色的叠加     
temp=size(inputr);
      pic=zeros(temp(1),temp(2),3);      
for i=1:temp(1);           
    for j=1: temp(2);               
        pic(i,j,1)=inputr(i,j);               
        pic(i,j,2)=inputg(i,j);               
        pic(i,j,3)=inputb(i,j);
         end      
end
    output = uint8(round(pic));     % 转化为 uint8
    watermarked_image_uint8=uint8(output);
    imwrite(watermarked_image_uint8,'watermarked_lena.bmp','bmp');     % 显示时间
    elapsed_time=cputime-start_time,     %输出结果     figure(2);
    imshow(watermarked_image_uint8);
   
title('水印图像');
要求水印的大小是原始图像的四分之一,既长宽分别是原始图像的二分之一。
搜索更多相关主题的帖子: function double figure title 
2014-05-15 22:20
微积分123
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2014-5-15
收藏
得分:0 
看到我看到我~
2014-05-15 22:21
快速回复:有哪个大神能帮我看看程序哪里出问题了
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.027737 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved