###最小二乘法试验###import numpy as np
from scipy.optimize import leastsq
###采样点(Xi,Yi)###Xi=np.array([8.19,2.72,6.39,8.71,4.7,2.66,3.78])Yi=np.array([7.01,2.78,6.47,6.71,4.1,4.23,4.05])###需要拟合的函数func及误差error###def func(p,x): k,b=p
return k*x+b
def error(p,x,y,s):print s
return func(p,x)-y #x、y都是列表,故返回值也是个列表#TESTp0=[100,2]#print( error(p0,Xi,Yi) )###主函数从此开始###s="Test the number of iteration"#试验最小二乘法函数leastsq得调用几次error函数才能找到使得均方误差之和最小的k、bPara=leastsq(error,p0,args=(Xi,Yi,s))#把error函数中除了p以外的参数打包到args中k,b=Para[0]print"k=",k,'\n',"b=",b
###绘图,看拟合效果###import matplotlib.pyplot as plt
plt.figure(figsize=(8,6))plt.scatter(Xi,Yi,color="red",label="Sample Point",linewidth=3)#画样本点x=np.linspace(0,10,1000)y=k*x+b
plt.plot(x,y,color="orange",label="Fitting Line",linewidth=2)#画拟合直线plt.legend()plt.show()
###最小二乘法试验###import numpy as np
from scipy.optimize import leastsq
###采样点(Xi,Yi)###Xi=np.array([0,1,2,3,-1,-2,-3])Yi=np.array([-1.21,1.9,3.2,10.3,2.2,3.71,8.7])###需要拟合的函数func及误差error###def func(p,x): a,b,c=p
return a*x**2+b*x+c
def error(p,x,y,s):print s
return func(p,x)-y #x、y都是列表,故返回值也是个列表#TESTp0=[5,2,10]#print( error(p0,Xi,Yi) )###主函数从此开始###s="Test the number of iteration"#试验最小二乘法函数leastsq得调用几次error函数才能找到使得均方误差之和最小的a~cPara=leastsq(error,p0,args=(Xi,Yi,s))#把error函数中除了p以外的参数打包到args中a,b,c=Para[0]print"a=",a,'\n',"b=",b,"c=",c
###绘图,看拟合效果###import matplotlib.pyplot as plt
plt.figure(figsize=(8,6))plt.scatter(Xi,Yi,color="red",label="Sample Point",linewidth=3)#画样本点x=np.linspace(-5,5,1000)y=a*x**2+b*x+c
plt.plot(x,y,color="orange",label="Fitting Curve",linewidth=2)#画拟合曲线plt.legend()plt.show()
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」