40python数据分析numpy基础之diag处理矩阵对角线元素

1 python数据分析numpy基础之diag处理矩阵对角线元素

python的numpy库的diag(v,k=0)函数,以一维数组的形式返回方阵的对角线元素,或将一维数组转换为方阵(非对角线元素为0)。

方阵:方形矩阵,行数和列数相等的矩阵。如果一个矩阵有n行和n列,则称为方阵。

矩阵:矩形阵列,由相同类型元素按矩形网格排列组成的二维结构。矩阵有2个维度,行和列,m×n的矩阵有m行n列。

主对角线:从矩阵的左上角到右下角的对角线,它的元素具有相同的行索引和列索引。

次对角线:从矩阵的右上角到左下角的对角线,它的元素的行索引+列索引=矩阵大小-1,a_ij,i+j=n-1,n为矩阵的行数或列数。

用法

python 复制代码
numpy.diag(v, k=0)

描述

numpy.diag(v,k=0),是一个用于创建和处理对角线数组的函数,提取矩阵对角线元素构造一维数组,或根据一维数组构造方阵。

入参

v:必选,列表、元组、数组,表示要处理的数组;

k:可选,默认为0,表示对角线位置;

1.1 入参v

numpy.diag(v,k=0)的入参v为必选入参;

如果v是二维数组,返回k位置的对角线;

如果v是一维数组,返回一个v作为k位置对角线的方阵,非对角线元素为0;

python 复制代码
>>> import numpy as np
# diag(v)创建和处理对角线元素的函数
# v为列表
>>> np.diag([[1,2,3],[4,5,6],[7,8,9]])
array([1, 5, 9])
# v为元组
>>> np.diag(((1,2,3),(4,5,6),(7,8,9)))
array([1, 5, 9])
# v为二维数组,提取矩阵对角线元素构造一维数组
>>> ar1=np.arange(1,10).reshape(3,3)
>>> ar1
array([[1, 2, 3],
       [4, 5, 6],
       [7, 8, 9]])
>>> np.diag(ar1)
array([1, 5, 9])
>>> np.arange(3)
array([0, 1, 2])
# v为一维数组,将一维数组作为主对角线,构造方阵
# 方阵的非对角线元素为0,行和列相等
>>> np.diag(np.arange(3))
array([[0, 0, 0],
       [0, 1, 0],
       [0, 0, 2]])

1.2 入参k

numpy.diag(v,k=0)的入参k为可选入参;

默认为0,返回主对角线;

小于0,返回主对角线左下方的对角线;

大于0,返回主对角线右上方的对角线;

python 复制代码
>>> import numpy as np
# diag(v,k=0)创建和处理对角线元素的函数
>>> ar1=np.arange(1,26).reshape(5,5)
>>> ar1
array([[ 1,  2,  3,  4,  5],
       [ 6,  7,  8,  9, 10],
       [11, 12, 13, 14, 15],
       [16, 17, 18, 19, 20],
       [21, 22, 23, 24, 25]])
# v为二维数组,k=0返回主对角线的元素构造一维数组
>>> np.diag(ar1,k=0)
array([ 1,  7, 13, 19, 25])
# v为二维数组,k<0返回主对角线左下方的元素构造一维数组
>>> np.diag(ar1,k=-1)
array([ 6, 12, 18, 24])
# v为二维数组,k>0返回主对角线右上方的元素构造一维数组
>>> np.diag(ar1,k=1)
array([ 2,  8, 14, 20])
>>> np.arange(3)
array([0, 1, 2])
# v为一维数组,k=0将一维数组作为主对角线构造方阵,非对角线元素为0
>>> np.diag(np.arange(3),k=0)
array([[0, 0, 0],
       [0, 1, 0],
       [0, 0, 2]])
# v为一维数组,k=-1将一维数组作为主对角线的左下方的对角线构造方阵,非对角线元素为0
>>> np.diag(np.arange(3),k=-1)
array([[0, 0, 0, 0],
       [0, 0, 0, 0],
       [0, 1, 0, 0],
       [0, 0, 2, 0]])
# v为一维数组,k=1将一维数组作为主对角线的右上方的对角线构造方阵,非对角线元素为0
>>> np.diag(np.arange(3),k=1)
array([[0, 0, 0, 0],
       [0, 0, 1, 0],
       [0, 0, 0, 2],
       [0, 0, 0, 0]])
相关推荐
爱丽_1 小时前
高维问题如何“降维计算”:矩阵映射、卷积与拆分汇总
深度学习·矩阵·cnn
chushiyunen3 小时前
python numpy包的使用
开发语言·python·numpy
MediaTea3 小时前
NumPy 函数手册:线性代数
线性代数·numpy
放下华子我只抽RuiKe56 小时前
深度学习 - 01 - NLP自然语言处理基础
前端·人工智能·深度学习·神经网络·自然语言处理·矩阵·easyui
工业互联网专业6 小时前
基于Python的广东旅游数据分析_flask+spider
python·数据分析·flask·毕业设计·源码·课程设计·spider
RFdragon10 小时前
分享本周所学——三维重建算法3D Gaussian Splatting(3DGS)
人工智能·线性代数·算法·机器学习·计算机视觉·矩阵·paddlepaddle
MediaTea15 小时前
NumPy 函数手册:文件读写
numpy
西***634715 小时前
什么是4:4:4超清画质?讯维矩阵在这方面有何技术优势?
矩阵·成都讯维
Kun丶17 小时前
Global Mapper 修改DEM
数据分析
炼丹炉大数据20 小时前
炼丹炉:宠物电商数据工具首选
大数据·数据分析·宠物