python打造光斑处理系统6:高斯拟合

2024-02-03 13:04

本文主要是介绍python打造光斑处理系统6:高斯拟合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 构建拟合函数
    • 数据获取
    • 打印信息

光斑处理:python处理高斯光束的图像
光斑处理系统:

  • 程序框架🌟打开图像🌟参数对话框/伪彩映射🌟裁切ROI
  • 光强分布

构建拟合函数

scipy中提供了非线性最小二乘回归算法,在曲线拟合方面有着不错的表现,所以下面先不考虑UI,创建一个高斯拟合工具,非常简单,如下图所示

from scipy.optimize import curve_fitdef fitGauss(x, y):gauss = lambda x,a,b,c : a*np.exp(-(x-b)**2/c**2)abc,para = curve_fit(gauss,x,y)Y = gauss(x,abc[0],abc[1],abc[2])info = "fit Model : a*exp(-(x-b)^2/c^2)\n"info += f"a={abc[0]:3f},b={abc[1]:3f},c={abc[2]:3f}"info += f"\nfit para:\n{para}"return Y, info

其中, x , y x,y x,y是用于曲线拟合的数据, Y Y Y是拟合曲线,abc是一个包含 a , b , c a, b, c a,b,c的数组,这三个参数即可组成一个高斯函数

y = a exp ⁡ [ − ( x − b ) 2 c 2 ] y=a\exp[-\frac{(x-b)^2}{c^2}] y=aexp[c2(xb)2]

数据获取

有了拟合函数,接下来只要生成适用于拟合的数据,就可以得到拟合曲线了,为此,暂时对图像按列取最大值,并以此作为待拟合数据。

在完成数据拟合后,需要分别用散点图绘制原始数据,并用曲线图绘制拟合结果,img_fit定义如下。

    def img_fit(self):y = np.max(self.img, 0)x = np.arange(len(y))Y, info = fitGauss(x,y)self.fig.clf()ax = self.fig.gca()ax.scatter(x,y,marker='.',label="origin data")ax.plot(x,Y,lw=1, label="fit data")ax.legend()self.canvas.draw()

先点击【裁切】,在弹出对话框中输入【thres】模式,然后点击【拟合】,运行结果如下

在这里插入图片描述

打印信息

尽管绘制了数据,但图窗中并没有空间输出具体的拟合参数,所以也无法评价光束的拟合信息。为此,可以创建一个对话框,专门用于打印相关信息,

def showInfo(txt):root = tk.Tk("help")root.title("光斑分析工具帮助文件")text = tk.Text(root)text.pack(expand=1,fill=tk.BOTH)text.insert(tk.END,txt)root.mainloop()

然后再img_fit绘图之后加上一行

        showInfo(info)

从而拟合结束之后,就会弹出拟合的参数信息,至此,一个基本的光斑分析工具就算完成了。

fit Model : a*exp(-(x-b)^2/c^2)
a=58.680398,b=27.761098,c=19.362408
fit para:
[[ 0.38468135 -0.0015651  -0.09690099][-0.0015651   0.02802167  0.00143946][-0.09690099  0.00143946  0.06715842]]

这篇关于python打造光斑处理系统6:高斯拟合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/674237

相关文章

Python自动化提取多个Word文档的文本

《Python自动化提取多个Word文档的文本》在日常工作和学习中,我们经常需要处理大量的Word文档,本文将深入探讨如何利用Python批量提取Word文档中的文本内容,帮助你解放生产力,感兴趣的小... 目录为什么需要批量提取Word文档文本批量提取Word文本的核心技术与工具安装 Spire.Doc

Python中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

Python容器转换与共有函数举例详解

《Python容器转换与共有函数举例详解》Python容器是Python编程语言中非常基础且重要的概念,它们提供了数据的存储和组织方式,下面:本文主要介绍Python容器转换与共有函数的相关资料,... 目录python容器转换与共有函数详解一、容器类型概览二、容器类型转换1. 基本容器转换2. 高级转换示

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

Python列表的创建与删除的操作指南

《Python列表的创建与删除的操作指南》列表(list)是Python中最常用、最灵活的内置数据结构之一,它支持动态扩容、混合类型、嵌套结构,几乎无处不在,但你真的会创建和删除列表吗,本文给大家介绍... 目录一、前言二、列表的创建方式1. 字面量语法(最常用)2. 使用list()构造器3. 列表推导式

Python使用Matplotlib和Seaborn绘制常用图表的技巧

《Python使用Matplotlib和Seaborn绘制常用图表的技巧》Python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于Matplotlib和Seaborn,本篇... 目录1. 引言:数据可视化的力量2. 前置知识与环境准备2.1. 必备知识2.2. 安装所需库2.3

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添