python科学计算之scipy——optimize用法


Posted in Python onNovember 25, 2019

写在前面

SciPy的optimize模块提供了许多数值优化算法,下面对其中的一些记录。

非线性方程组求解

SciPy中对非线性方程组求解是fslove()函数,它的调用形式一般为fslove(fun, x0),fun是计算非线性方程组的误差函数,它需要一个参数x,fun依靠x来计算线性方程组的每个方程的值(或者叫误差),x0是x的一个初始值。

"""
计算非线性方程组:
  5x1+3 = 0
  4x0^2-2sin(x1x2)=0
  x1x2-1.5=0
"""
## 误差函数
def fun(x):
  x0,x1,x2 = x.tolist()
  return[5*x1+3,4x0^2-2sin(x1x2),x1x2-1.5]

result = optimize.fsolve(fun,[1,1,1])
## result
[-0.70622057  -0.6  -2.5]

在计算非线性方程中的解时,比如像坐标上升算法,其中需要用到未知数的导数,同样,scipy的fslove()也提供了fprime参数传递未知数的雅各比矩阵从而加速计算,传递的雅各比矩阵每一行时某一方程对各个未知数的导数。对于上面的例子,我们可以写下如下的雅各比矩阵传入。

def j(x):
  x0,x1,x2 = x.tolist()
  return[[0,5,0],[8*x0,-2*x2*cos(x1*x2],[0,x2,x1]]

result = optimize.fsolve(fun,[1,1,1],fprime=j)
#result
[-0.70622057  -0.6  -2.5]

scipy的内部在实现fslove时应该时应该是利用了坐标上升算法或者梯度相关优化算法,但本人没有考证,有兴趣的可以看看源码。

最小二乘拟合

关于最小二乘算法的理论这里并不想谈,网上解释的文章也挺多,在 optimize模块中,可以使用leastsq()对数据进行最小二乘拟合计算。 leastsq()的用法很简单,只需要将计箅误差的函数和待确定参数的初始值传递给它即可。

x = np.array([8.19,2.72,6.39,8.71,4.7,2.66,3.78])
y = np.array([7.01,2.78,6.47,6.71,4.1,4.23,4.05])
def residual(p):
  k,b = p
  return y-(k*x+b)
r = optimize.leastsq(residual,[1,0])
k,b = r[0]
# print k
.613495349193
# print b
.79409254326
def func(x,p):
  """
    计算的正弦波 :A*sin(2*pi*k*x+theta)
  """
  A,k,theta = p
  return A*sin(2*np.pi*k*x+theta)

def redis(p,y,x):
  return y-func(x,p)

x = np.linspace(0,2*np.pi,100)
A,k,theta = 10,0.34,np.pi/6
y0 = func(x,[A,k,theta])
# 加入噪声
np.random.seed(0)
y1 = y0+2*np.random.randn(len(x))
p0 = [7,0.40,0]
# p0是A,k,theta的初始值,y1,x要拟合的数据
plsq = optimize.leastsq(redis, p0,args=(y1,x))
print [A,k,theta] #真是的参数值
print plsq[0]  #拟合后的参数值

对于像正弦波或者余弦波的曲线拟合,optimize提供curve_fit()函数,它的使用方式和leastq()稍有不同,它直接计算曲线的值,比如上面的拟合正弦波可以用cureve_fit()来写。

def func2(x,p):
  """
    计算的正弦波 :A*sin(2*pi*k*x+theta)
  """
  A,k,theta = p
  return A*sin(2*np.pi*k*x+theta)
ret,_=optimize.curve_fit(func2,x,y1,p0=p0)

该函数有一个缺点就是对于初始值敏感,如果初始频率和真实频率值差太多,会导致最后无法收敛到真是频率。

局部最小值

optimize模块还提供了常用的最小值算法如:Nelder-Mead、Powell、CG、BFGS、Newton-CG等,在这些最小值计算时,往往会传入一阶导数矩阵(雅各比矩阵)或者二阶导数矩阵(黑塞矩阵)从而加速收敛,这些最优化算法往往不能保证收敛到全局最小值,大部分会收敛到局部极小值。这些函数的调用方式为:

optimize.minimize(target_fun,init_val,method,jac,hess) 
target_fun:函数的表达式计算; 
init_val:初始值; 
method:最小化的算法; 
jac:雅各比矩阵 
hess:黑塞矩阵。

全局最小值算法

全局最小值使用optimize.basinhopping()来实现,这个函数首先要定义一个误差计算方式,比如平方误差函数,niter时迭代的次数,最后还需要一个局部极小值优化方法,minimizer_kwargs传入。比如上面的正弦函数拟合:

def func1(x,p):
  """
    计算的正弦波 :A*sin(2*pi*k*x+theta)
  """
  A,k,theta = p
  return A*sin(2*np.pi*k*x+theta)
def func_error(p,y,x):
  return np.sum((y-func1(x,p)**2)
result = optimize.basinhopping(func_error,[1,1,1],niter=10,
              minimizer_kwargs={"method":"L-BFGS-B",
                        "args":(y1,x1)})
## [1,1,1]是传入的初始值,args是需要拟合的数据

以上这篇python科学计算之scipy——optimize用法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python标准库defaultdict模块使用示例
Apr 28 Python
在Python中处理字符串之isdecimal()方法的使用
May 20 Python
python一键去抖音视频水印工具
Sep 14 Python
使用python itchat包爬取微信好友头像形成矩形头像集的方法
Feb 21 Python
python集合是否可变总结
Jun 20 Python
解决Python正则表达式匹配反斜杠''\''问题
Jul 17 Python
Python使用grequests(gevent+requests)并发发送请求过程解析
Sep 25 Python
Python实现获取当前目录下文件名代码详解
Mar 10 Python
python中turtle库的简单使用教程
Nov 11 Python
windows+vscode安装paddleOCR运行环境的步骤
Nov 11 Python
python爬虫用scrapy获取影片的实例分析
Nov 23 Python
python实现定时发送邮件到指定邮箱
Dec 23 Python
基于python中__add__函数的用法
Nov 25 #Python
pygame库实现移动底座弹球小游戏
Apr 14 #Python
python科学计算之numpy——ufunc函数用法
Nov 25 #Python
OpenCV里的imshow()和Matplotlib.pyplot的imshow()的实现
Nov 25 #Python
Python解析json代码实例解析
Nov 25 #Python
python实现差分隐私Laplace机制详解
Nov 25 #Python
python3实现弹弹球小游戏
Nov 25 #Python
You might like
php 空格,换行,跳格使用说明
2009/12/18 PHP
PHP无限分类(树形类)
2013/09/28 PHP
yii上传文件或图片实例
2014/04/01 PHP
PHP制作用户注册系统
2015/10/23 PHP
javascript 贪吃蛇实现代码
2008/11/22 Javascript
js中将字符串转换成json的三种方式
2011/01/12 Javascript
浅谈JavaScript Date日期和时间对象
2014/12/29 Javascript
JavaScript实现页面跳转的几种常用方式
2015/11/28 Javascript
jQuery实现点击弹出背景变暗遮罩效果实例代码
2016/06/24 Javascript
Angular2搜索和重置按钮过场动画
2017/05/24 Javascript
JS给按钮添加跳转功能类似a标签
2017/05/30 Javascript
详解升级react-router 4 踩坑指南
2017/08/14 Javascript
js使用html2canvas实现屏幕截取的示例代码
2017/08/28 Javascript
微信小程序常用简易小函数总结
2019/02/01 Javascript
基于node简单实现RSA加解密的方法步骤
2019/03/21 Javascript
关于layui 弹出层一闪而过就消失的解决方法
2019/09/09 Javascript
vant 时间选择器--开始时间和结束时间实例
2020/11/04 Javascript
[41:52]DOTA2-DPC中国联赛 正赛 CDEC vs Dynasty BO3 第二场 2月22日
2021/03/11 DOTA
Python之lambda匿名函数及map和filter的用法
2019/03/05 Python
python3通过selenium爬虫获取到dj商品的实例代码
2019/04/25 Python
python3.4+pycharm 环境安装及使用方法
2019/06/13 Python
Python中typing模块与类型注解的使用方法
2019/08/05 Python
Python socket 套接字实现通信详解
2019/08/27 Python
wxPython:python首选的GUI库实例分享
2019/10/05 Python
Python yield生成器和return对比代码实例
2020/04/20 Python
python实现人像动漫化的示例代码
2020/05/17 Python
Python爬虫分析微博热搜关键词的实现代码
2021/02/22 Python
HTML+CSS3 模仿Windows7 桌面效果
2010/06/17 HTML / CSS
英国最全面的橄榄球联盟门票网站:Live Rugby Tickets
2018/10/06 全球购物
New Balance澳大利亚官网:运动鞋和健身服装
2019/02/23 全球购物
行政经理的岗位职责
2013/11/23 职场文书
中学教师培训制度
2014/01/31 职场文书
会计毕业自我鉴定
2014/02/05 职场文书
狼和鹿教学反思
2014/02/05 职场文书
中考冲刺决心书
2014/03/11 职场文书
python之django路由和视图案例教程
2021/07/26 Python