产生指定信噪比的高斯噪声
函数介绍参考:OpenCV学习笔记(十二)——随机数产生器RNG
第一步:通过RNG::fill产生N(0,1)分布的高斯变量,注意初始化随机种子,不然每次运行都是一样的结果。例子:
cv::RNG rng(cv::getTickCount()); //随机种子
Mat gauss(10,10,CV_32F);
rng.fill(gauss,cv::RNG::NORMAL,0,1);
第二步:信噪比
求信号功率: sigPower = sum(abs(sig(:)).^2))/length(sig(:));
转化为dB: sigPower = 10*log10(sigPower)
噪声功率:noisePower = sigPower-SNR
dB转线性:noisePower = 10^(noisePower /10);
产生信噪比为SNR的高斯噪声:y = (sqrt(noisePower))*randn(row,col);
产生椒盐噪声