需要 numpy 库支持

保存链接

http://www.cnblogs.com/chamie/p/4870078.html

1.numpy的导入和使用

  1. from numpy import *;#导入numpy的库函数
  2. import numpy as np; #这个方式使用numpy的函数时,需要以np.开头。

2.矩阵的创建

由一维或二维数据创建矩阵

  1. >>> from numpy import *
    >>> a1=array([1,2,3])
    >>> a1
    array([1, 2, 3])
    >>> a1=mat(a1)
    >>> a1
    matrix([[1, 2, 3]])
    >>> shape(a1)
    (1, 3)
    >>> b=matrix([1,2,3])
    >>> shape(b)
    (1, 3)

创建常见的矩阵

  1. >>>data1=mat(zeros((3,3))) #创建一个3*3的零矩阵,矩阵这里zeros函数的参数是一个tuple类型(3,3)
  2. >>> data1
  3. matrix([[ 0., 0., 0.],
  4. [ 0., 0., 0.],
  5. [ 0., 0., 0.]])
  6. >>>data2=mat(ones((2,4))) #创建一个2*4的1矩阵,默认是浮点型的数据,如果需要时int类型,可以使用dtype=int
  7. >>> data2
  8. matrix([[ 1., 1., 1., 1.],
  9. [ 1., 1., 1., 1.]])
  10. >>>data3=mat(random.rand(2,2)) #这里的random模块使用的是numpy中的random模块,random.rand(2,2)创建的是一个二维数组,需要将其转换成#matrix
  11. >>> data3
  12. matrix([[ 0.57341802, 0.51016034],
  13. [ 0.56438599, 0.70515605]])
  14. >>>data4=mat(random.randint(10,size=(3,3))) #生成一个3*3的0-10之间的随机整数矩阵,如果需要指定下界则可以多加一个参数
  15. >>> data4
  16. matrix([[9, 5, 6],
  17. [3, 0, 4],
  18. [6, 0, 7]])
  19. >>>data5=mat(random.randint(2,8,size=(2,5))) #产生一个2-8之间的随机整数矩阵
  20. >>> data5
  21. matrix([[5, 4, 6, 3, 7],
  22. [5, 3, 3, 4, 6]])
  23. >>>data6=mat(eye(2,2,dtype=int)) #产生一个2*2的对角矩阵
  24. >>> data6
  25. matrix([[1, 0],
  26. [0, 1]])
  27.  
  28. a1=[1,2,3]
  29. a2=mat(diag(a1)) #生成一个对角线为1、2、3的对角矩阵
  30. >>> a2
  31. matrix([[1, 0, 0],
  32. [0, 2, 0],
  33. [0, 0, 3]])

3.常见的矩阵运算

1. 矩阵相乘

  1. >>>a1=mat([1,2]);
  2. >>>a2=mat([[1],[2]]);
  3. >>>a3=a1*a2 #1*2的矩阵乘以2*1的矩阵,得到1*1的矩阵
    >>> a3
    matrix([[5]])

2. 矩阵点乘

矩阵对应元素相乘

  1. >>>a1=mat([1,1]);
  2. >>>a2=mat([2,2]);
  3. >>>a3=multiply(a1,a2)
  4. >>> a3
  5. matrix([[2, 2]])

矩阵点乘

  1. >>>a1=mat([2,2]);
  2. >>>a2=a1*2>>>a2
  3. matrix([[4, 4]])

3.矩阵求逆,转置 
矩阵求逆

  1. >>>a1=mat(eye(2,2)*0.5)
  2. >>> a1
  3. matrix([[ 0.5, 0. ],
  4. [ 0. , 0.5]])
  5. >>>a2=a1.I #求矩阵matrix([[0.5,0],[0,0.5]])的逆矩阵
  6. >>> a2
  7. matrix([[ 2., 0.],
  8. [ 0., 2.]])

矩阵转置

  1. >>> a1=mat([[1,1],[0,0]])
  2. >>> a1
  3. matrix([[1, 1],
  4. [0, 0]])
  5. >>> a2=a1.T
  6. >>> a2
  7. matrix([[1, 0],
  8. [1, 0]])

4.计算矩阵对应行列的最大、最小值、和。

  1. 3>>>a1=mat([[1,1],[2,3],[4,2]])
    >>> a1
    matrix([[1, 1],
            [2, 3],
            [4, 2]])

计算每一列、行的和

  1. >>>a2=a1.sum(axis=0) #列和,这里得到的是1*2的矩阵
  2. >>> a2
  3. matrix([[7, 6]])
  4. >>>a3=a1.sum(axis=1) #行和,这里得到的是3*1的矩阵
  5. >>> a3
  6. matrix([[2],
  7. [5],
  8. [6]])
  9. >>>a4=sum(a1[1,:])  #计算第一行所有列的和,这里得到的是一个数值
  10. >>> a4
  11. 5                    #第0行:1+1;第2行:2+3;第3行:4+2

计算最大、最小值和索引

  1. >>>a1.max()   #计算a1矩阵中所有元素的最大值,这里得到的结果是一个数值
  2. 4
  3. >>>a2=max(a1[:,1]) #计算第二列的最大值,这里得到的是一个1*1的矩阵
  4. >>> a2
  5. matrix([[3]])
  6. >>>a1[1,:].max()  #计算第二行的最大值,这里得到的是一个一个数值
  7. 3
  8. >>>np.max(a1,0)  #计算所有列的最大值,这里使用的是numpy中的max函数
    matrix([[4, 3]])
  9. >>>np.max(a1,1)  #计算所有行的最大值,这里得到是一个矩阵
  10. matrix([[1],
            [3],
            [4]])
  11. >>>np.argmax(a1,0) #计算所有列的最大值对应在该列中的索引
    matrix([[2, 1]])
  12. >>>np.argmax(a1[1,:])  #计算第二行中最大值对应在该行的索引
    1

5.矩阵的分隔和合并 
矩阵的分隔,同列表和数组的分隔一致。

  1. >>>a=mat(ones((3,3)))
  2. >>> a
  3. matrix([[ 1., 1., 1.],
  4. [ 1., 1., 1.],
  5. [ 1., 1., 1.]])
  6. >>>b=a[1:,1:] #分割出第二行以后的行和第二列以后的列的所有元素
  7. >>> b
  8. matrix([[ 1., 1.],
  9. [ 1., 1.]])

矩阵的合并

  1. >>>a=mat(ones((2,2)))
  2. >>> a
  3. matrix([[ 1., 1.],
  4. [ 1., 1.]])
  5. >>>b=mat(eye(2))
  6. >>> b
  7. matrix([[ 1., 0.],
  8. [ 0., 1.]])
  9. >>>c=vstack((a,b)) #按列合并,即增加行数
  10. >>> c
  11. matrix([[ 1., 1.],
  12. [ 1., 1.],
  13. [ 1., 0.],
  14. [ 0., 1.]])
  15. >>>d=hstack((a,b)) #按行合并,即行数不变,扩展列数
  16. >>> d
  17. matrix([[ 1., 1., 1., 0.],
  18. [ 1., 1., 0., 1.]])

4.矩阵、列表、数组的转换

列表可以修改,并且列表中元素可以使不同类型的数据,如下:

  1. l1=[[1],'hello',3];

numpy中数组,同一个数组中所有元素必须为同一个类型,有几个常见的属性:

  1. >>>a=array([[2],[1]])
  2. >>> a
  3. array([[2],
  4. [1]])
  5. >>>dimension=a.ndim
  6. >>> dimension
  7. 2
  8. >>>m,n=a.shape
  9. >>> m
  10. 2
  11. >>> n
  12. 1
  13. >>>number=a.size #元素总个数
  14. >>> number
  15. 2
  16. >>>str=a.dtype #元素的类型
  17. >>> str
  18. dtype('int64')

numpy中的矩阵也有与数组常见的几个属性。 
它们之间的转换:

  1. >>>a1=[[1,2],[3,2],[5,2]] #列表
  2. >>> a1
  3. [[1, 2], [3, 2], [5, 2]]
  4. >>>a2=array(a1) #将列表转换成二维数组
  5. >>> a2
  6. array([[1, 2],
  7. [3, 2],
  8. [5, 2]])
  9. >>>a3=mat(a1) #将列表转化成矩阵
  10. >>> a3
  11. matrix([[1, 2],
  12. [3, 2],
  13. [5, 2]])
  14. >>>a4=array(a3) #将矩阵转换成数组
  15. >>> a4
  16. array([[1, 2],
  17. [3, 2],
  18. [5, 2]])
    >>>a41=a3.getA() #将矩阵转换成数组
    >>>a41
    array([[1,2]
           [3,2]
           [5,2]])
  19. >>>a5=a3.tolist() #将矩阵转换成列表
  20. >>> a5
  21. [[1, 2], [3, 2], [5, 2]]
  22. >>>a6=a2.tolist() #将数组转换成列表
  23. >>> a6
  24. [[1, 2], [3, 2], [5, 2]]

这里可以发现三者之间的转换是非常简单的,这里需要注意的是,当列表是一维的时候,将它转换成数组和矩阵后,再通过tolist()转换成列表是不相同的,需要做一些小小的修改。如下:

  1. >>>a1=[1,2,3] #列表
  2. >>>a2=array(a1)
  3. >>> a2
  4. array([1, 2, 3])
  5. >>>a3=mat(a1)
  6. >>> a3
  7. matrix([[1, 2, 3]])
  8. >>> a4=a2.tolist()
  9. >>> a4
  10. [1, 2, 3]
  11. >>> a5=a3.tolist()
  12. >>> a5
  13. [[1, 2, 3]]
  14. >>> a6=(a4==a5)
  15. >>> a6
  16. False
  17. >>> a7=(a4 is a5[0])
  18. >>> a7
  19. True

矩阵转换成数值,存在以下一种情况:

  1. >>> dataMat=mat([1])
  2. >>> val=dataMat[0,0] #这个时候获取的就是矩阵的元素的数值,而不再是矩阵的类型
  3. >>> val
  4. 1
  1.  

Python学习笔记5 【转载】基本矩阵运算_20170618的更多相关文章

  1. Python学习笔记——Day5(转载)

    python 编码转换 主要介绍了python的编码机制,unicode, utf-8, utf-16, GBK, GB2312,ISO-8859-1 等编码之间的转换. 常见的编码转换分为以下几种情 ...

  2. OpenCV之Python学习笔记

    OpenCV之Python学习笔记 直都在用Python+OpenCV做一些算法的原型.本来想留下发布一些文章的,可是整理一下就有点无奈了,都是写零散不成系统的小片段.现在看 到一本国外的新书< ...

  3. python学习笔记(五岁以下儿童)深深浅浅的副本复印件,文件和文件夹

    python学习笔记(五岁以下儿童) 深拷贝-浅拷贝 浅拷贝就是对引用的拷贝(仅仅拷贝父对象) 深拷贝就是对对象的资源拷贝 普通的复制,仅仅是添加了一个指向同一个地址空间的"标签" ...

  4. Python学习笔记(十二)—Python3中pip包管理工具的安装【转】

    本文转载自:https://blog.csdn.net/sinat_14849739/article/details/79101529 版权声明:本文为博主原创文章,未经博主允许不得转载. https ...

  5. python 学习笔记 13 -- 经常使用的时间模块之time

    Python 没有包括相应日期和时间的内置类型.只是提供了3个相应的模块,能够採用多种表示管理日期和时间值: *    time 模块由底层C库提供与时间相关的函数.它包括一些函数用于获取时钟时间和处 ...

  6. python 学习笔记 12 -- 写一个脚本获取城市天气信息

    近期在玩树莓派,前面写过一篇在树莓派上使用1602液晶显示屏,那么可以显示后最重要的就是显示什么的问题了. 最easy想到的就是显示时间啊,CPU利用率啊.IP地址之类的.那么我认为呢,假设可以显示当 ...

  7. python学习笔记整理——字典

    python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...

  8. VS2013中Python学习笔记[Django Web的第一个网页]

    前言 前面我简单介绍了Python的Hello World.看到有人问我搞搞Python的Web,一时兴起,就来试试看. 第一篇 VS2013中Python学习笔记[环境搭建] 简单介绍Python环 ...

  9. python学习笔记之module && package

    个人总结: import module,module就是文件名,导入那个python文件 import package,package就是一个文件夹,导入的文件夹下有一个__init__.py的文件, ...

  10. python学习笔记(六)文件夹遍历,异常处理

    python学习笔记(六) 文件夹遍历 1.递归遍历 import os allfile = [] def dirList(path): filelist = os.listdir(path) for ...

随机推荐

  1. springboot入门以及配置文件

    springboot入门以及配置文件 SpringBoot是什么? Spring Boot它本身并不提供Spring框架的核心特性以及扩展功能,只是用于快速.敏捷地开发新一代基于Spring框架的应用 ...

  2. springmvc的文件上传和JWT图形验证码

    相关pom依赖 <dependency> <groupId>commons-fileupload</groupId> <artifactId>commo ...

  3. go语言设计模式之memento

    memento.go package memento import ( "fmt" ) type State struct { Description string } type ...

  4. 201871010113-刘兴瑞《面向对象程序设计(java)》第七周学习总结

    项目 内容 这个作业属于哪个课程 <任课教师博客主页链接> https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 <作业链接地址>htt ...

  5. python爬虫初认识

    一.爬虫是什么? 如果我们把互联网比作一张大的蜘蛛网,数据便是存放于蜘蛛网的各个节点,而爬虫就是一只小蜘蛛, 沿着网络抓取自己的猎物(数据)爬虫指的是:向网站发起请求,获取资源后分析并提取有用数据的程 ...

  6. USACO Max Flow

    洛谷 P3128 [USACO15DEC]最大流Max Flow 洛谷传送门 JDOJ 3027: USACO 2015 Dec Platinum 1.Max Flow JDOJ传送门 Descrip ...

  7. eclipse3.7以后编译代码提示ambiguous 的解决方法

    Eclispe3.7以后在使用可变函数时可能会遇到这种编译错误的问题 The method is ambiguous 正确的解决方法是:  在eclipse.ini -vmargs后面添加  -Dto ...

  8. springboot+jpa分库分表项目实例

    分库分表场景 关系型数据库本身比较容易成为系统瓶颈,单机存储容量.连接数.处理能力都有限.当单表的数据量达到1000W或100G以后,由于查询维度较多,即使添加从库.优化索引,做很多操作时性能仍下降严 ...

  9. C语言程序设计100例之(5):分解质因数

    例5    分解质因数 题目描述 将一个正整数分解质因数.例如:输入90,输出 90=2*3*3*5. 输入 输入数据包含多行,每行是一个正整数n (1<n <100000) . 输出 对 ...

  10. URLDecoder异常Illegal hex characters in escape (%)

    URLDecoder对参数进行解码时候,代码如: URLDecoder.decode(param,"utf-8"); 有时候会出现类似如下的错误: URLDecoder异常Ille ...