【Python学习笔记】23:numpy的add和multiply

2023-12-09 15:19

本文主要是介绍【Python学习笔记】23:numpy的add和multiply,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

add和multiply是numpy里比较常用的两种运算,分别是加法和乘法运算。

加法运算

>>> np.add.accumulate([1,2,3]) #累加
array([1, 3, 6], dtype=int32)

累加np.add.accumulate()适用于python序列(串不行)和numpy数组,每一个位置的元素和前面的所有元素加起来求和,得到的始终是numpy数组。

>>> np.add.reduce([1,2,3,4,5]) #连加
15

连加np.add.reduce()是将所有元素加在一起求和。

>>> x=np.array([1,2,3,4])
>>> np.add.at(x,[0,2],3)
>>> x
array([4, 2, 6, 4])

np.add.at()是将传入的数组中制定下标位置的元素加上指定的值,如上面是将x中下标为0和为2的元素加上了3,这会改变传入的数组x。

>>> np.add.outer([1,2,3],[4,5,6,7])
array([[ 5,  6,  7,  8],[ 6,  7,  8,  9],[ 7,  8,  9, 10]])

np.add.outer()将第一个列表或数组中的每个元素依次加到第二个列表或数组中的每个元素,得到每一行。

>>> x=np.arange(8)
>>> x
array([0, 1, 2, 3, 4, 5, 6, 7])
>>> np.add.reduceat(x,[0,4,1,5,2,6,3,7]) #在各切片上作reduce运算
array([ 6,  4, 10,  5, 14,  6, 18,  7], dtype=int32)

np.add.reduceat()对于传入的数组,根据传入的list(第二个参数)作指定的变化,传入的list中的数字是成对出现的。如上面的例子中是将x中0,4部分切片作np.add.reduce()运算(也就是连加),放在第一个位置,然后第二个位置就是下标4在x中的值,也就是4,以此类推。

>>> x=np.linspace(0,15,16).reshape(4,4)
>>> x
array([[  0.,   1.,   2.,   3.],[  4.,   5.,   6.,   7.],[  8.,   9.,  10.,  11.],[ 12.,  13.,  14.,  15.]])
>>> np.add.reduceat(x,[0,3,1])
array([[ 12.,  15.,  18.,  21.],[ 12.,  13.,  14.,  15.],[ 24.,  27.,  30.,  33.]])

这个例子是对于二维数组的reduceat的用法,0->3是一个切片,1->默认下界是一个切片,所以所得第0行为原来的第0行+第1行+第2行,所得第1行为原来的第3行,所得第2行为原来的第1行+至默认结尾,也就是第1行+第2行+第3行。

总的来说,redeceat函数传入的indices参数列表中的每个元素要看它后面的元素是不是比它大,如果比它大,作两者间的切片reduce,反之,它自己对应的元素即是该处结果。对于最后一个参数,因为其后已经没有元素,我们规定最后一项为从该参数到默认结尾作reduce连加。可以看下面这个例子。

>>> np.add.reduceat(x,[0,3,1,1])
array([[ 12.,  15.,  18.,  21.],[ 12.,  13.,  14.,  15.],[  4.,   5.,   6.,   7.],[ 24.,  27.,  30.,  33.]])

四行分别是原来的0->3切片,3行,1行,1->默认切片。

>>> np.add.reduceat(x,[0,3,1,3],axis=1) #对列进行计算
array([[  3.,   3.,   3.,   3.],[ 15.,   7.,  11.,   7.],[ 27.,  11.,  19.,  11.],[ 39.,  15.,  27.,  15.]])

可以看到它还有一个默认参数axis=0表示对行进行计算,上面的例子中axis为1表示对列进行计算,从左到右的四列分别是原来的0->3列切片,3列,1->3列切片,3列。

乘法运算

>>> x=np.arange(8)
>>> x
array([0, 1, 2, 3, 4, 5, 6, 7])
>>> np.multiply.at(x,[0,1,2],5)
>>> x
array([ 0,  5, 10,  3,  4,  5,  6,  7])

乘法与加法的几个函数用法很相似,np.multiply.at()表示将某个数组中的制定下标元素乘以指定值,如上面是对x中下标为0,1,2的元素都乘以了5。这会改变原数组。

>>> np.multiply.accumulate([1,2,3,4])
array([ 1,  2,  6, 24], dtype=int32)

np.multiply.accumulate()表示累乘,每个元素和它前面的所有元素相乘,返回新的数组。

>>> np.multiply.outer([1,2,3],[4,5,6])
array([[ 4,  5,  6],[ 8, 10, 12],[12, 15, 18]])

np.multiply.outer()表示将第一个列表或数组中的每个元素依次乘到第二个列表或数组中的每个元素,得到每一行。

>>> np.multiply.reduce([1,2,3,4])
24

np.multiply.reduce表示连乘,所有元素相乘。对于二维的数组,还有下面的用法。

>>> np.multiply.reduce([[1,2,3,4],[5,6,7,8]])
array([ 5, 12, 21, 32])

这表示纵向的(外部)reduce,每个子数组的对应子元素相乘,得到新的数组。

>>> np.multiply.reduce([[1,2,3,4],[5,6,7,8]],axis=1)
array([  24, 1680])

这表示横向的(内部)reduce,每个子数组自己作reduce即可。

>>> x=np.linspace(0,15,16).reshape(4,4)
>>> x
array([[  0.,   1.,   2.,   3.],[  4.,   5.,   6.,   7.],[  8.,   9.,  10.,  11.],[ 12.,  13.,  14.,  15.]])
>>> np.multiply.reduceat(x,[0,3,1])
array([[    0.,    45.,   120.,   231.],[   12.,    13.,    14.,    15.],[  384.,   585.,   840.,  1155.]])

和add的reduceat用法一样,这三行分别是原来行的0->3切片,3行,1->默认结尾切片。

>>> np.multiply.reduceat(x,[0,3,1],axis=1)
array([[    0.,     3.,     6.],[  120.,     7.,   210.],[  720.,    11.,   990.],[ 2184.,    15.,  2730.]])

这三列分别是原来列的0->3切片,3列,1->默认结尾切片。multiply的reduceat函数作的都是外部的reduce。

这篇关于【Python学习笔记】23:numpy的add和multiply的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/474165

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学