Python的默认实现(CPython)处理某些操作非常慢,因为动态性和解释性,



CPython 在每次循环必须左数据类型的检查和函数的调度。。在编译是进行这样的操作。就会加快执行速度。

通用函数介绍

Numpy 为很多类型的操作提供了方便的、静态类型的、可编译程序的接口。叫做向量操作。

对数组的操作会用于数组的每一个元素。



也可以对俩个数组进行运算

探索通用函数

俩种存在形式

  • 一元通用函数 unary ufunc 对单个输入操作
  • 二元通用函数 binary ufunc 对俩个输入操作

    1)数组的运算

    Numpy 通用函数的使用方式非常自然,就是Python原生的算术运算符。加 减 乘 除

    | Operator | Equivalent ufunc | Description |

    | -------- | ---------------- | ----------------------------------- |

    | + | np.add | Addition (e.g., 1 + 1 = 2) |

    | - | np.subtract | Subtraction (e.g., 3 - 2 = 1) |

    | - | np.negative | Unary negation (e.g., -2) |

    | * | np.multiply | Multiplication (e.g., 2 * 3 = 6) |

    | / | np.divide | Division (e.g., 3 / 2 = 1.5) |

    | // | np.floor_divide | Floor division (e.g., 3 // 2 = 1) |

    | ** | np.power | Exponentiation (e.g., 2 ** 3 = 8) |

    | % | np.mod | Modulus/remainder (e.g., 9 % 4 = 1) |

    2)绝对值



    np.absolute



    3)三角函数



    逆三角函数

4)指数和对数

指数运算的逆运算, 即对数运算

np.log 以自然常数 e 为底数的对数

高级的通用函数特性

  • 指定输出

    out参数

  • 聚合

    reduce 方法会对给定的元素和操作 重复执行,直至得到单个的结果



如果需要保存计算的中间结果使用 accumulate

  • 外积

    任何通用函数都可以使用outer方法获得俩个不同输入 数组 所有元素对 的函数运算结果。

    可以用一行代码实现一个乘法表

聚合:最小值、最大值和其他值

  • 数组值求和



    sum 和 np.sum不一样。np.sum更快。np.sum 知道数组的维度

  • 最小值,最大值

    np.min np.max
  • 多维度聚合

    默认是整个数组的聚合结果,可以按照某个维度聚合。 参数 axis

  • 其他聚合函数

    | Function Name | NaN-safe Version | Description |

    | ------------- | ---------------- | ----------------------------------------- |

    | np.sum | np.nansum | Compute sum of elements |

    | np.prod | np.nanprod | Compute product of elements |

    | np.mean | np.nanmean | Compute mean of elements |

    | np.std | np.nanstd | Compute standard deviation |

    | np.var | np.nanvar | Compute variance |

    | np.min | np.nanmin | Find minimum value |

    | np.max | np.nanmax | Find maximum value |

    | np.argmin | np.nanargmin | Find index of minimum value |

    | np.argmax | np.nanargmax | Find index of maximum value |

    | np.median | np.nanmedian | Compute median of elements |

    | np.percentile | np.nanpercentile | Compute rank-based statistics of elements |

    | np.any | N/A | Evaluate whether any elements are true |

    | np.all | N/A | Evaluate whether all elements are true |

Python数据科学手册-Numpy数组的计算,通用函数的更多相关文章

  1. Python数据科学手册-Numpy数组的计算:广播

    广播可以简单理解为用于不同大小数组的二元通用函数(加减乘等)的一组规则 二元运算符是对相应元素逐个计算 广播允许这些二元运算符可以用于不同大小的数组 更高维度的数组 更复杂的情况,对俩个数组的同时广播 ...

  2. Python数据科学手册-Numpy数组的计算:比较、掩码和布尔逻辑,花哨的索引

    Numpy的通用函数可以用来替代循环, 快速实现数组的逐元素的 运算 同样,使用其他通用函数实现数组的逐元素的 比较 < > 这些运算结果 是一个布尔数据类型的数组. 有6种标准的比较操作 ...

  3. Python数据科学手册-Numpy数组的排序

    1)  Numpy中的快速排序: np.sort  和 np.argsort np.sort 是快速排序,算法复杂度 O[ N log N] ,也可以选择归并排序和堆排序 如果不想修改原始输入数组,返 ...

  4. Python数据科学手册-Numpy入门

    通过Python有效导入.存储和操作内存数据的技巧 数据来源:文档.图像.声音.数值等等,将所有的数据简单的看做数字数组 非常有助于 理解和处理数据 不管数据是何种形式,第一步都是 将这些数据转换成 ...

  5. Python数据科学手册-Numpy的结构化数组

    结构化数组 和 记录数组 为复合的.异构的数据提供了非常有效的存储 (一般使用pandas 的 DataFrame来实现) 传入的dtpye 使用 Numpy数据类型 Character Descri ...

  6. Python数据科学手册

    Python数据科学手册(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1KurSdjNWiwMac3o3iLrzBg 提取码:qogy 复制这段内容后打开百度网盘手 ...

  7. 100天搞定机器学习|day45-53 推荐一本豆瓣评分9.3的书:《Python数据科学手册》

    <Python数据科学手册>共五章,每章介绍一到两个Python数据科学中的重点工具包.首先从IPython和Jupyter开始,它们提供了数据科学家需要的计算环境:第2章讲解能提供nda ...

  8. Python数据科学手册-前言

    读Python数据科学手册 笔记 系列 数据科学 data science https://img2022.cnblogs.com/blog/2827305/202205/2827305-202205 ...

  9. Matplotlib 使用 - 《Python 数据科学手册》学习笔记

    一.引入 import matplotlib as mpl import matplotlib.pyplot as plt 二.配置 1.画图接口 Matplotlib 有两种画图接口: (1)一个是 ...

随机推荐

  1. 一文搞懂 Netty 发送数据全流程 | 你想知道的细节全在这里

    欢迎关注公众号:bin的技术小屋,如果大家在看文章的时候发现图片加载不了,可以到公众号查看原文 本系列Netty源码解析文章基于 4.1.56.Final版本 在<Netty如何高效接收网络数据 ...

  2. 经典的损失函数:交叉熵和MSE

    经典的损失函数: ①交叉熵(分类问题):判断一个输出向量和期望向量有多接近.交叉熵刻画了两个概率分布之间的距离,他是分类问题中使用比较广泛的一种损失函数.概率分布刻画了不同事件发生的概率. 熵的定义: ...

  3. 函数式(Functional)接口

    public class LambdaTest2 { @Test public void test1(){ happyTime(500, new Consumer<Double>() { ...

  4. 一文解决Vue中实现 Excel下载到本地以及上传Excel

    相信大家在项目中经常会遇到一些上传下载文件的相关功能,本文就Excel的相关功能进行简述: 咱直接看代码: <div class="import-main-content"& ...

  5. 使用OpenCv+Arduino实现挂机自动打怪

    使用OpenCv+Arduino实现挂机自动打怪 最近在玩某网游,练级十分枯燥和缓慢,就是挂机刷刷刷,所以研究一下自动化,找了个可以原地挂机刷怪的职业,然后用OpenCv检测技能冷却,冷却好了通过串口 ...

  6. 用虚拟机封装win10系统的一些记录

    想用虚拟机封装一个WIN10企业LTSC,期间参考了IT天空小鱼儿的几大步骤一直到手动优化完,后面就自己用系统安装直接备份了一个.gho镜像.期间出过好多毛病,不过总算是成功实现了.注意点: 1.前面 ...

  7. 活动回顾|Apache DolphinScheduler x Pulsar 在线 Meetup

    关于 Apache DolphinScheduler: " Apache DolphinScheduler(Incubating) 是一个分布式去中心化.易扩展的可视化工作流任务调度系统,致 ...

  8. Spring 01 概述

    简介 Spring 是开源的轻量级 J2EE 框架 我们常说的 Spring 实际上是指 Spring Framework,它是 Spring 家族中的一个重要分支. 官方文档 https://doc ...

  9. Redis常用指令之string、list、set、zset、hash

    Redis之五大类型常用指令 redis的一些小知识 redis服务器端口默认是6379 在编译完成后的bin目录下启动服务端:redis-server 客户端连接操作:redis-cli -h lo ...

  10. mybatis 14: 多对一关联查询

    业务背景 根据订单id查询订单的信息,以及该订单所属的客户的基本信息(不包括该客户自己的订单信息) 两张数据表 客户表 订单表 实体类 客户实体类:Customer private Integer i ...