返回顶部
首页 > 资讯 > 后端开发 > Python >Python如何实现两种稀疏矩阵的最小二乘法
  • 360
分享到

Python如何实现两种稀疏矩阵的最小二乘法

2023-07-05 06:07:22 360人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

今天小编给大家分享一下python如何实现两种稀疏矩阵的最小二乘法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。最小二乘法s

今天小编给大家分享一下python如何实现两种稀疏矩阵的最小二乘法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

最小二乘法

scipy.sparse.linalg实现了两种稀疏矩阵最小二乘法lsqr和lsmr,前者是经典算法,后者来自斯坦福优化实验室,据称可以比lsqr更快收敛。

这两个函数可以求解Ax=b,或arg minx ∥Ax−b∥2,或arg minx ∥Ax−b∥2 +d2∥x−x0∥2,其中A必须是方阵或三角阵,可以有任意秩。

通过设置容忍度at ,bt,可以控制算法精度,记r=b-A为残差向量,如果Ax=b是相容的,lsqr在∥r∥⩽at∗∥A∥⋅∥x∥+bt∥b∥时终止;否则将在∥ATr∥⩽at∥A∥⋅∥r∥。

如果两个容忍度都是10−6 ,最终的∥r∥将有6位精度。

lsmr的参数如下

lsmr(A, b, damp=0.0, atol=1e-06, btol=1e-06, conlim=100000000.0, maxiter=None, show=False, x0=None)

参数解释:

  • A 可谓稀疏矩阵、数组以及线性算子

  • b 为数组

  • damp 阻尼系数,默认为0

  • atol, btol 截止容忍度,是lsqr迭代的停止条件,即at ,bt 。

  • conlim 另一个截止条件,对于最小二乘问题,conlim应该小于108,如果Ax=b是相容的,则conlim最大可以设到1012

  • iter_limint 迭代次数

  • show 如果为True,则打印运算过程

  • calc_var 是否估计(A.T@A + damp**2*I)^{-1}的对角线

  • x0 阻尼系数相关

lsqr和lsmr相比,没有maxiter参数,但多了iter_lim, calc_va参数。

上述参数中,damp为阻尼系数,当其不为0时,记作δ,待解决的最小二乘问题变为

Python如何实现两种稀疏矩阵的最小二乘法

返回值

lsmr的返回值依次为:

  • x 即Ax=b中的x

  • istop 程序结束运行的原因

  • itn 迭代次数

  • nORMr ∥b−Ax

  • normar ∥AT (b−Ax)∥

  • norma ∥A∥

  • conda A的条件数

  • normx ∥x∥

lsqr的返回值为

  1. x 即Ax=b中的x

  2. istop 程序结束运行的原因

  3. itn 迭代次数

  4. r1norm Python如何实现两种稀疏矩阵的最小二乘法

  5. anorm 估计的Frobenius范数Aˉ

  6. acond Aˉ的条件数

  7. arnorm ∥ATr−δ2(x−x0)∥

  8. xnorm ∥x∥

  9. var (ATA)−1

二者的返回值较多,而且除了前四个之外,剩下的意义不同,调用时且须注意。

测试

下面对这两种算法进行验证,第一步就得先有一个稀疏矩阵

import numpy as npfrom scipy.sparse import csr_arraynp.random.seed(42)  # 设置随机数状态mat = np.random.rand(500,500)mat[mat<0.9] = 0csr = csr_array(mat)

然后用这个稀疏矩阵乘以一个x,得到b

xs = np.arange(500)b = mat @ xs

接下来对这两个最小二乘函数进行测试

from scipy.sparse.linalg import lsmr, lsqrimport matplotlib.pyplot as pltmx = lsmr(csr, b)[0]qx = lsqr(csr, b)[0]plt.plot(xs, lw=0.5)plt.plot(mx, lw=0, marker='*', label="lsmr")plt.plot(qx, lw=0, marker='.', label="lsqr")plt.legend()plt.show()

为了对比清晰,对图像进行放大,可以说二者不分胜负

Python如何实现两种稀疏矩阵的最小二乘法

接下来比较二者的效率,500 &times; 500 500\times500500&times;500这个尺寸显然已经不合适了,用2000&times;2000

from timeit import timeitnp.random.seed(42)  # 设置随机数状态mat = np.random.rand(500,500)mat[mat<0.9] = 0csr = csr_array(mat)timeit(lambda : lsmr(csr, b), number=10)timeit(lambda : lsqr(csr, b), number=10)

测试结果如下

>>> timeit(lambda : lsqr(csr, b), number=10)
0.5240591000001587
>>> timeit(lambda : lsmr(csr, b), number=10)
0.6156221000019286

看来lsmr并没有更快,看来斯坦福也不靠谱(滑稽)。

以上就是“Python如何实现两种稀疏矩阵的最小二乘法”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网Python频道。

--结束END--

本文标题: Python如何实现两种稀疏矩阵的最小二乘法

本文链接: https://lsjlt.com/news/350062.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python实现两种稀疏矩阵的最小二乘法
    目录最小二乘法返回值测试最小二乘法 scipy.sparse.linalg实现了两种稀疏矩阵最小二乘法lsqr和lsmr,前者是经典算法,后者来自斯坦福优化实验室,据称可以比lsqr...
    99+
    2023-02-26
    Python稀疏矩阵最小二乘法 Python稀疏矩阵 Python 最小二乘法
  • Python如何实现两种稀疏矩阵的最小二乘法
    今天小编给大家分享一下Python如何实现两种稀疏矩阵的最小二乘法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。最小二乘法s...
    99+
    2023-07-05
  • python如何实现矩阵乘法
    小编给大家分享一下python如何实现矩阵乘法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!矩阵相乘需要前面矩阵的行数与后面矩阵的列数相同方可相乘。第一步,先将前面矩阵的每一行分别与后面矩阵的列相乘,作为结果矩阵的行列;第...
    99+
    2023-06-26
  • java实现稀疏矩阵的压缩与解压的方法
    目录任务要求思路分析稀疏矩阵的压缩稀疏矩阵的解压代码实现任务要求 把棋盘当作一个稀疏矩阵,0表示没棋,1表示黑棋,2表示蓝棋。 把该稀疏矩阵压缩以三元组形式表示并以文件形式保存,再写...
    99+
    2024-04-02
  • NumPy如何实现矩阵乘法
    这篇文章主要介绍NumPy如何实现矩阵乘法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!NumPy 支持的几类矩阵乘法也很重要。元素级乘法你已看过了一些元素级乘法。你可以使用 multiply 函数或 * 运算符来实...
    99+
    2023-06-14
  • C/C++如何实现两矩阵相乘之模拟法
    目录数学中两矩阵怎么相乘C/C++语言实现总结数学中两矩阵怎么相乘 矩阵相乘需要前面矩阵的列数与后面矩阵的行数相同方可相乘。 将前面矩阵的第i行各元素分别与后面矩阵的第j列相应位置元...
    99+
    2023-02-06
    c++两个矩阵相乘 C++矩阵相乘 c++矩阵运算
  • python机器学习MATLAB最小二乘法的两种解读
    目录最小二乘法代价函数与最小二乘法向量到子空间的距离与最小二乘法最小二乘法与多项式拟合多项式拟合结果绘图:最小二乘法与多元线性回归多元线性回归结果绘图:最小二乘法 大部分的最小二乘法...
    99+
    2024-04-02
  • Python怎么调用实现最小二乘法
    所谓线性最小二乘法,可以理解为是解方程的延续,区别在于,当未知量远小于方程数的时候,将得到一个无解的问题。最小二乘法的实质,是保证误差最小的情况下对未知数进行赋值。最小二乘法是非常经典的算法,而且这个名字我们在高中的时候就已经接触了,属于极...
    99+
    2023-05-19
    Python
  • 如何在python项目中实现一个最小二乘法
    这篇文章给大家介绍如何在python项目中实现一个最小二乘法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、最小二乘法是什么最小二乘法Least Square Method,做为分类回归算法的基础,有着悠久的历史(由...
    99+
    2023-06-06
  • Python调用实现最小二乘法的方法详解
    目录numpy实现scipy封装速度对比补充所谓线性最小二乘法,可以理解为是解方程的延续,区别在于,当未知量远小于方程数的时候,将得到一个无解的问题。最小二乘法的实质,是保证误差最小...
    99+
    2023-05-17
    Python调用最小二乘法 Python实现最小二乘法 Python最小二乘法
  • PHP如何使用数组循环来实现矩阵乘法
    这篇文章主要介绍“PHP如何使用数组循环来实现矩阵乘法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“PHP如何使用数组循环来实现矩阵乘法”文章能帮助大家解决问题。什么是矩阵乘法在数学中,一个矩阵是由...
    99+
    2023-07-06
  • Python数据拟合实现最小二乘法示例解析
    目录线性拟合高阶多项式多自变量指数函数所谓最小二乘法,即通过对数据进行拟合,使得拟合值与样本值的方差最小。 线性拟合 这个表达式还是非常简单的。 对于有些情况,我们往往选取自然序...
    99+
    2024-04-02
  • 使用Python怎么实现一个曲线拟合的最小二乘法
    今天就跟大家聊聊有关使用Python怎么实现一个曲线拟合的最小二乘法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。模块导入import numpy as ...
    99+
    2023-06-06
  • Python实现求解斐波那契第n项的解法(包括矩阵乘法+快速幂)
    斐波那契数列 首先我们来定义一下斐波那契数列: 即数列的第0项: 算法一:递归 递归计算的节点个数是O(2ⁿ)的级别的,效率很低,存在大量的重复计算。 比如: f(...
    99+
    2024-04-02
  • Java实现最小生成树MST的两种解法
    目录一、prim算法二、kruskal算法一、prim算法 时间复杂度较之kruskal较高 通俗的解释就是: (1)从哪个点开始生成最小生成树都一样,最后的权值都是相同的 (2...
    99+
    2024-04-02
  • 如何进行Python矩阵转置中的二维数组的实际操作
    本篇文章给大家分享的是有关如何进行Python矩阵转置中的二维数组的实际操作,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。如果你对Python矩阵转置的实际应用操作方案的转置不...
    99+
    2023-06-17
  • NumPy 打包 Python 编程算法:如何实现高效的矩阵运算?
    NumPy 是 Python 编程中非常重要的一个库,它能够帮助我们实现高效的矩阵运算。本文将为大家介绍 NumPy 的基本使用方法,以及如何用 NumPy 实现高效的矩阵运算。 一、NumPy 简介 NumPy 是 Python 编程中非...
    99+
    2023-06-30
    打包 numy 编程算法
  • 如何用python实现中文输出的两种方法
    如何用python实现中文输出的两种方法,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。这篇Python学习教程主要介绍了python实现中文输出的两种方法,实例分析了Pyt...
    99+
    2023-06-02
  • JavaScript中二叉树如何实现查找最小值、最大值、给定值算法
    小编给大家分享一下JavaScript中二叉树如何实现查找最小值、最大值、给定值算法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!具体如下:function Node(data,...
    99+
    2024-04-02
  • Python如何实现列表的最小公倍数
    小编给大家分享一下Python如何实现列表的最小公倍数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. lcmfrom functools ...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作