最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

对Photoshop高斯模糊滤镜的算法总结

来源:懂视网 责编:小采 时间:2020-11-27 14:49:44
文档

对Photoshop高斯模糊滤镜的算法总结

对Photoshop高斯模糊滤镜的算法总结:最近有感于部分网友对高斯模糊滤镜的研究,现总结如下。高斯模糊是数字图像模板处理法的一种。其模板是根据二维正态分布(高斯分布)函数计算出来的。 正态分布最早由A.棣莫弗在求二项分布的渐近公式中得到。C.F.高斯在研究测量误差时从另一个角度导出了它。
推荐度:
导读对Photoshop高斯模糊滤镜的算法总结:最近有感于部分网友对高斯模糊滤镜的研究,现总结如下。高斯模糊是数字图像模板处理法的一种。其模板是根据二维正态分布(高斯分布)函数计算出来的。 正态分布最早由A.棣莫弗在求二项分布的渐近公式中得到。C.F.高斯在研究测量误差时从另一个角度导出了它。
最近有感于部分网友对高斯模糊滤镜的研究,现总结如下。高斯模糊是数字图像模板处理法的一种。其模板是根据二维正态分布(高斯分布)函数计算出来的。
正态分布最早由A.棣莫弗在求二项分布的渐近公式中得到。C.F.高斯在研究测量误差时从另一个角度导出了它。P.S.拉普拉斯和高斯研究了它的性质。故名高斯模糊。

一维正态分布的函数定义:

对Photoshop高斯模糊滤镜的算法总结

型随机变量的分布,第一参数μ是遵从正态分布的随机变量的均值,第二个参数σ2是此随机变量的方差,所以正态分布记作N(μ,σ2 )。 遵从正态分布的随机变量的概率规律为取 μ邻近的值的概率大 ,而取离μ越远的值的概率越小;σ越小,分布越集中在μ附近,σ越大,分布越分散。正态分布的密度函数的特点是:关于μ对称,在μ处达到最大值,在正(负)无穷远处取值为0,在μ±σ处有拐点。它的形状是中间高两边低 ,图像是一条位于x轴上方的钟形曲线。当μ=0,σ2 =1时,称为标准正态分布,记为N(0,1)。

两个常数的意义:μ-期望,σ^2 方差。

下面我们解决第一个疑问:高斯模糊滤镜中的半径是什么?答案是高斯半径就是公式中的σ。

高斯曲线的图形和半径的含义如下图(来自Adobe SDK中技术支持专家的文档)所示:

对Photoshop高斯模糊滤镜的算法总结

可见高斯半径(σ)对曲线形状的影响,σ越小,曲线越高越尖,σ越大,曲线越低越平缓。对二维图像来说,是一个钟形曲面,高斯半径越小,曲面越高越尖越陡峭;高斯半径越大,曲面越低越平缓。因此高斯半径越小,则模糊越小,高斯半径越大,则模糊程度越大。我们将看到ps对高斯半径的范围定义是【0.1~250】。当半径为0.1时,高斯模板在计算后只有中间像素为1,其他像素均=0(实际上只是趋近0),即图像不会有变化。

第二个疑问,高斯模板大小和高斯半径的关系?这是一个一直困扰我们的误解。因为我们的思维进入了物理实现的误区。在物理实现中,高斯模板有界,从而使我们忽略了这个问题的真正答案:高斯模板在逻辑上是无边界的。也就是说高斯模板本质上是逻辑上无穷拓展曲面的一个近似。因此,模板大小我们应该认为它是无穷大的。只不过在计算的时候,因为在远处趋近0,因此在某个阈值之下我们不再考虑这些值,这个阈值就是模板边界。

下面,二维高斯曲面的公式(x,y代表像素的模板坐标,模板中心位置为原点):

对Photoshop高斯模糊滤镜的算法总结


即:g(x,y)= ( 1 / (2*pi*σ^2) ) * exp( -(x^2+y^2)/(2*σ^2) ) ;

根据这个公式,我们可以计算出不同半径下的高斯模板,实际上模板是无穷大的,只是在中心较远处,他们会趋近0.例如,我们计算出r=0.7时的一个归一化后的高斯模板:

高斯模板(guass radius=0.700000)

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.gxlcms.com/

-->//guass radius=0.700000
0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000
0.000000 0.000000 0.000001 0.000012 0.000033 0.000012 0.000001 0.000000 0.000000
0.000000 0.000001 0.000093 0.001976 0.005481 0.001976 0.000093 0.000001 0.000000
0.000000 0.000012 0.001976 0.042189 0.117046 0.042189 0.001976 0.000012 0.000000
0.000000 0.000033 0.005481 0.117046 0.324724 0.117046 0.005481 0.000033 0.000000
0.000000 0.000012 0.001976 0.042189 0.117046 0.042189 0.001976 0.000012 0.000000
0.000000 0.000001 0.000093 0.001976 0.005481 0.001976 0.000093 0.000001 0.000000
0.000000 0.000000 0.000001 0.000012 0.000033 0.000012 0.000001 0.000000 0.000000
0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000

在网络上众所周知流传的高斯3*3模板实际上是对高斯曲面的一个整数除法形式的近似:

1 2 1

2 4 2 /16

1 2 1

实际验证,我们发现这个3*3模板实际上是对高斯半径约为0.849时的一个近似,当r=0.849时,其3*3归一模板为(在MATLAB中,输入h=fspecial('gaussian', 3, 0.849);即可得到这个模板):

(guass radius=0.849000)
0.062467 0.125000 0.062467
0.125000 0.250131 0.125000
0.062467 0.125000 0.062467

然后我们可以用Matlab中的imfilter来对图像进行高斯模糊的处理:

img = imread('c:demo.bmp');
h = fspecial('gaussian', 3, 0.849);
img2 = imfilter(img, h);
subplot(121), imshow(img); title('原图')
subplot(122), imshow(img2); title('高斯模糊后')

效果如下:

对Photoshop高斯模糊滤镜的算法总结

我们可以在Matlab中用如下语句绘制高斯曲面:

绘制高斯曲面的Matlab代码

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.gxlcms.com/

-->%绘制高斯模糊曲面!--------------------
r=0.849; %高斯半径(从0.1到250)
x=-3:0.2:3;
y=x;
[X,Y]=meshgrid(x,y);
Z=exp(-(X.^2+Y.^2)./(2*r*r))/(2*pi*r*r);
mesh(X,Y,Z)

效果如下图:

对Photoshop高斯模糊滤镜的算法总结

在数字信号处理中,高斯模糊算法是一种滤波器,它的时域和频域曲线如下所示:

对Photoshop高斯模糊滤镜的算法总结

从频域曲线看出,高斯模糊本质上一种低通滤波器。体现在图像处理上,图像的边缘等灰度变化剧烈的地方对应高频信息,将被滤除。

最后,我们给出计算高斯模糊模板的C语言代码,请注意,由于高斯模板是对称的,实际上我们只需要计算出大约1/4模板即可。但这里的代码我们没有做这样的优化。我们输出的模板是(2*N+1)*(2N+1),高斯半径用r表示。

计算高斯模板

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.gxlcms.com/

-->#include <math.h>
#include <stdio.h>
#define N 3 /* 模板大小:(2N+1) * (2N+1) */
void main()
{
double a[2*N+1][2*N+1]; /* 高斯模板 */
double r=0.6; /* 高斯半径:[ 0.1, 250] */
double A=1/(2*M_PI*r*r);
int i,j;
for(i=-1*N;i<=N;i++)
for(j=-1*N;j<=N;j++)
a[i+N][j+N]=A*exp((-1)*(i*i+j*j)/ (2*r*r));
}

同时,作为比较,我们给出在Matlab中生成高斯模板的代码(fspecial的代码局部,其中p3是第三个参数即高斯半径):

 case 'gaussian' % Gaussian filter

 siz = (p2-1)/2; %注:p2即模板边长,默认值为33
 std = p3; %注:p3即高斯半径,默认为为0.5
 
 [x,y] = meshgrid(-siz(2):siz(2),-siz(1):siz(1));
 arg = -(x.*x + y.*y)/(2*std*std);

 h = exp(arg);
 h(h<eps*max(h(:))) = 0;

 sumh = sum(h(:)); %注:模板归一化
 if sumh ~= 0,
 h = h/sumh;
 end;

更多对Photoshop高斯模糊滤镜的算法总结相关文章请关注PHP中文网!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

对Photoshop高斯模糊滤镜的算法总结

对Photoshop高斯模糊滤镜的算法总结:最近有感于部分网友对高斯模糊滤镜的研究,现总结如下。高斯模糊是数字图像模板处理法的一种。其模板是根据二维正态分布(高斯分布)函数计算出来的。 正态分布最早由A.棣莫弗在求二项分布的渐近公式中得到。C.F.高斯在研究测量误差时从另一个角度导出了它。
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top