当前位置: 首页 > news >正文

衡阳市住建局官方网站做移动网站优化快

衡阳市住建局官方网站,做移动网站优化快,微分销平台登陆,山西建设执业资格注册管理中心网站文章目录 质心目标截取光斑半径 python图像处理教程:初步📷插值变换📷形态学处理📷滤波 光斑是工程中经常出现的图像数据,其特点是目标明确,分布清晰。对光斑图像的分析,主要包括质心定位、目标…

文章目录

    • 质心
    • 目标截取
    • 光斑半径

python图像处理教程:初步📷插值变换📷形态学处理📷滤波

光斑是工程中经常出现的图像数据,其特点是目标明确,分布清晰。对光斑图像的分析,主要包括质心定位、目标截取以及半径拟合等。

质心

所谓质心,就是质量的中心,连续物体的质心可表示为 ∫ x f ( x ) d x ∫ f ( x ) d x \frac{\int xf(x)\text dx}{\int f(x)\text dx} f(x)dxxf(x)dx,则图像质心可表示为

x ˉ = ∑ i p i j ∑ p i j y ˉ = ∑ j p i j ∑ p i j \bar x = \frac{\sum ip_{ij}}{\sum p_{ij}}\quad \bar y = \frac{\sum jp_{ij}}{\sum p_{ij}} xˉ=pijipijyˉ=pijjpij

由于图像是二维数组,有两个可以操作的方向,故而除了全局的质心外,其每一行或每一列均有一个质心,行质心和列质心的交叉点,就是图像的质心,图像如下,左侧为原始光斑,右侧为其行质心和列质心。

在这里插入图片描述

绘图代码如下,考虑到求质心时,有一个求和项需要做除数,所以在求质心之前,将图像加上 1 0 − 9 10^{-9} 109,以确保不会出现除0错误,同时不会对质心造成干扰。

from numpy as np
import matplotlib.pyplot as plt# 创建一副光斑图像
size = [256,256]
x, y = np.indices(size)
d2 = (x-80)**2+(y-80)**2
img = 255*np.exp(-d2/32)# 求行质心和列质心
arr = np.arange(256).reshape(-1,1)cImg = img + 1e-9
cenRow = (cImg @ arr).reshape(-1)/np.sum(cImg, 0)
cenCol = (cImg.T @ arr).reshape(-1)/np.sum(cImg, 1)# 绘图
fig = plt.figure()
ax1 = fig.add_subplot(121)
ax1.imshow(img, cmap='gray')ax2 = fig.add_subplot(122, sharey=ax1)
ax2.tick_params(axis="y", labelleft=False)
arr = arr.reshape(-1)
plt.imshow(img)
plt.plot(arr, cenRow)
plt.plot(cenCol,arr)
plt.show()

目标截取

由于光斑只占据图片中很小一部分,大量的冗余信息等同于噪声,会影响数据处理,故需截取感兴趣的区域。【plt.ginput】函数提供一种交互操作方法,可返回鼠标点击的位置,其输入参数为选取点数,输出为点击的点的坐标。根据返回的点的位置,即可对图像进行截取。

plt.imshow(img)
p1, p2 = plt.ginput(2)roi = img[int(p1[1]):int(p2[1]), int(p1[0]):int(p2[0])]

在本例中, p 1 , p 2 p_1, p_2 p1,p2两点分别在左上角和右下角,从而无论 x x x还是 y y y p 1 p_1 p1的值均小于 p 2 p_2 p2。另一方面,ginput的返回值是 ( x , y ) (x,y) (x,y)坐标,而矩阵截取过程则是先行后列,行对应的是 y y y,这就是roi在截取时的选区逻辑。

最终截取结果如下。

在这里插入图片描述

fig = plt.figure()
ax = fig.add_subplot(121)
plt.imshow(roi)ax = fig.add_subplot(122, projection='3d')
yGrid, xGrid = np.indices(roi.shape)
ax.plot_surface(yGrid, xGrid, roi)
plt.show()

光斑半径

一般来说,Gauss光束以其强度最大值的 1 e \frac{1}{e} e1处为边界,也就是说,最简单的求解光斑半径的方法,就是统计所有边界内部的点的个数,然后再根据圆面积公式求取其半径。

area = np.sum(roi>255/np.e)
r = np.sqrt(area/np.pi)
# 5.56

另一种方法,则需对光斑的某一维度进行高斯拟合。具体方法是对roi按列求最大值,然后对得到的数组进行高斯拟合,最终得到半径值 r = 5.65 r=5.65 r=5.65,显然更接近于我们最开始设定的 32 \sqrt{32} 32 ,其拟合结果如下。

在这里插入图片描述

from scipy.optimize import curve_fit
def gauss(x, a, b, c):return a*np.exp(-(x-b)**2/c**2)y = np.max(roi,0)
x = np.arange(len(y))abc,  para = curve_fit(gauss,x,y)
print(abc)							#即上式中的a,b,c
# [255.          19.           5.65685425]
Y = gauss(x,abc[0],abc[1],abc[2])	#拟合值
plt.scatter(x,y, label="origin")    #绘制原始数据的散点图
plt.plot(x,Y, label="curve_fit")	#绘制拟合数据的曲线图
plt.legend()
plt.show()
http://www.yayakq.cn/news/977339/

相关文章:

  • 网站建设上传视频教程建e全景官网
  • 网站内容管理系统源码网站怎么做来流量
  • 做网站应该用什么语言来开发安徽房和城乡建设部网站
  • 游戏网站开发具备建设银行海门支行网站
  • 安徽先锋网站两学一做标志设计软件
  • 建设网站建设白度经验哪有学电脑培训班
  • 电子网站风格设计.net网站方案
  • 婚纱网站设计首页专注高端品牌网站的设计
  • 公司网站建站哪个系统好用浙江省特种作业证查询官网
  • 企业网站建设总结报告滁州市建设局网站
  • 不同网站建设特点如何做美食网站
  • 青岛网站商城设计湛江专业自助建站详细解读
  • 网站建设开发背景简介网站购物分享seo
  • 台州超值营销型网站建设地址国内精美网站欣赏
  • 企业科技网站建设微信公众号手机网站
  • 企业快速建站免费模板网站管理与维护的优势
  • 太阳镜商城网站建设中国设计网怎么样
  • 网站logo设计标准做企业网站需要买什么
  • 网站qq号获取中国最好的编程学校
  • 网站建设分录最新新闻热点国家大事
  • 腾讯建设网站视频视频视频平板电脑网站模板
  • 搜索网站建设推广优化卖保温杯去什么网站做推广
  • 综合商城网站程序杭州建站模板
  • 做app网站公司哪家好王野天简历
  • 莱芜网站建设流程西安网站建设 app
  • 网站建设与维护工作内容泉州网站排名优化
  • 网站抄袭嵌入式开发板推荐
  • 全屏类网站建设wordpress新界面
  • 深圳市门户网站建设企业济南房地产网app下载
  • 常州做网站包括哪些淄博专业网站建设哪家专业