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中字符串类型json操作的注意事项
May 02 Python
Python探索之静态方法和类方法的区别详解
Oct 27 Python
详解Python中如何写控制台进度条的整理
Mar 07 Python
利用python库在局域网内传输文件的方法
Jun 04 Python
python批量修改文件夹及其子文件夹下的文件内容
Mar 15 Python
详解Python基础random模块随机数的生成
Mar 23 Python
django框架面向对象ORM模型继承用法实例分析
Jul 29 Python
学习Django知识点分享
Sep 11 Python
python selenium实现发送带附件的邮件代码实例
Dec 10 Python
Python ORM编程基础示例
Feb 02 Python
Python类的动态绑定实现原理
Mar 21 Python
Python Django form 组件动态从数据库取choices数据实例
May 19 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数组函数序列之array_keys() - 获取数组键名
2011/10/30 PHP
php使用sql数据库 获取字段问题介绍
2013/08/12 PHP
smarty中改进truncate使其支持中文的方法
2016/05/30 PHP
轻松实现php文件上传功能
2017/02/17 PHP
PHP文件类型检查及fileinfo模块安装使用详解
2019/05/09 PHP
PHP 对象接口简单实现方法示例
2020/04/13 PHP
jquery插件 cluetip 关键词注释
2010/01/12 Javascript
利用javascript判断文件是否存在
2013/12/31 Javascript
JS判断浏览器是否支持某一个CSS3属性的方法
2014/10/17 Javascript
Underscore.js常用方法总结
2015/02/28 Javascript
js实现基于正则表达式的轻量提示插件
2015/08/29 Javascript
jQuery实现滑动页面固定顶部显示(可根据显示位置消失与替换)
2015/10/28 Javascript
javascript实现input file上传图片预览效果
2015/12/31 Javascript
jQuery配合coin-slider插件制作幻灯片效果的流程解析
2016/05/13 Javascript
js弹出窗口返回值的简单实例
2016/05/28 Javascript
jQuery层级选择器实例代码
2017/02/06 Javascript
详解angularjs结合pagination插件实现分页功能
2017/02/10 Javascript
vue loadmore组件上拉加载更多功能示例代码
2017/07/19 Javascript
Angular模板表单校验方法详解
2017/08/11 Javascript
详解angularjs跨页面传参遇到的一些问题
2018/11/01 Javascript
小程序scroll-view安卓机隐藏横向滚动条的实现详解
2019/05/16 Javascript
使用watch在微信小程序中实现全局状态共享
2019/06/03 Javascript
angularjs自定义过滤器demo示例
2019/08/24 Javascript
vue中destroyed方法的使用说明
2020/07/21 Javascript
Vue 列表页带参数进详情页的操作(router-link)
2020/11/13 Javascript
python下10个简单实例代码
2017/11/15 Python
使用matplotlib画散点图的方法
2018/05/25 Python
Python设计模式之组合模式原理与用法实例分析
2019/01/11 Python
Python注释、分支结构、循环结构、伪“选择结构”用法实例分析
2020/01/09 Python
Selenium环境变量配置(火狐浏览器)及验证实现
2020/12/07 Python
澳大利亚家用电器在线商店:Billy Guyatts
2020/05/05 全球购物
应届毕业生求职信范文分享
2013/12/26 职场文书
关于环保的标语
2014/06/13 职场文书
房屋出租委托书格式
2014/09/23 职场文书
大雁塔英文导游词
2015/02/10 职场文书
装配车间主任岗位职责
2015/04/08 职场文书