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编写一个git自动上传的脚本(打包成exe)

《基于Python编写一个git自动上传的脚本(打包成exe)》这篇文章主要为大家详细介绍了如何基于Python编写一个git自动上传的脚本并打包成exe,文中的示例代码讲解详细,感兴趣的小伙伴可以跟... 目录前言效果如下源码实现利用pyinstaller打包成exe利用ResourceHacker修改e

Python在二进制文件中进行数据搜索的实战指南

《Python在二进制文件中进行数据搜索的实战指南》在二进制文件中搜索特定数据是编程中常见的任务,尤其在日志分析、程序调试和二进制数据处理中尤为重要,下面我们就来看看如何使用Python实现这一功能吧... 目录简介1. 二进制文件搜索概述2. python二进制模式文件读取(rb)2.1 二进制模式与文本

Python中Tkinter GUI编程详细教程

《Python中TkinterGUI编程详细教程》Tkinter作为Python编程语言中构建GUI的一个重要组件,其教程对于任何希望将Python应用到实际编程中的开发者来说都是宝贵的资源,这篇文... 目录前言1. Tkinter 简介2. 第一个 Tkinter 程序3. 窗口和基础组件3.1 创建窗

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

Django调用外部Python程序的完整项目实战

《Django调用外部Python程序的完整项目实战》Django是一个强大的PythonWeb框架,它的设计理念简洁优雅,:本文主要介绍Django调用外部Python程序的完整项目实战,文中通... 目录一、为什么 Django 需要调用外部 python 程序二、三种常见的调用方式方式 1:直接 im

Python字符串处理方法超全攻略

《Python字符串处理方法超全攻略》字符串可以看作多个字符的按照先后顺序组合,相当于就是序列结构,意味着可以对它进行遍历、切片,:本文主要介绍Python字符串处理方法的相关资料,文中通过代码介... 目录一、基础知识:字符串的“不可变”特性与创建方式二、常用操作:80%场景的“万能工具箱”三、格式化方法

Spring Boot 处理带文件表单的方式汇总

《SpringBoot处理带文件表单的方式汇总》本文详细介绍了六种处理文件上传的方式,包括@RequestParam、@RequestPart、@ModelAttribute、@ModelAttr... 目录方式 1:@RequestParam接收文件后端代码前端代码特点方式 2:@RequestPart接

浅析python如何去掉字符串中最后一个字符

《浅析python如何去掉字符串中最后一个字符》在Python中,字符串是不可变对象,因此无法直接修改原字符串,但可以通过生成新字符串的方式去掉最后一个字符,本文整理了三种高效方法,希望对大家有所帮助... 目录方法1:切片操作(最推荐)方法2:长度计算索引方法3:拼接剩余字符(不推荐,仅作演示)关键注意事

python版本切换工具pyenv的安装及用法

《python版本切换工具pyenv的安装及用法》Pyenv是管理Python版本的最佳工具之一,特别适合开发者和需要切换多个Python版本的用户,:本文主要介绍python版本切换工具pyen... 目录Pyenv 是什么?安装 Pyenv(MACOS)使用 Homebrew:配置 shell(zsh

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

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