numpy 广播机制

  1.  +. -. *. /都会激发广播机制
>>> s
array([[1],
       [2],
       [3]])
>>> ss
array([[1, 2],
       [3, 4],
       [5, 6]])
>>> s
array([[1],
       [2],
       [3]])
>>> ss + s
array([[2, 3],
       [5, 6],
       [8, 9]])
>>> ss - s
array([[0, 1],
       [1, 2],
       [2, 3]])
>>> ss * s
array([[ 1,  2],
       [ 6,  8],
       [15, 18]])
>>> ss / s
array([[1.        , 2.        ],
       [1.5       , 2.        ],
       [1.66666667, 2.        ]])
  • 标量vs向量/矩阵
  • 会自动扩展至纬度相等(此处标量->(3, 1))
>>> s
array([[1],
       [2],
       [3]])
>>> s + 1
array([[2],
       [3],
       [4]])
>>> s - 1
array([[0],
       [1],
       [2]])
>>> s * 2
array([[2],
       [4],
       [6]])
>>> s / 2
array([[0.5],
       [1. ],
       [1.5]])
  • 向量vs矩阵
  • 会自动扩展至纬度相等(此处向量->(3, 2))
  • 必须要有一个维度是相等的才会发生广播,否则报错
>>> s
array([[1],
       [2],
       [3]])
>>> ss
array([[1, 2],
       [3, 4],
       [5, 6]])
>>> s
array([[1],
       [2],
       [3]])
>>> ss + s
array([[2, 3],
       [5, 6],
       [8, 9]])
>>> ss - s
array([[0, 1],
       [1, 2],
       [2, 3]])
>>> ss * s
array([[ 1,  2],
       [ 6,  8],
       [15, 18]])
>>> ss / s
array([[1.        , 2.        ],
       [1.5       , 2.        ],
       [1.66666667, 2.        ]])
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值