- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章基于Java实现空间滤波完整代码由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
滤波的本义是指信号有各种频率的成分,滤掉不想要的成分,即为滤掉常说的噪声,留下想要的成分,这即是滤波的过程,也是目的。空间滤波是一种采用滤波处理的影像增强方法。其理论基础是空间卷积和空间相关。目的是改善影像质量,包括去除高频噪声与干扰,及影像边缘增强、线性增强以及去模糊等。分为低通滤波(平滑化)、高通滤波(锐化)和带通滤波.
各类图像处理系统在图像的采集、获取、传送和转换(如成像、复制扫描、传输以及显示等)过程中,均处在复杂的环境中,光照、电磁多变,所有的图像均不同程度地被可见或不可见的噪声干扰。噪声源包括电子噪声、光子噪声、斑点噪声和量化噪声。如果信噪比低于一定的水平,噪声逐渐变成可见的颗粒形状,导致图像质量的下降。除了视觉上质量下降,噪声同样可能掩盖重要的图像细节,在对采集到的原始图像做进一步的分割处理时,我们发现有一些分布不规律的椒盐噪声,为此采取相应的对策就是对图像进行必要的滤波降噪处理.
(1) 中值滤波 。
part/01 。
是将每个像元在以其为中心的m×n邻域内取中间亮度值来代替该像元值,以达到去尖锐“噪声”和平滑图像的目的。具体计算方法与模板卷积方法类似,仍采用活动窗口的扫描方法。取值时,将m×n窗口内所有像元按亮度值的大小排列,取中间值作为中间像元的值。所以m×n取奇数为好。一般来说,图像亮度为阶梯状变化时,取均值平滑比取中值滤波要明显得多,而对于突出亮点的“噪声”干扰,从去“噪声”后对原图的保留程度看取中值要优于取均值.
代码实现:
比如我们要对下面矩阵进行中值滤波运算, 。
4 4 3 7 6 8 8 。
4 4 3 7 6 8 8 。
2 2 15 8 9 9 9 。
5 5 8 9 13 10 10 。
7 7 9 12 15 11 11 。
8 8 11 10 14 13 13 。
8 8 11 10 14 13 13 。
输出结果如下图所示:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
package
nb;
import
java.util.arraylist;
import
java.util.arrays;
import
java.util.scanner;
public
class
zzlb {
public
static
void
main(string[] args) {
scanner s=
new
scanner(system.in);
system.out.println(
"请输入矩阵的行数:"
);
int
x=s.nextint();
//获取键盘输入的数字
system.out.println(
"请输入矩阵的列数:"
);
int
y=s.nextint();
//获取键盘输入的数字
int
[][]b=
new
int
[x][y];
//创建一个二维数组
int
[]p=
new
int
[
9
];
//创建一个可以存放9个元素的一维数组来获取#3*3窗口的像元值
system.out.println(
"请输入"
+x+
"*"
+y+
"的矩阵:"
);
for
(
int
i =
0
; i <y; i++) {
for
(
int
j =
0
; j < x; j++) {
b[i][j]=s.nextint();
//将键盘输入的矩阵存放到二维数组里面
}
}
system.out.print(
"运算结果如下:\n"
);
for
(
int
i =
1
; i <y-
1
; i++) {
for
(
int
j =
1
; j < x-
1
; j++) {
//锁定到中心像元的位置,从(1,1)开始
int
g=
0
;
for
(
int
k =i-
1
; k <=i+
1
; k++) {
for
(
int
l =j-
1
; l <=j+
1
; l++) {
p[g++]=b[k][l];
//将3*3矩阵窗口存储到一维数组中
}
}
for
(
int
k =
0
; k <p.length-
1
; k++) {
for
(
int
l =
0
; l < p.length-
1
-k; l++) {
if
(p[l]>p[l+
1
]) {
int
temp = p[l];
p[l]=p[l+
1
];
p[l+
1
]=temp;
//本次采用冒泡排序法对3*3窗口内的像元从小到大排序
}
}
}
system.out.print(p[
4
]+
" "
);
//输出每个3*3模板的中心值,下标都是4
}
system.out.println(
"\n"
);
//输出完一行就换行
}
}
}
|
有小伙伴看到就会说:我求的是55的矩阵,为什么输入的是77的矩阵?原因在于我们运用的33矩阵窗口放在矩阵4个角的像元时,需要额外添加邻近的像元来构成33的窗口,对于这个添加的临时像元值一般和最近的像元值保持一致.
(2)罗伯特锐化 。
part/02 。
图像锐化是为了突出图像上地物的边缘、轮廓,或某些线性目标要素的特征。这种滤波方法提高了地物边缘与周围像元之间的反差,因此也被称为边缘增强。锐化的方法很多,在此只介绍罗伯特梯度。梯度反映了相邻像元的亮度变化率,也就是说,图像中如果存在边缘,如湖泊、河流的边界,山脉和道路等,则边缘处有较大的梯度值。对于亮度值较平滑的部分,亮度梯度值较小。因此,找到梯度较大的位置,也就找到边缘,然后再用不同的梯度计算值代替边缘处像元的值,也就突出了边缘,实现了图像的锐化.
不过在讲解之前小编先给大家引入一个新的概念——图像卷积运算, 卷积运算:可看作是加权求和的过程,使图像区域中的每个像素分别与卷积核(权矩阵)的每个元素对应相乘,所有乘积之和作为区域中心像素的新值。它是在空间域上对图像作局部检测的运算,以实现平滑和锐化的目的。具体作法是选定一个卷积函数,又称为“模板”,实际上是一个m×n图像。二维的卷积运算是在图像中使用模板来实现运算的。运算方法从图像左上角开始,选定与模板同样大小的矩阵元素窗口,图像窗口与模板像元对应的亮度值相乘后再相加,最后一般将计算结果放在窗口中心位置(当m和n都是奇数时),代替原来的像元灰度值。然后活动窗口向右移动一个像元再以同样的方法进行卷积运算,逐行扫描,直到全幅影像都扫描一遍,最后生成新图像。罗伯特锐化方法使用的两个模板如下:
f=|aidxi|+|aidyi|,其中a是矩阵中的2*2个元素,i是第i个元素,i<=4,计算结果放在左上角像元,代替之前的灰度值,但是右下角的像元模板范围内没有其他像元了,无法进行计算,为此使用罗伯特锐化方法都要在原始矩阵的最下边和最右边添加一行和一列,值都和最临近的像元灰度值一样。为了直白了断,小编直接上例子吧,比如有某个矩阵,如下图(1)所示,我要用上面两个模板进行罗伯特锐化,首先得在右边和下边分别添加一行和一列,如下图(2)所示:
接下来对左上角像元进行运算:|2*(-1)+30+40+51|+|20+3*(-1)+41+50|=4, 。
接下来对右上角像元进行运算:|3*(-1)+30+50+51|+|30+3*(-1)+51+50|=4, 。
接下来对左下角像元进行运算:|4*(-1)+50+40+51|+|40+5*(-1)+41+50|=2, 。
接下来对右下角像元进行运算:|5*(-1)+50+50+51|+|50+5*(-1)+51+50|=0,最终输出矩阵如下所示:
这种算法的意义在于用交叉的方法检测出像与其领域在上下之间或左右之间或斜方向之间的差异,最终产生一个梯度影像,达到提取边缘信息的目的.
代码实现:
比如我们要对下面矩阵进行中值滤波运算, 。
2 2 10 10 10 10 。
2 2 10 10 10 10 。
2 2 10 10 10 10 。
2 2 2 2 2 2 。
2 2 2 2 2 2 。
2 2 2 2 2 2 。
输出结果如下图所示:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
package
nb;
import
java.util.scanner;
public
class
robet {
public
static
void
main(string[] args) {
scanner s1 =
new
scanner(system.in);
system.out.println(
"请输入矩阵的行数:"
);
int
x = s1.nextint();
//获取键盘输入的数字
system.out.println(
"请输入矩阵的列数:"
);
int
y = s1.nextint();
//获取键盘输入的数字
int
[][] b =
new
int
[x][y];
//创建一个二维数组
system.out.println(
"请输入"
+ x +
"*"
+ y +
"的矩阵:"
);
for
(
int
i =
0
; i < y; i++) {
for
(
int
j =
0
; j < x; j++) {
b[i][j] = s1.nextint();
}
///将键盘输入的矩阵存放到二维数组里面
}
for
(
int
i =
0
; i <y-
1
; i++) {
for
(
int
j =
0
; j <x-
1
; j++) {
b[i][j]=math.abs(b[i][j]-b[i+
1
][j+
1
])+math.abs(b[i+
1
][j]-b[i][j+
1
]);
system.out.print(b[i][j]+
" "
);
}
//对两个模板进行图像卷积运算后取绝对值相加,并且把结果放到2*2窗口的左上方
system.out.println(
"\n"
);
//输出完一行就换行
}
}
}
|
到此这篇关于基于java的空间滤波代码实现的文章就介绍到这了,更多相关java空间滤波内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://blog.csdn.net/qq_43173805/article/details/119868866 。
最后此篇关于基于Java实现空间滤波完整代码的文章就讲到这里了,如果你想了解更多关于基于Java实现空间滤波完整代码的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
运行 Tomcat 失败并出现 java.lang.OutOfMemoryError - 与缺少 PermGen 空间相关的错误。 我最近将 Tomcat 更改为以自己的用户(而非 root)运行。
我们有一个表,其中包含数百万行,其中包含 PostGIS 几何图形。我们要执行的查询是:落在边界几何内的最新条目是什么?这个查询的问题是我们经常会有大量的项目匹配边界框(半径大约为 5 公里),然后
我有一个Elasticsearch设置,它将允许用户搜索通配符作为索引。 array:3 [ "index" => "users" "type" => "user" "body" => arra
我创建了一个表,其中每行包含两个按钮,并且两个按钮连接在一起,我想将两个按钮分开。我用过 不起作用,css 也是,这是他们的另一种方式。 我有另一个问题,因为我不想在表格边框内显示操作按钮,而是在靠近
我试图在 jQuery Mobile 中的两个按钮之间留出空白。现实中的布局是这样的: Button 1 Button 2 (Hidden w/ display: none)
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
您好,我对图表应用程序还很陌生。现在我为我的应用程序创建了条形图。当我运行 create bar chart as separate project 时,输出如下所示。 然后当我将条形图与我的应用程序
我在使用 H2 和 GeoDB(内存中,junit)时遇到问题。 另外,使用 Hibernate 5(每个包的最新版本,包括 hibernate-spatial)和 Spring 4。 通过 id 实
我想画一张澳大利亚的 map ,并将每个城市表示为一个点。 然后突出显示人口众多(> 1M)的城市 library(sp) library(maps) data(canada.cities) head
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 提供事实和引用来回答它. 6年前关闭。 Improve this
如何保持.txt文件中存在的空格?在.txt文件中,它表示: text :text text1 :text1 text23 :text2 text345 :text3 如果我写这段
以下哪个键最大? 选项 1:16 个数字 [0,9] 选项 2:30 个元音 选项 3:字母表中的 16 个字母 选项 4:32 位 有人可以帮助我,告诉我哪一个是正确的答案以及我们如何计算它吗?我知
在 Unity 3d 中使用 Azure 空间 anchor 来实现在 iOS 和 Android 上部署的室内和室外增强现实体验是否有益? 最佳答案 是的,对于 Azure Spatial Anch
我有一个绝对定位的圆形图像。图像只需占据屏幕宽度的 17%,并且距离顶部 5 个像素。 问题是,当我调整图像大小以占据屏幕宽度的 17% 时,它会这样做,但同时容器会变长。图像本身不会拉伸(stret
我在 Ubuntu 14.04 上使用 Cassandra。从文档中,我可以看到运行命令: nodetool snapshot 创建我的 key 空间的快照。 命令的输出是: nodetool sn
Heroku引入了“私有(private)空间”,是否可以将现有应用迁移到私有(private)空间? https://blog.heroku.com/archives/2015/9/10/herok
是否允许在语义记录中使用非绑定(bind)空格 或其他 HTML 编码字符?我遇到的问题是 ; 字符被软件视为记录的结尾。 例如:假设我有一份婚姻记录,其中包含 2 个结婚者的姓氏、结婚年份以及结
我正在研究“智能 parking ”项目,偶然发现了包含我们真正需要的YouTube视频。我们已经实现了第一部分,即从视频源进行实时透视变换,下一步是将其定义为一组矩形 我基本上需要知道他是如何做到的
我有两个类:Engine 和 Trainset(多个单元),这两个类共享其 ID 空间,其中包含名称和系列 id=- . 这是我的Engine类(它是抽象的,因为有引擎的子类型(DieselEngin
如果有人能帮助我,那就太好了。 我正在尝试使用Java的Split命令,使用空格分割字符串,但问题是,字符串可能没有空格,这意味着它将只是一个简单的顺序(而不是“输入2”将是“退出”) Scanner
我是一名优秀的程序员,十分优秀!