ufunc函数

2023-12-07 20:19
文章标签 函数 ufunc

本文主要是介绍ufunc函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ufunc函数

ufunc简介

ufunc是universal function的简称,它能对数组每个元素进行运算的函数。NumPy的许多ufunc函数都是用C语言实现的,因此它们的运算速度非常快。
值得注意的是,对于同等长度的ndarray,np.sin()比math.sin()快
但是对于单个数值,math.sin()的速度更快。

角度转换成弧度:
角度:a
弧度:u=a/180*pi

四则运算

NumPy提供了许多ufunc函数,它们和相应的运算符运算结果相同。
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

比较运算和布尔运算

使用==>对两个数组进行比较,会返回一个布尔数组,每个元素都是对应的元素的比较结果。
在这里插入图片描述

表达式ufunc函数
y=x1==x2equal(x1,x2)
y=x1!=x2not_equal(x1,x2)
y=x1<x2less(x1,x2)
y=x1<=x2not_equak(x1,x2)
y=x1>x2greater(x1,x2)
y=x1>=x2greater_equal(x1,x2)

广播broadcasting

使用ufunc对两个数组进行运算时,ufunc函数会对两个数组的对应元素进行运算。如果数组的形状不相同,就会进行下广播处理。简而言之,就是向两个数组每一维度上的最大值靠齐。
在这里插入图片描述
例子
在这里插入图片描述
广播的前提条件是扩充维度的长度必须为1,当不为1时报错。
在这里插入图片描述
可以看到将a的列扩充一倍就可以和b运算,但因为扩充单位是(2,3)其中列长度为2,所以报错。
在这里插入图片描述
可以看到判断仅与被扩充维度有关,即使另一个维度为1也报错
在这里插入图片描述

ogrid

ogrid用来生成广播运算所用的数组

NumPy的函数库

随机数

除了前面介绍的ufunc()函数外,NumPy还提供了大量对于数组运算的函数。它们能够简化逻辑,提高运算速度。
1、numpy.random.rand(d0,d1,…,dn)
作用:参数一个给定形状的数组(其实应该是ndarray对象或者是一个单值),数组中的值服从从[0,1)之间的均匀分布。
参数:维度的长度。如果没有参数则返回一个float
返回值:nadrray或float
2、numpy.random.uniform(low=0.0,high=1.0,size=None)
作用:返回一个在区间[low,high)中均匀分布的数组,size指定形状。
参数:
low、high:float型或者float型的类数组对象。指定抽样区间
size:int型或int型元组。指定形状,如果不提供size,则返回一个服从该分布的随机数。
3、numpy.random.randn(d0,d1,…,dn)
作用:返回一个指定形状的数组,数组中的值服从标准正态分布(均值为0,方差为1)。
参数:d0,d1,…,dn:int,可选。如果没有参数,则返回一个服从标准正态分布的float型随机数。
返回值:ndarray对象或者float
4、numpy.random.normal(loc=0.0,scale=1.0,size=None)
作用:返回一个由size指定形状的数组,数组中的值服从均值为loc,标准差为scale的正态分布
参数:
loc:float型或者float型的类数组的类数组对象,指定均值
scale:float型或者float型的类数组对象,指定标准差
size:int型或者int型元组,指定了数组的形状。如果不提供size,且loc和scale为标量(不是类数组对象),则返回一个服从该分布的随机数。
输出:ndarray或者一个标量
5、numpy.random.randint(low,high=None,size=None,dtype=‘I’)
作用:返回一个在区间[low,high)中离散均匀抽样的数组,size指定形状,dtype指定数据类型。
参数:
low,high:int型,指定抽样区间
size:int型或int型元组,指定形状
dypte:可选参数,指定数据类型,比如int,int64等,默认是np.int
返回值:如果指定了size,则返回一个int型的ndarray对象,否则返回一个服从该分布的int型随机数。
6、numpy.random.random(size=None)
作用:返回从[0,1)之间均匀抽样的数组,size指定形状。
返回值:float或者float型的ndarray对象

求和,平均值,方差

函数名功能
sum求和
average加权平均数
var方差
mean期望
std标准差
product连乘积

在这里插入图片描述
axis选择求和的轴,第几轴(列为1,行为0)
在这里插入图片描述
keepdims可以保存原来数组的维数
在这里插入图片描述

大小与排序

函数名功能
min最小值
max最大值
ptp极差
argmin最小值的下标
mininum二元最小值
maxinum二元最大值
sort数组排序
argsort数组排序下标
percentile分位数
median中位数

在这里插入图片描述
sort()对数组进行排序会改变数组的内容,返回一个新的数组。axis的默认值都为1,即按最终轴进行排序。axis=0对每列上的值进行排序。
在这里插入图片描述

percentile计算处于p%上的值。
在这里插入图片描述

统计函数

NumPy中常用的统计函数由unique(),bicount(),histogram()。
unique()
在这里插入图片描述
unique有两个参数,return_index=True同时返回原始数组中的下标,return_inverse=True表示原始数据在新数组的下标。
在这里插入图片描述
bincount()
对非负整数数组中的各个元素出现的次数进行统计,返回数组中的第i个元素是整数i出现的次数。
histogram()
对以为数组进行直方图统计,其参数为histogram(a,bins=10,range=None,weights=None)函数返回两个一维数组,hist是每个区间的统计结果,bin_edges返回区间的边界值。
在这里插入图片描述

操作多维数组

多维数组可以进行连接,分段等多种操作。
vstack()、hstack()、column_statck()

在这里插入图片描述
split()函数进行分段
在这里插入图片描述

多项式函数

多项式函数是整数的次幂与系数的乘积,如: f ( x ) = a n ( x n ) + a n − 1 ( x ( n − 1 ) ) + … + a 1 ( x ) + a 0 f(x)= an(x^n)+ an-1(x^{(n-1)})+…+ a1(x)+ a0 f(x)=an(xn)+an1(x(n1))++a1(x)+a0NumPy中多项式函数可以用一维数组表示。a[0]为最高次,a[-1]为常数项。
在这里插入图片描述

在这里插入图片描述

多项式函数可以进行四则运算,其中运算的列表自动化成多项式函数
多项式也可以进行积分和求导,也可以求多项式的根。
之后用到再细讲

这篇关于ufunc函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Django中的函数视图和类视图以及路由的定义方式

《Django中的函数视图和类视图以及路由的定义方式》Django视图分函数视图和类视图,前者用函数处理请求,后者继承View类定义方法,路由使用path()、re_path()或url(),通过in... 目录函数视图类视图路由总路由函数视图的路由类视图定义路由总结Django允许接收的请求方法http

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串