Adding haze to image
显示 更早的评论
回答(3 个)
Image Analyst
2016-10-25
编辑:Thorsten
2016-10-25
Use rand() to add an offset and a slight amount of noise. ofr a grayscale image, try this:
maxGL = max(grayImage(:));
hazyImage = uint8(double(grayImage) + 240 - maxGL + 10 * rand(size(grayImage)));
figure;
subplot(1, 2, 1);
imshow(grayImage);
subplot(1, 2, 2);
imshow(hazyImage);
6 个评论
hussein ali
2016-10-25
Image Analyst
2016-10-25
Well I think it does work but maybe you don't think it's realistic enough. In that case I invite you to look at the Vision Lab at the University of Dayton that does research into fog and haze removal. Perhaps if you know how it's removed you can learn what constitutes realistic haze and you can generate it. See this link University of Dayton Vision Lab.
hussein ali
2016-10-31
hussein ali
2016-11-24
Image Analyst
2016-11-24
I'm not Thorsten but since the 240 was in my code I'll answer anyway. Basically I wanted to brighten the image and add a bit of noise to make it look hazy.
I subtracted maxGL to get the image all negative.
Then I added up to 10 gray levels of noise. So now the gray levels go from large negative up to as much as 10.
Then I added 240 to brighten the image. Whatever the old max was, it will now be at 240. For example it might have been at 130 - doesn't matter - now it will be at 240 so it looks brighter. Then there's still the 10 gray levels of noise on top of that so the image goes to as bright as 250 gray levels. You can change the 240 to be whatever you want, to map the old max brightness to a new level.
hussein ali
2017-1-23
Amjad Mushtaq
2022-6-2
编辑:Walter Roberson
2022-9-19
image=imread('image2.jpg');
subplot(2,2,1); imshow(image);title('imege');
a=imcomplement(image);
subplot(2,2,2);imshow(a);title('incomplement');
b=imreducehaze(a); % this is hazy filter code
subplot(2,2,3);imshow(b);title('hazy filter');
1 个评论
Walter Roberson
2022-6-2
Ah, but the question was how to add haze, not how to remove it.
GNANA PRAKASH
2022-9-19
maxGL = max(grayImage(:));
hazyImage = uint8(double(grayImage) + 240 - maxGL + 10 * rand(size(grayImage)));
figure;
subplot(1, 2, 1);
imshow(grayImage);
subplot(1, 2, 2);
imshow(hazyImage);
类别
在 帮助中心 和 File Exchange 中查找有关 Contrast Adjustment 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!