zoukankan      html  css  js  c++  java
  • numpy基础--线性代数

    以下代码的前提:import numpy as np

    线性代数(如矩阵乘法、矩阵分解、行列式以及其他方阵数学等)是任何数组库的重要组成部分。numpy提供了一个用于矩阵乘法的dot函数(既是一个数组方法也是numpy命名空间中的一个函数)。

     1 >>> x = np.array([[1, 2, 3], [4, 5, 6]]) 
     2 >>> y = np.array([[1, 2], [3, 4], [5, 6]]) 
     3 >>> x
     4 array([[1, 2, 3],
     5        [4, 5, 6]])
     6 >>> y
     7 array([[1, 2],
     8        [3, 4],
     9        [5, 6]])
    10 >>> np.dot(x, y) 
    11 array([[22, 28],
    12        [49, 64]])
    13 >>> x.dot(y)
    14 array([[22, 28],
    15        [49, 64]])
    16 >>>

    numpy.linalg中有一组标准的矩阵分解运算以及诸如求逆和行列式之类的东西。

     1 >>> from numpy.linalg import inv, qr
     2 >>> X = np.arange(9).reshape(3, 3) 
     3 >>> X
     4 array([[0, 1, 2],
     5        [3, 4, 5],
     6        [6, 7, 8]])
     7 >>> mat = X.T.dot(X) 
     8 >>> mat
     9 array([[45, 54, 63],
    10        [54, 66, 78],
    11        [63, 78, 93]])
    12 >>> inv(mat)
    13 array([[ 3.51843721e+13, -7.03687442e+13,  3.51843721e+13],
    14        [-7.03687442e+13,  1.40737488e+14, -7.03687442e+13],
    15        [ 3.51843721e+13, -7.03687442e+13,  3.51843721e+13]])
    16 >>> mat.dot(inv(mat)) 
    17 array([[ 0.79296875,  1.        , -0.2109375 ],
    18        [ 0.1484375 ,  1.        , -0.046875  ],
    19        [-0.74609375,  1.        ,  0.6171875 ]])
    20 >>> q, r = qr(mat)
    21 >>> q
    22 array([[-0.47673129,  0.77849894,  0.40824829],
    23        [-0.57207755,  0.07784989, -0.81649658],
    24        [-0.66742381, -0.62279916,  0.40824829]])
    25 >>> r
    26 array([[-9.43927963e+01, -1.15559666e+02, -1.36726535e+02],
    27        [ 0.00000000e+00, -1.40129810e+00, -2.80259620e+00],
    28        [ 0.00000000e+00,  0.00000000e+00,  3.55271368e-15]])
    29 >>>

    下表是常用的numpy.linalg函数。

    diag

    以一维数组的形式返回方阵的对角线(或非对角线)元素,或将一维数组转换为方阵(非对角线元素为0)

    dot

    矩阵乘法

    trace

    计算对角线元素的和

    det

    计算矩阵行列式

    eig

    计算方阵的本征值和本征向量

    inv

    计算方阵的逆

    pinv

    计算矩阵的Moore-Penrose伪逆

    qr

    计算QR分解

    svd

    计算奇异值分解(SVD)

    solve

    解线性方程组Ax=b,其中A为一个方阵

    lstsq

    计算Ax=b的最小二乘解

  • 相关阅读:
    Oracle-启动和关闭oracle的归档(ARCHIVELOG)模式
    Linux-数据表示方式
    Linux-21-30
    linux-1-10
    自律
    jenkins-修改系统时间
    jenkins-通过ssh username with private key配置节点服务器
    jenkins-slave开机自动启动
    mongodb-mongo使用
    mongodb-centos76yum安装mongodb
  • 原文地址:https://www.cnblogs.com/mrlayfolk/p/12249039.html
Copyright © 2011-2022 走看看