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 相关文章推荐
wxPython使用系统剪切板的方法
Jun 16 Python
Python selenium 父子、兄弟、相邻节点定位方式详解
Sep 15 Python
谈谈如何手动释放Python的内存
Dec 17 Python
python实现随机调用一个浏览器打开网页
Apr 21 Python
Python处理中文标点符号大集合
May 14 Python
Python多进程方式抓取基金网站内容的方法分析
Jun 03 Python
django使用JWT保存用户登录信息
Apr 22 Python
python中wheel的用法整理
Jun 15 Python
tensorflow使用CNN分析mnist手写体数字数据集
Jun 17 Python
python 使用xlsxwriter循环向excel中插入数据和图片的操作
Jan 01 Python
浅谈Selenium+Webdriver 常用的元素定位方式
Jan 13 Python
python源码剖析之PyObject详解
May 18 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/04/26 PHP
如何使用jQuery+PHP+MySQL来实现一个在线测试项目
2015/04/26 PHP
盘点PHP和ASP.NET的10大对比!
2015/12/24 PHP
PHPstorm快捷键(分享)
2017/07/17 PHP
php使用pecl方式安装扩展操作示例
2019/08/12 PHP
JavaScript 读取元素的CSS信息的代码
2010/02/07 Javascript
Juery解决tablesorter中文排序和字符范围的方法
2015/05/06 Javascript
Js调用Java方法并互相传参的简单实例
2016/08/11 Javascript
bootstrap select插件封装成Vue2.0组件
2017/04/17 Javascript
angularjs2中父子组件的数据传递的实例代码
2017/07/05 Javascript
利用Angular2 + Ionic3开发IOS应用实例教程
2018/01/15 Javascript
最后说说Vue2 SSR 的 Cookies 问题
2018/05/25 Javascript
JS中比Switch...Case更优雅的多条件判断写法
2019/09/05 Javascript
vue v-for直接循环数字实例
2019/11/07 Javascript
JS document内容及样式操作完整示例
2020/01/14 Javascript
详解webpack-dev-middleware 源码解读
2020/03/23 Javascript
JavaScript ECMA-262-3 深入解析(二):变量对象实例详解
2020/04/25 Javascript
Python中join函数简单代码示例
2018/01/09 Python
python实现电脑自动关机
2018/06/20 Python
在Pycharm中自动添加时间日期作者等信息的方法
2019/01/16 Python
python将excel转换为csv的代码方法总结
2019/07/03 Python
Django logging配置及使用详解
2019/07/23 Python
PyCharm使用之配置SSH Interpreter的方法步骤
2019/12/26 Python
keras读取h5文件load_weights、load代码操作
2020/06/12 Python
html5绘制时钟动画
2014/12/15 HTML / CSS
Manuka Doctor美国官网:麦卢卡蜂蜜和蜂毒护肤
2016/12/25 全球购物
西班牙香水和化妆品连锁店:Druni
2019/05/05 全球购物
Java文件和目录(IO)操作
2014/08/26 面试题
初任培训自我鉴定
2013/10/07 职场文书
大学生就业推荐信范文
2013/11/29 职场文书
网络编辑职责
2014/03/01 职场文书
预备党员转正思想汇报
2014/09/26 职场文书
护理医院见习报告
2014/11/03 职场文书
少年的你:世界上没有如果,要在第一次就勇敢的反抗
2019/11/20 职场文书
python字典的元素访问实例详解
2021/07/21 Python
Java后端 Dubbo retries 超时重试机制的解决方案
2022/04/14 Java/Android