【NumPy】NumPy线性代数模块详解:掌握numpy.linalg的核心功能

🧑 博主简介:阿里巴巴嵌入式技术专家,深耕嵌入式+人工智能领域,具备多年的嵌入式硬件产品研发管理经验。

📒 博客介绍:分享嵌入式开发领域的相关知识、经验、思考和感悟,欢迎关注。提供嵌入式方向的学习指导、简历面试辅导、技术架构设计优化、开发外包等服务,有需要可加文末联系方式联系。

💬 博主粉丝群介绍:① 群内高中生、本科生、研究生、博士生遍布,可互相学习,交流困惑。② 热榜top10的常客也在群里,也有数不清的万粉大佬,可以交流写作技巧,上榜经验,涨粉秘籍。③ 群内也有职场精英,大厂大佬,可交流技术、面试、找工作的经验。④ 进群免费赠送写作秘籍一份,助你由写作小白晋升为创作大佬。⑤ 进群赠送CSDN评论防封脚本,送真活跃粉丝,助你提升文章热度。有兴趣的加文末联系方式,备注自己的CSDN昵称,拉你进群,互相学习共同进步。

NumPy线性代数模块详解:掌握numpy.linalg的核心功能

  • 1. NumPy库介绍
  • 2. linalg 模块介绍
    • 常用的 `numpy.linalg` 函数概述:
    • 2.1 函数定义及参数说明
      • linalg.inv
      • linalg.det
      • linalg.eig
      • linalg.solve
      • linalg.norm
  • 3. 示例代码
    • 3.1 计算矩阵的逆矩阵
    • 3.2 计算矩阵的行列式
    • 3.3 计算矩阵的特征值与特征向量
    • 3.4 解决线性方程组
    • 3.5 计算矩阵或向量的范数
  • 4. 实际应用:主成分分析(PCA)
  • 5. 总结

在这里插入图片描述

1. NumPy库介绍

NumPy(Numerical Python)是Python编程语言的一个核心库,用于大量的科学计算。 NumPy提供了对大型、多维数组和矩阵的支持,并且附带了大量的数学函数库来进行这些数组的操作。它是许多高级数据分析和机器学习库的基础,比如Pandas、SciPy和Scikit-learn。

NumPy的主要优势在于其数组对象(ndarray),这种对象比Python列表更为高效,可以存储同类型的数据元素,并且支持各种复杂的数值运算。对于需要进行大量数值计算和数据处理的应用程序,NumPy是首选工具。

2. linalg 模块介绍

numpy.linalg 模块提供了一组用于线性代数的基础函数。这些函数涵盖了矩阵分解、矩阵特征值与特征向量、求解线性系统等操作。线性代数是科学计算中一个重要的部分,NumPy通过numpy.linalg模块为用户提供高效且功能齐全的线性代数工具。

常用的 numpy.linalg 函数概述:

  • linalg.inv: 计算矩阵的逆矩阵。
  • linalg.det: 计算矩阵的行列式。
  • linalg.eig: 计算矩阵的特征值与特征向量。
  • linalg.solve: 解决线性方程组。
  • linalg.norm: 计算矩阵或向量的范数。

2.1 函数定义及参数说明

linalg.inv

计算逆矩阵。

numpy.linalg.inv(a)

参数:

  • a: 输入方阵。

返回:

  • out: 输入矩阵的逆矩阵。

linalg.det

计算矩阵的行列式。

numpy.linalg.det(a)

参数:

  • a: 输入方阵。

返回:

  • 行列式的值。

linalg.eig

计算矩阵的特征值与特征向量。

numpy.linalg.eig(a)

参数:

  • a: 输入方阵。

返回:

  • w: 特征值数组。
  • v: 特征向量构成的二维数组。

linalg.solve

解决线性方程组。

numpy.linalg.solve(a, b)

参数:

  • a: 系数矩阵。
  • b: 目标矩阵(或向量)。

返回:

  • 解向量或矩阵。

linalg.norm

计算矩阵或向量的范数。

numpy.linalg.norm(x, ord=None, axis=None, keepdims=False)

参数:

  • x: 输入数组。
  • ord: 范数类型(默认为2范数)。
  • axis: 计算范数的维度。
  • keepdims: 布尔值,是否保持原数组的维度。

返回:

  • 范数值。

3. 示例代码

接下来我们通过一些示例代码来展示numpy.linalg模块的具体用法。

3.1 计算矩阵的逆矩阵

在这个示例中,我们将展示如何计算一个方阵的逆矩阵。

import numpy as np# 创建一个二维数组表示矩阵
A = np.array([[1, 2],[3, 4]])# 计算矩阵的逆矩阵
A_inv = np.linalg.inv(A)
print("Inverse of A:\n", A_inv)

输出如下:

Inverse of A:[[-2.   1. ][ 1.5 -0.5]]

3.2 计算矩阵的行列式

行列式是矩阵的重要属性之一,尤其在求解线性方程和矩阵特征值时起重要作用。

import numpy as np# 创建一个二维数组表示矩阵
A = np.array([[1, 2],[3, 4]])# 计算矩阵的行列式
det_A = np.linalg.det(A)
print("Determinant of A:", det_A)

输出如下:

Determinant of A: -2.0000000000000004

3.3 计算矩阵的特征值与特征向量

特征值与特征向量在很多领域有应用,如振动分析、图像处理和物理学。

import numpy as np# 创建一个二维数组表示矩阵
A = np.array([[1, 2],[2, 1]])# 计算矩阵的特征值与特征向量
eigenvalues, eigenvectors = np.linalg.eig(A)
print("Eigenvalues of A:", eigenvalues)
print("Eigenvectors of A:\n", eigenvectors)

输出如下:

Eigenvalues of A: [ 3. -1.]
Eigenvectors of A:[[ 0.70710678 -0.70710678][ 0.70710678  0.70710678]]

3.4 解决线性方程组

求解形如 (Ax = b) 的线性方程组。

import numpy as np# 创建系数矩阵A和目标向量b
A = np.array([[3, 1],[1, 2]])
b = np.array([9, 8])# 解决线性方程组
x = np.linalg.solve(A, b)
print("Solution x:", x)

输出如下:

Solution x: [2. 3.]

3.5 计算矩阵或向量的范数

范数是衡量矩阵或向量大小的一种方式。

import numpy as np# 创建一个二维数组表示矩阵
A = np.array([[1, 2],[3, 4]])# 计算矩阵的Frobenius范数
norm_A = np.linalg.norm(A)
print("Frobenius norm of A:", norm_A)# 创建一个一维数组表示向量
v = np.array([1, 2, 3])# 计算向量的2范数(欧几里得范数)
norm_v = np.linalg.norm(v)
print("2-norm of v:", norm_v)

输出如下:

Frobenius norm of A: 5.477225575051661
2-norm of v: 3.7416573867739413

4. 实际应用:主成分分析(PCA)

主成分分析(PCA)是数据降维的经典方法。这里我们展示如何使用 numpy.linalg 进行PCA实现。

import numpy as np# 创建一个示例数据集
X = np.array([[2.5, 2.4], [0.5, 0.7], [2.2, 2.9], [1.9, 2.2], [3.1, 3.0], [2.3, 2.7], [2, 1.6], [1, 1.1], [1.5, 1.6], [1.1, 0.9]])# 减去数据的均值
X_mean = X - np.mean(X, axis=0)# 计算协方差矩阵
cov_matrix = np.cov(X_mean, rowvar=False)# 计算协方差矩阵的特征值与特征向量
eigenvalues, eigenvectors = np.linalg.eig(cov_matrix)# 将特征值排序,并获得相应的特征向量
sorted_index = np.argsort(eigenvalues)[::-1]
sorted_eigenvalues = eigenvalues[sorted_index]
sorted_eigenvectors = eigenvectors[:, sorted_index]# 选择前两个主成分
n_components = 2
eigenvector_subset = sorted_eigenvectors[:, 0:n_components]# 将数据投影到主成分空间
X_reduced = np.dot(eigenvector_subset.transpose(), X_mean.transpose()).transpose()print("Reduced data:\n", X_reduced)

输出如下:

Reduced data:[[ 0.82797019  0.17511531][-1.77758033  0.14285723][ 0.99219749  0.38437499][ 0.27421042  0.13041721][ 1.67580142 -0.20949846][ 0.9129491   0.17528244][ 0.09910944 -0.3498247 ][-1.14457216  0.04641726][-0.43804614  0.01776463][-1.40196572 -0.384375  ]]

5. 总结

NumPy是进行科学计算的强大工具,该库的numpy.linalg模块则专门提供了各种线性代数运算的支持。在这篇文章中,我们详细介绍了numpy.linalg中的一些常用函数,并通过丰富的示例演示了它们的具体应用。

通过这些示例,我们了解到:

  1. numpy.linalg.inv 用于计算矩阵的逆矩阵。
  2. numpy.linalg.det 用于计算矩阵的行列式。
  3. numpy.linalg.eig 用于计算矩阵的特征值与特征向量。
  4. numpy.linalg.solve 用于解决线性方程组。
  5. numpy.linalg.norm 用于计算矩阵或向量的范数。

此外,我们还展示了numpy.linalg在主成分分析(PCA)中的实际应用,展示了如何使用这些线性代数函数来进行数据降维操作。

掌握NumPy中的linalg模块,不仅能够有效完成各种线性代数计算,还能在实际的数据处理和分析任务中提供重要支持。如果你对更多的NumPy功能感兴趣,建议继续深入学习和探索。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/18666.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

多年期货盈利的秘诀就是亏了就跑

不怎么看消息面,尤其期货,外汇。 正大招主账户:欧美4恒指26小恒12 欢迎咨询代理 详YJCFPL 坚持学习,吸收别人的经验,为我所用。 独立思考,培养良好的生活习惯。 我能活到现在的秘诀就是:亏了就赶…

Hexo最新实战:(一)Hexo7.0+GitHub Pages博客搭建

前言 很多平台都能写博客还有创作激励,为什么我又要搭一个?为什么这次要选择用Hexo框架? 对应的原因是流量自由和省钱,第一个,很多平台能写但不是都有收益,而且平台有自身的规则,比如会屏蔽一…

【区块链】外部应用程序与区块链进行交互

一,外部应用程序与区块链进行交互案例目标与流程 1.1案例目标 掌握FISCO BCOS应用环境的搭建 与使用(FISCO BCOSWeBASE)掌握基于Java SpringBoot的应 用程序后端项目搭建与开发。掌握应用程序后端与FISCO BCOS 链的交互。掌握应用程序前端…

『大模型笔记』量化 vs 剪枝 vs 蒸馏:为推理优化神经网络!

量化 vs 剪枝 vs 蒸馏:为推理优化神经网络! 文章目录 一. 量化 vs 剪枝 vs 蒸馏:为推理优化神经网络!1.1. 量化(Quantization)1.2. 剪枝(purning)1.3. 知识蒸馏(Knowledge Distillation,也称为模型蒸馏)1.4. 工程优化(Engineering Optimizations)1.5. 总结二. 参考…

【旅行商问题的优化】

#include<bits/stdc.h> // 包含标准库的头文件using namespace std; // 使用标准命名空间template <class Type> // 模板声明&#xff0c;Type为类型参数 class Traveling{ // 定义Traveling类friend Type Tsp(int **, int[],int, Type); // 声明友元函数Tsp publi…

WPF hc:PropertyGrid 嵌套显示

重点&#xff1a; 编写Edit特性即可&#xff1a; public class ParameterEditor : PropertyEditorBase{public override FrameworkElement CreateElement(PropertyItem propertyItem){var pg new PropertyGrid();return pg;}public override DependencyProperty GetDependen…

2024/5/22 ARMday7

按键控制LED灯亮和灭 do_irq.c #include "key_it.h" //#include "led.h" extern void printf(const char *fmt, ...); unsigned int i 0; void do_irq(void) {//获取中断号unsigned int irqno(GICC->IAR & (0x3FF));switch (irqno){case 99://处…

Playwright 元素定位

一、get_by_XXXXX 1. get_by_role&#xff1a;根据元素角色进行定位, 常用的参数有两个&#xff0c;第一个是角色名称 role&#xff0c;第二个是元素的文本 name。其他参数的解释大家可以参考源码注释。 # 获取页面名称为确定的按钮 page.get_bt_role(button, name确定) pl…

cfa三级大神复习经验分享系列(一)

教材还是Notes? 对于愚钝如我之流&#xff0c;建议大家三级一定要看教材。Note很精华很浓缩&#xff0c;我觉得看过教材再看note感觉总结的很精辟&#xff0c;但是Note是以考点列的&#xff0c;而教材像小说一样娓娓道来&#xff0c;有逻辑有情节&#xff0c;如果不follow很难…

Android MIPI屏配置

参考资料&#xff1a;RockChip发布的DRM Display Driver Development Guide手册&#xff0c;以及网上大量相关博客资料 首先要拿到《屏幕硬件规格书》和《DataSheet》&#xff0c;软件配置主要依靠DataSheet提供数据支持。 查阅DataSheet里面on sequence和off sequence说明&a…

机器学习之爬山算法(Hill Climbing Algorithm)

爬山算法(Hill Climbing Algorithm)是一种简单而常见的启发式搜索算法,通常用于解决优化问题。它的基本思想类似于登山过程中爬升到山顶的过程,即从一个起始点开始,不断尝试向邻近的点移动,直到找到一个局部最优解。 下面是爬山算法的基本工作流程: 初始化:选择一个初…

关于同一个地址用作两个不同页面时,列表操作栏按钮混淆状态

同一个地址用作两个不同页面时&#xff0c;列表页的操作栏中有好多个按钮&#xff0c;如果用了v-if&#xff0c;可能会导致按钮混淆状态如disabled等属性混乱 解决方法1&#xff1a; 将v-if换成v-show&#xff0c;用了v-show之后意味着所有按钮都在只是在页面上隐藏了 解决方…

【python深度学习】——torch.min()

【python深度学习】——torch.min 1. torch.min()1.1 计算整个张量的最小值1.2 沿特定维度计算最小值1.3 比较两个张量 1. torch.min() torch.min()接受的参数如下: input: 输入的张量。dim: 沿指定维度寻找最小值。如果指定了该参数&#xff0c;返回一个元组&#xff0c;其中…

基于Vue+SpirngBoot的博客管理平台的设计与实现(论文+源码)_kaic

摘 要 随着当下社会的发展&#xff0c;互联网已经成为时代的主流&#xff0c;从此进入了互联网时代&#xff0c;对大部分人来说&#xff0c;互联网在日常生活中的应用是越来越频繁&#xff0c;大家都在互联网当中互相交流、学习、娱乐。博客正是扮演这样一个角色。博客已成为当…

[Nodejs]使用adm-zip和fs-extra压缩打包后的文件

在此之前&#xff0c;操作目录、压缩文件是通过scripts来实现的&#xff0c;在windows机器上多有不便&#xff0c;需要通过linux命令行来实现cp、rm命令&#xff1a; "cpdist": "cp -r ./dist/* ../../qw-portal/assetAllocation/", "rmdist": …

实验八 单区域OSPF路由协议配置

一、实验目的 掌握 OSPF 动态路由协议的配置、诊断方法。 二、实验步骤 1、 运行Cisco Packet Tracer软件&#xff0c;在逻辑工作区放入三台路由器、两台工作站PC及一台笔记本&#xff0c;分别点击各路由器&#xff0c;打开其配置窗口&#xff0c;关闭电源&#xff0c;分别加…

如何选择云服务器

云服务器选择概述 在选择合适的云服务器时&#xff0c;需要综合考虑多个方面的因素&#xff0c;包括但不限于云服务器的类型、配置、价格、性能、安全性、可靠性、扩展性以及服务商的品牌信誉等。以下是根据搜索结果得出的详细分析和建议。 云服务器选择详解 云服务器类型选…

Python装饰器的应用

Python 中的装饰器是一种语法糖&#xff0c;可以在运行时&#xff0c;动态的给函数或类添加功能。装饰器本质上是一个函数&#xff0c;使用 函数名就是可实现绑定给函数的第二个功能 。它的作用就是在不修改被装饰对象源代码和调用方式的前提下为被装饰对象添加额外的功能。 …

策略模式代码

import java.util.*; enum TYPE { NORMAL,CASH_DISCOUNT,CASH_RETURN}; interface Cashsuper { public double acceptCash(double money); } class CashNormal implements CashSuper{// 正常收费子类 public double accptCash(double money){ return money; …

微信小程序如何在公共组件中改变某一个页面的属性值

需求 公共组件A改变页面B的属性isShow的值。 思路 首先目前我不了解可以直接在组件中改变页面的值的方法&#xff0c;所以我通过监听的方式在B页面监听app.js的某一属性值的改变从而改变B页面的值&#xff0c;众所周知app.js的某一属性值是很容易就能更改的。 app.js globa…