Signal to noise ratio color image (code) for dB

I am trying to compute signal to noise ratio (dB) in color images as follows:
noisydata = imnoise(original,'gaussian',0.0,0.1); % mean = 0.0, variance = 0.1
[var_orgR, var_noiseR] = snr(noisydata(:,:,1),original(:,:,1));
[var_orgR, var_noiseR] = snr(noisydata(:,:,2),original(:,:,2));
[var_orgR, var_noiseR] = snr(noisydata(:,:,3),original(:,:,3));
SNR= 10*log10((var_orgR + var_orgG + var_orgB)/(var_noiseR + var_noiseG + var_noiseB));
function [var_original, var_noise] = snr(noisydata, original)
mean_original = mean(original(:));
tmp = original - mean_original;
var_original = sum(tmp(:).^2);
noise = noisydata - original;
mean_noise = mean(noise(:));
tmp = noise - mean_noise;
var_noise = sum(tmp(:).^2);
end
The problem is I get value of SNR = 0.0330, I would like to get SNR in dB like 1 dB, 5 dB, etc.
Could any one please guide/suggest how to obtain SNR in dB?
Thank you. Dbs

답변 (2개)

Image Analyst
Image Analyst 2013년 2월 3일

0 개 추천

Where did you get these formulas? I'm not sure I agree with them. In fact I don't, unless you can show me some reference that say otherwise.

댓글 수: 5

Dadhichi
Dadhichi 2013년 2월 3일
The final SNR is from paper: Subpixel edge detection of color images by principal axis analysis and moment-preserving principle, by Shyi-Chyi Cheng∗, Tian-LuuWu.
Well it's not the formula I'm familiar with, and not the one in Wikipedia either. For example, the signal is the signal minus the mean of the signal, instead of just the original signal like most people use. Then, you're not doing it on a pixel by pixel basis. Then, the mean of logs, is not mathematically the same as the log of means. But whatever, if that formula is used for something in a paper you want to replicate, then go ahead and use it. 10log10() does give units in decibels, so you're okay there. Though you may not be getting the numbers you think you should because that's not the regular formula for SNR.
Dadhichi
Dadhichi 2013년 2월 3일
Hello, I understand your concern, its not the conventional way of computing SNR but its the formula used when three channels are to be considered. Anyways I got the solution :), I just had to change the datatype to 'uint8'. Hope this is helpful to other people.
I don't think that would fix it. I would need proof. Anyway, I don't know what a "fix" is. Like I said, you asked how to get the number in decibels and I told you that it's already in decibels.
Dadhichi
Dadhichi 2013년 2월 4일
What proof do you need? If you have access to papers you'll agree. The code is correct, uint8 was programming error, it is not required. Anyways, 'noisydata' and 'original' should have values in same range i.e. between 0 to 1 (was another programming error) :D .

댓글을 달려면 로그인하십시오.

Toqeer Mahmood
Toqeer Mahmood 2015년 10월 9일

0 개 추천

Dear Dadhichi
I am also confused in the same problem, I also want to find SNR with the whole number as 5dB, 10db, 15dB etc. Please send me the working code to find it, if possible for you (my email is toqeer.mahmood@yahoo.com).
Thanks in advance, waiting for your kind reply.

카테고리

도움말 센터File Exchange에서 Time-Frequency Analysis에 대해 자세히 알아보기

질문:

2013년 2월 3일

답변:

2015년 10월 9일

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by