numpy matrix 与ndarray的区别

版本:2.7.10

例子:

A=np.array([[1,2],[3,4]])
B=np.array([[5,6],[7,8]])

C=np.mat([[1,2],[3,4]])
D=np.mat([[6,7],[8,9]])
1.ndarray 可以是任意维数 mat只能是2维的
#正常
A=np.array([[[1,2]]])
#报错
B = np.mat([[[1,2]]]) 
2.矩阵乘法
ndarray: 
    1. np.dot  是叉乘 (各元素相乘后相加)
        A.dot(B)=np.dot(A,B) 
        得到:
            array([[19, 22],
                  [43, 50]])
     2 A*B=np.multiply(A,B) (各对应位置元素相乘)

     得到:
     array([[ 5, 12],
            [21, 32]])
matrix:

    1. C*D=np.dot(C,D)=C.dot(D)  (各元素相乘后相加)
    得到:
    matrix([[22, 25],
           [50, 57]])
    2. np=np.multiply(C,D)  (各对应位置元素相乘)
    得到:
        matrix([[6, 7],
                [8, 9]])
3.matrix与ndarray互换
1.matrix->ndarray  (使用matrix对象的A属性或者np.asarray()方法)
    E=C.A
    E=np.asarray(C)
    #注意E和A共享内存空间,修改了A之后E的值也会被修改

2.ndarray->matrix (使用np.asmatrix()方法)
    E=np.asmatrix(A)
4.matrix 和 array 都可以通过objects后面加.T 得到其转置。但是 matrix objects 还可以在后面加 .H f得到共轭矩阵, 加 .I 得到逆矩阵。
5.** 运算符的作用也不一样 :因为a是个matrix,所以a**2返回的是a*a,相当于矩阵相乘。而c是array,c**2相当于,c中的元素逐个求平方
6.numpy 中的array与numpy中的matrix的最大的不同是,在做归约运算时,array的维数会发生变化,但matrix总是保持为2维。例如下面求平均值的运算
>>> C
matrix([[1, 2],
        [3, 4]])
>>> C.mean(1)
matrix([[1.5],
        [3.5]])
>>> A
array([[1, 2],
       [3, 4]])
>>> A.mean(1)
array([1.5, 3.5])
>>> 
  • 7
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: numpy中的matrixarray都是用来存储多维数组的数据结构,但是它们有一些区别。 1. matrix是二维数组,而array可以是任意维度的数组。 2. matrix只能进行矩阵运算,而array可以进行任意维度的数组运算。 3. matrix的乘法运算使用*符号,而array的乘法运算使用dot()函数。 4. matrix的切片返回的是一个matrix对象,而array的切片返回的是一个array对象。 5. matrix的转置使用T属性,而array的转置使用transpose()函数。 总的来说,如果你需要进行矩阵运算,那么使用matrix更方便;如果你需要进行任意维度的数组运算,那么使用array更方便。 ### 回答2: numpy中的matrixarray都是用来处理多维数组的数据结构,但它们有一些区别。 首先,matrix是一个二维数组,而array可以是任意维度的数组。这意味着matrix只能处理二维矩阵操作,而array可以处理任意维度的矩阵操作。 其次,matrix只能进行矩阵运算,而array可以进行矩阵运算和逐元素运算。也就是说,对于两个matrix对象进行乘法运算,会进行真正的矩阵乘法操作;而对于两个array对象进行乘法运算,会进行逐元素相乘操作。 此外,matrix对象具有一些特定的运算符重载。例如,通过`*`操作符进行矩阵乘法运算,使用`**`操作符进行矩阵的幂运算。 另外一个区别matrix对象是一个子类,继承自numpyndarray对象。由于继承的关系,matrix对象拥有ndarray对象的所有方法和属性,同时还有一些matrix独有的方法。 虽然matrix具有一些特殊的性质和方法,但大多数情况下,使用array更加方便和灵活。这是因为在科学计算中,多维数组的操作通常不仅仅只涉及到矩阵运算。因此,通常建议优先使用array而不是matrix。 ### 回答3: NumPy中的matrixarray都是用于数值计算的数据结构,但它们在一些方面有一些不同。 首先,matrixarray的子类,因此可以使用array中的方法和功能。但matrix有一些额外的功能,使得它更适合于线性代数运算。例如,matrix可以使用*运算符实现矩阵乘法,而array对应的操作是使用multiply()函数。 其次,matrix是二维的数据结构,而array可以是任意维度的。这意味着创建一个matrix时,输入的数据必须是二维的,而创建一个array时可以是任意维度的。例如,使用matrix创建一个二维矩阵可以是matrix([[1, 2], [3, 4]]),但使用array创建一个二维数组可以是array([[1, 2], [3, 4]])。 此外,matrix具有固定的行和列的结构,因此在进行矩阵运算时,可以直接使用矩阵的行和列的标签进行索引,而不需要使用索引值。这使得代码更加直观和易读。 然而,array在其他方面的功能上比matrix更加灵活和强大。因为它可以是任意维度的,所以在处理高维数组或非线性代数操作时,array更加适用。同时,array也更加常用和广泛应用,因为它是NumPy中最基本的数据结构。 总之,matrixarray在功能和用途上有一些差异。如果需要进行线性代数运算或者处理二维数组,matrix是一个较好的选择;而如果需要处理任意维度的数组或者需要更灵活的操作,array更加合适。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值