Rumah > Java > javaTutorial > java 图像卷积运算,高斯模糊以及拉普拉斯算子

java 图像卷积运算,高斯模糊以及拉普拉斯算子

黄舟
Lepaskan: 2016-12-30 11:36:22
asal
3367 orang telah melayarinya

阅读前请看<前言>,谢谢!

关于卷积,在上一篇中我们已经提到来,不明白的童鞋可以去看上一篇。

看到题目,聪明的童鞋应该明白他们直接的关系了。对于卷积运算,采取不同的模板(Mask),就能得到不同的结果,先实现卷积运算。

代码如下:

public void filter(double[][] mask) {
		toGray();//灰度化
		int mh = mask.length;
		int mw = mask[1].length;
		int sh = (mh+1)/2;
		int sw = (mw+1)/2;
		double maskSum = math.sum(mask);
		int[] d= new int[w*h];
		
		for(int i=(mh-1)/2+1;i<h-(mh-1)/2;i++){
			for(int j=(mw-1)/2+1;j<w-(mw-1)/2;j++){
				
			   int s = 0;
		       for(int m=0; m<mh ; m++){
		    	   for(int n=0;n<mw;n++){
		    		   s = s + (int)(mask[m]
*this.data[j+n-sw +(i+m-sh)*w]);
		    	   }
		       }
		       
		       if(maskSum != 0)
		    	   s /= maskSum;
		       
		       if(s < 0)
		    	   s =0;
		       if(s > 255)
		    	   s = 255;
		       d[j + i * w] = s;   
			}
		}
		
		this.data = d;
	}
Salin selepas log masuk

对于由高斯核生成的高斯模板如下:

697.png

698.png


运行结果分别为,右边为高斯7*7模板生成的结果:

699.jpg

锐化模板:

700.jpg

运行结果:

701.jpg

拉普拉斯算子:

702.jpg

运行结果:

703.jpg

 以上就是java 图像卷积运算,高斯模糊以及拉普拉斯算子的内容,更多相关内容请关注PHP中文网(m.sbmmt.com)!


sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan