第2章 Python 数字图像处理(DIP) --数字图像基础4 -- 像素间的一些基本关系 - 邻域 - 距离测试

目录

  • 像素间的一些基本关系
      • 像素的相邻像素
      • 距离测试

import sys
import numpy as np
import cv2
import matplotlib 
import matplotlib.pyplot as plt
import PIL
from PIL import Imageprint(f"Python version: {sys.version}")
print(f"Numpy version: {np.__version__}")
print(f"Opencv version: {cv2.__version__}")
print(f"Matplotlib version: {matplotlib.__version__}")
print(f"Pillow version: {PIL.__version__}")
Python version: 3.6.12 |Anaconda, Inc.| (default, Sep  9 2020, 00:29:25) [MSC v.1916 64 bit (AMD64)]
Numpy version: 1.16.6
Opencv version: 3.4.1
Matplotlib version: 3.3.2
Pillow version: 8.0.1

像素间的一些基本关系

像素的相邻像素

  • N4(p)N_4(p)N4(p)
  • 坐标(x,y)(x, y)(x,y)处的像素ppp有2个水平的相信像素和2个垂直的相邻像素,它们的坐标是(x+1,y),(x−1,y),(x,y+1),(x,y−1)(x+1, y),(x-1, y),(x, y+1),(x, y-1)(x+1,y),(x1,y),(x,y+1),(x,y1)这组像素称为ppp的4邻域,用N4(p)N_4(p)N4(p)表示
  • ND(p)N_D(p)ND(p)
  • ppp的4个对角相邻像素的坐标是(x+1,y+1),(x+1,y−1),(x−1,y+1),(x−1,y−1)(x+1, y+1),(x+1,y-1),(x-1,y+1),(x-1, y-1)(x+1,y+1),(x+1,y1),(x1,y+1),(x1,y1)ND(p)N_D(p)ND(p)表示。
  • N8(p)N_8(p)N8(p)
  • 这些相邻像素和4邻域全称为8邻域

如题一个邻域包含ppp,那么称该邻域为闭邻域,否则称该邻域为开邻域。

def n4p(x_0):x = np.zeros(5)y_4 = np.zeros_like(x)x[0] = x_0y_4[0] = x_0x[1] = x[0] + 1y_4[1] = y_4[0]x[2] = x[0] - 1y_4[2] = y_4[0]x[3] = x[0]y_4[3] = y_4[0] + 1x[4] = x[0]y_4[4] = y_4[0] - 1return x, y_4def ndp(x_0):x = np.zeros(5)y_D = np.zeros_like(x)x[0] = x_0y_D[0] = x_0x[1] = x[0] + 1y_D[1] = y_D[0] + 1x[2] = x[0] + 1y_D[2] = y_D[0] - 1x[3] = x[0] - 1y_D[3] = y_D[0] + 1x[4] = x[0] - 1y_D[4] = y_D[0] - 1return x, y_D
x_4, y_4 = n4p(0)
x_d, y_d = ndp(0)
x_8 = np.concatenate((x_4, x_d))
y_8 = np.concatenate((y_4, y_d))plt.figure(figsize=(15, 5))
plt.subplot(1,3,1), plt.scatter(x_4, y_4), plt.title("N_4"),# plt.xticks([]), plt.yticks([])
plt.subplot(1,3,2), plt.scatter(x_d, y_d), plt.title("N_D"),# plt.xticks([]), plt.yticks([])
plt.subplot(1,3,3), plt.scatter(x_8, y_8), plt.title("N_8"),# plt.xticks([]), plt.yticks([])
plt.tight_layout()
plt.show()

在这里插入图片描述

# 图像的邻域
height, width = 3, 3
img_ori = np.zeros([height, width], dtype=np.float)img_4 = img_ori.copy()
img_4[0, 1] = 1.0
img_4[1, 0] = 1.0
img_4[1, 1] = 1.0
img_4[1, 2] = 1.0
img_4[2, 1] = 1.0img_d = img_ori.copy()
img_d[0, 0] = 1.0
img_d[0, 2] = 1.0
img_d[1, 1] = 1.0
img_d[2, 0] = 1.0
img_d[2, 2] = 1.0img_8 = (img_d + img_4)
img_8[1, 1] = 0.5plt.figure(figsize=(15, 5))
plt.subplot(1,3,1), plt.imshow(img_4, 'gray'), plt.title("N_4"),# plt.xticks([]), plt.yticks([])
plt.subplot(1,3,2), plt.imshow(img_d, 'gray'), plt.title("N_D"),# plt.xticks([]), plt.yticks([])
plt.subplot(1,3,3), plt.imshow(img_8, 'gray'), plt.title("N_8"),# plt.xticks([]), plt.yticks([])
plt.tight_layout()
plt.show()

在这里插入图片描述

距离测试

对于坐标分别为(x,y),(u,v)和(w,z)的像素p,q和s(x, y),(u,v)和(w, z)的像素p, q和s(x,y),(u,v)(w,z)p,qs,如果
(a)D(p,q)≥0[D(p,q)=0,当且仅当p=q](a)\; D(p, q) \ge 0 \; [D(p,q) = 0, 当且仅当p=q](a)D(p,q)0[D(p,q)=0,p=q]
(b)D(p,q)==D(q,p)且(b)\; D(p, q) == D(q, p) 且(b)D(p,q)==D(q,p)
(c)D(p,s)≤D(p,q)+D(q,s)(c)\; D(p, s) \leq D(p, q) + D(q, s)(c)D(p,s)D(p,q)+D(q,s)
则D是一个距离函数或距离测度。p和qp 和 qpq之间的区几里得(欧氏)距离定义为:
De(p,q)=[(x−u)2+(y−v)2]12(2.19)D_{e}(p, q) = \Big[(x - u)^2 + (y -v)^2 \Big]^{\frac{1}{2}} \tag{2.19}De(p,q)=[(xu)2+(yv)2]21(2.19)

对于这个距离测度,到点(x, y)的距离小于等于r的像素,是中心在(x, y)、半径为r的圆盘。

p和q之间的距离D4p和q之间的距离D_4pqD4(称为街区距离-曼哈顿距离)
D4(p,q)=∣x−u∣+∣y−v∣(2.20)D_4(p, q) = |x - u| + |y - v| \tag{2.20}D4(p,q)=xu+yv(2.20)

p和q之间的距离D8p和q之间的距离D_8pqD8(称为棋盘距离)
D4(p,q)=max(∣x−u∣,∣y−v∣)(2.21)D_4(p, q) = max(|x - u|, |y - v|) \tag{2.21}D4(p,q)=max(xu,yv)(2.21)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/260851.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iphone备忘录突然没了_苹果突然下架12 天猫:双11有惊喜!iPhone12 mini配色缩水

点击“蓝字”关注我们苹果旗舰店突然下架iPhone 12 天猫回应:请期待11.11的惊喜今天,有网友反馈,苹果天猫旗舰店的iPhone 12和iPhone 12 Pro被下架了。小编查看了下,天猫Apple Store旗舰店确实已经下降了目前在售的 iPhone 12 和 …

第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波1 - 灰度变换和空间滤波基础、Sigmoid激活函数

这里写目录标题本节的目标背景灰度变换和空间滤波基础本节的目标 了解空间域图像处理的意义,以及它与变换域图像处理的区别熟悉灰度变换所有的主要技术了解直方图的意义以及如何操作直方图来增强图像了解空间滤波的原理 import sys import numpy as np import cv2…

absolute 必须 relative_Workfine如何控制身份证号码必须为18位?

在信息化系统的设计中,由于业务的需要,我们往往需要设置许多控制项,以保证系统能够按照业务要求流转,必须出库数量不能超过库存,人员信息不能重复录入,考勤区间不能有交叉等。此篇以实例的方式告诉大家如果…

ASP.NET MVC5 网站开发实践(二) Member区域 - 用户部分(2)用户登录、注销

上次实现了用户注册,这次来实现用户登录,用到IAuthenticationManager的SignOut、SignIn方法和基于声明的标识。最后修改用户注册代码实现注册成功后直接登录。 目录: ASP.NET MVC5 网站开发实践 - 概述 ASP.NET MVC5 网站开发实践(一) - 项目…

第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波2 - 图像反转、对数变换

目录一些基本的灰度变换函数图像反转对数变换一些基本的灰度变换函数 如下图显示了在图像处理中频繁使用的3类基本函数: 线性(反转和恒等变换)函数对数(对数和反对数变换)函数幂律(nnn次幂和nnn次根变换&…

为Android应用程序添加社会化分享功能

正在做个android的小应用,有点想尝试一下社会化分享,比如分享到新浪微博啥的。看一下新浪,人人网的API,说实话功能很全很强大,但虽说有相对的SDK,但是总觉得不方便。因为正在使用友盟的统计SDK,…

安卓手机浏览器排行_安卓手机双11性价比排行发布|拯救者手机发透明版|小米发大光圈手机镜头...

智友新闻2020-11-05本期摘要:①安卓手机双11性价比排行榜发布②联想拯救者电竞手机 Pro 至尊透明版启动预约③小米发伸缩式大光圈镜头概念安卓手机双11性价比排行榜发布 安兔兔近日发布了安卓手机双11性价比排行榜。该榜单的统计维度为 2020年10月1日至10月31日。其…

SQL Server 2008故障转移集群+数据库镜像配置实例之三

前两篇文章已经建立了SQL 2008 的故障转移集群,由于故障转移集群存在一个单点故障,既是当网络存储设备不可用时,整个集群就不可用了。所以为了获得更好的高可用特性和容灾机制,我们可以将集群中的某一特定SQL数据库配置一个镜像数…

第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波3 -幂律变换、伽马变换

目录幂律(伽马)变换幂律(伽马)变换 scrγ(3.5)s c r^{\gamma} \tag{3.5}scrγ(3.5) c和γc和\gammac和γ是正常数。考虑到偏移(即输入为0时的一个可度量输出),可改写为sc(rϵ)γs c (r \epsi…

没有与参数列表匹配的 重载函数 strcpy_s 实例_Zemax光学设计实例(84)Ftheta扫描平场透镜的设计...

导论:F-theta透镜又叫激光扫描聚焦镜,是激光加工行业必不可少的光学元件之一。对于理想薄透镜,光束的偏转角度与轨迹位置的关系为YF*tan(θ),这种非线性关系会使得匀速偏转的振镜扫描速度与轨迹运动速度是不匹配的,导致…

MongoDB学习笔记(一)--基础

Insert MongoDB在执行插入时,首先会将插入的数据转换成BSON格式。然后MongoDB数据库会对BSON进行解剖,并检查是否存在_id建。 >doc {"_id" : 1…

第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波4 - 分段线性变换 - 对比度拉伸

目录分段线性变换对比度拉伸最大最小值拉伸分段线性变换 优点 形式可以任意复杂 缺点 要求用户输入很多参数 对比度拉伸 光照不足、成像传感器的动态范围偏小、图像获取过程中镜头孔径的设置错误 点(r1,s1)和点(r2,s2)(r_1, s_1)和点(r_2, s_2)(r1​,s1​)和点(r2​,s2​…

2017网易内推编程题(判断单词):解答代码

2019独角兽企业重金招聘Python工程师标准>>> 小易喜欢的单词具有以下特性: 1.单词每个字母都是大写字母 2.单词没有连续相等的字母 3.单词没有形如“xyxy”(这里的x,y指的都是字母,并且可以相同)这样的子序列,子序列可…

iphone查看删除的短信_想要恢复已经删除的的短信怎么办?

阅读本文前,请您先点击上面的蓝色字体,再点击“关注”,这样您就可以继续免费收到文章了。每天都有分享,完全是免费订阅,请放心关注。 …

第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波5 - 分段线性变换 - 灰度级分层

目录灰度级分层灰度级分层 二值图像 将感兴趣范围内的所有灰显示为一个值(白色),而将其它灰度值显示为另一个值(黑色) 其他灰度级不变 使期望的灰度范围变量(或变暗),但保持图像中…

SQL Server聚集索引的选择

先声明文章非原创,摘自博客园:http://www.cnblogs.com/CareySon/archive/2012/03/06/2381582.html 简介 在SQL Server中,数据是按页进行存放的。而为表加上聚集索引后,SQL Server对于数据的查找就是按照聚集索引的列作为关键字进行…

c++突破网关屏蔽_为什么加了屏蔽罩,测试效果反而不好?

来自专治PCB疑难杂症微信群群友(群友突破1200人啦,文末添加杨老师微信号,可添加入群)的问题讨论:设计时我加了屏蔽罩,结果在测试的时候不加屏蔽罩的效果要比加了屏蔽罩的效果好,这是为何?跟PCB设计的屏蔽罩…

第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波6 - 分段线性变换 - 比特平面分层

目录比特平面分层比特平面分层 在一幅256级灰度图像中,图像的值是由8比特(1字节)组成的 def convert_bin(data, n):"""convert decimal to binary, return n th bit, 0 if bit value 0 else 1""" #---------…

iOS GCD

from:http://www.cnblogs.com/dsxniubility/p/4296937.html 一般: dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{// 耗时操作dispatch_async(dispatch_get_main_queue(), ^{// 更新UI});}); 本文是对以往学习的多线…

c++和java哪个难_2020 年 11 月编程语言排行榜,Python 超越 Java ?

来源:tiobe.com/tiobe-index/November-2020TIOBE 2020 年 11 月份的编程语言排行榜已经公布,官方的标题是:Python 势如破竹,超越 Java。题外话: 目前小哈正在个人博客(新搭建的网站,域名就是犬小哈的拼音) www.quanxia…