How to divide gray scale image into 8x8 blocks and access each block separately to apply dct2 on the block
12 ビュー (過去 30 日間)
古いコメントを表示
I want to divide the grayscale image which in my case is the 'cameraman.tif' into 8x8 blocks then run dct2 on each block to
later hide a binary watermark image into each block.
So far I tried blockproc and many other methods but none of them satisfy my needs.
2 件のコメント
dharaneesh govindaraj
2021 年 10 月 23 日
I want to do same process. I dont know how to convert the image and watermark. Please help me by providing code
Image Analyst
2021 年 10 月 23 日
編集済み: Image Analyst
2021 年 10 月 23 日
@dharaneesh govindaraj, start with running and understanding my attached blockproc() demos. Then adapt them to make the function it runs fft2() instead of whatever I used. But this is essentially what Stephane does below.
採用された回答
Stephane Dauvillier
2019 年 4 月 29 日
編集済み: Stephane Dauvillier
2019 年 4 月 29 日
file = 'cameraman.tif';
im=imread(file);
imshow(im);
In order to use blockproc you have to use a function that accpts blocksstructure, that's why you need to use something like this
imModified = blockproc(im,[8 8],@(blkStruct) dct2(blkStruct.data));
imshow(imModified)
I hope this answers your question
2 件のコメント
Stephane Dauvillier
2019 年 4 月 29 日
You have a function to add your watermak ?
Let's just say you have your function has followed
function imageWithWatermak = myFunction(imageWithoutWatermark)
...
end
Then you will do
blockproc(im,[8 8],@(blkStruct) myFunction(blkStruct.data));
その他の回答 (1 件)
KALYAN ACHARJYA
2019 年 4 月 29 日
編集済み: KALYAN ACHARJYA
2019 年 4 月 29 日
image1=rgb2gray(imread('test.jpg'));
[rows colm]=size(image1);
% pading for make 8 disible, im my case rows 96 and colm 200
% 96 alread divisible by 8, no need modification: 12
% colm 200 no need modification: 25
% Otherwise do zero pading, where required rows or colm, or both
result=dct2(image1,[12 25]);
% This size [12 25] divides the image in 8x8 blocks, each block size is 12x25
imshow(result);
There may more simpler way also.
0 件のコメント
参考
カテゴリ
Help Center および File Exchange で Image Processing Toolbox についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!