Python数据科学numpy的运算、分布函数和矩阵

article/2025/9/17 14:55:50

本文介绍numpy的常用运算、统计分布函数和矩阵的基础用法

numpy的一元多元运算,给我们做数据处理分析做基础,忘记的时候可以查看文档,常用的理解记忆就行。以下代码演示前提均以import numpy as np为前提

1. 一元运算:

  • 运算函数:
    np.abs(x)/np.fabsx) -绝对值/浮点数绝对值;
    np.sqrt(x) -开平方根;
    np.square(x) -平方
    np.log(x)/np.log2(x)/np.log10(x) -取log对数值
    np.cell(x)/np.floor(x)/np.rint(x) -类似数学的进一法/退一法/四舍五入

  • 统计函数:
    np.sum(a) -求和
    np.mean(a) -均值
    np.average(a,axis=0,weights=[10,5,1]) -加权平均,weight是权重属性
    np.std(a)/np.var(a) -标准差 /方差
    np.min(a)/np.max(a) -最小值/最大值
    np.ptp(a) -极差 np.median(a) -中位数
    np.argmin(a)/np.argmax(a) -返回将成一维后最小值最大值的索引值

  • 三角函数:
    np.sin() np.cos() np.tan() 普通型三角函数
    np.sinh() np.cosh() np.tanh() 双面型三角函数

  • np.exp() 指数值
    np.sign 符号值

下面演示一下运算函数的np.ceil()/np.floor()/np.rint()和统计函数的np.argmin()/np.argmax()

a1 = np.array([[90.2,70.6,88.1],[98.0,90.8,92.5],[-10.5,2.2,-98.7]])
result1 = np.ceil(a1)
result2 = np.floor(a1)
result3 = np.rint(a1)
print(result1)
print("========================")
print(result2)
print("========================")
print(result3)
print("========================")
print(a1)

在这里插入图片描述
结果分别显示进一法、退一法、四舍五入的效果。**值得注意的一点是,遇到负数是,数字会往大的方向。因为负数里面,数字越大值越小。**例如,np.floor(-1.2) 结果等于-2,代码例子也同理。
此外,最后一个打印是为了对比运算前后数组的变化,结论是运算后不改变原数组。

统计函数的np.argmax()/np.argmin()

a1 = np.array([[90.2,70.6,88.1],[98.0,90.8,92.5],[-10.5,2.2,-98.7]])
result1,result2,result3 = np.argmin(a1),np.argmax(a1),a1.flatten()
print(result1,result2)
print("这是数组一维的效果:",result3)

在这里插入图片描述
第一个打印结果,返回降成一维后的最大最小值的索引。为了方便我们检查最大最小值对应的索引位置,我也把数组降维打印出来,方便检查。
数组中最小值为-98.7,在第9个位置(最后一个),索引值8,正确。
数组中最大值为98.0,在第4个位置,索引值3,正确。

2. 二元运算

  • np.maximum(x,y) np.fmax() 最大值 浮点数
    np.minimum(x,y) np.fmin() 最小值 浮点数
    np.mod(x,y) 模运算
    np.copysign(x,y) 将y中的各值的符号值赋值给x的对应元素

这里的运算函数用得比较少,不做过多的演示。

3. 三元运算

  • np.where(判断或布尔值,True返回值,False返回值) 像Excel的if函数
    且条件判断:np.where(np.logical_and(val>1,val<5),1,0)
    或条件判断:np.where(np.logical_or(age>50,salary>100000),1,0)
b1 = np.array([[[15,16,4],[80,22,28]],[[1,2,3],[56,23,1]]])
print(np.where(np.logical_and(b1>15,b1<20),1,0))
print("==================")
print(np.where(np.logical_or(b1>30,b1<10),1,0))
print("==================")
print(np.where(np.logical_not(b1>=10),1,0))

在这里插入图片描述
4.分布函数

  • 均匀分布与正态分布
c1 = np.random.rand(10)
c11 = np.random.uniform(10,100,(2,3))
print("均匀分布:\n",c1,"\n",c11)c2 = np.random.randn(6)
c22 = np.random.normal(2,1.2,(4,2))
print("正态分布:\n",c2,"\n",c22)

在这里插入图片描述
np.random.rand(x):[0,1)的均匀分布,x为组成分布的个数
np.random.uniform(low,high,size):[low,high)的均匀分布,size=shape数组形状

np.randn(x):标准正态分布(均值0,方差1)x为组成分布的个数
np.normal(loc,scale,size):正态分布,loc均值,scale方差,size=shape数组形状

  • 随机分布和泊松分布
c3 = np.random.randint(1,100,(5,3))
c4 = np.random.poisson(0.7,(3,3))
print("随机整数分布:\n",c3)
print("泊松分布:\n",c4)

在这里插入图片描述
np.random.randint(low,high,size):[low,high)的随机整数分布,size=shape
np.random.poisson(lam,size):lam是事件发生概率,size=shape

5. 矩阵

矩阵乘法运算的两种情况

  • 数组是由ndarray组成
  • 数组是由matrix组成

用代码运行看看两者的差异

d1 = np.array([[2,4,2],[3,1,1]])
d2 = np.matrix([[6,1],[1,2],[8,3]])
d = np.matmul(d1,d2)
print(d1)
print("============")
print(d2)
print("============")
print(d)

在这里插入图片描述
如果两个数据集是有包含用ndarray存的话(这里是一个ndarray,一个matrix),则需要用np.matmul()/np.dot()函数来进行乘法运算。

如果是用matrix存的话,则可以如下图代码所示,直接用运算符号,方便。

d3 = np.matrix([[1,2,3],[5,6,3]])
d4 = np.matrix([[2,6],[2,7],[5,1]])
d = d3*d4
print(d3)
print("============")
print(d4)
print("============")
print(d)

在这里插入图片描述
复习一下线性代数矩阵基本运算过程:
1 2 3 2 6
5 6 3 2 7
5 1

(2,2)乘(2,3)=(2*3)

符合(m,n)乘 (n,l)= (m*l)

=12+22+35 =21
=1
6+27+31 =23
=52+62+35 =37
=5
6+67+31 =75
(2*3)

还有一个广播机制,需要深入去研究一下才能理解透。
下次再见,坚持!


http://chatgpt.dhexx.cn/article/xCrxCeX1.shtml

相关文章

IEEE802.11信道PDP与频谱分布

%实现IEEE802.11信道仿真&#xff0c;画出IEEE802.11信道的PDP曲线与频谱图 clear,clf scale 1e-9;%纳秒量级 Ts 50*scale;%采样时间间隔&#xff0c;50ns t_rms25*scale;%RMS时延扩展&#xff0c;25ns num_ch10000;%信道数 N128;%FFT长度 PDPIEEE802_11_model(t_rms,Ts);%调…

计算二维离散随机变量的联合概率分布

一. 定义 Joint probability distribution: 给定至少两个随机变量X,Y,…, 它们的联合概率分布(Joint probability distribution)指的是每一个随机变量的值落入特定范围或者离散点集合内的概率. 对于只有两个随机变量的情况, 称为二元分布(bivariate distribution). 联合概率…

matlab 分布拟合,曲线拟合和分布拟合 - MATLAB Simulink Example - MathWorks 中国

在曲线拟合与分布拟合之间进行选择 曲线拟合和分布拟合是不同类型的数据分析。 当您要将某个响应变量建模为预测变量的函数时,请使用曲线拟合。 当您要为单一变量的概率分布建模时,请使用分布拟合。 曲线拟合 在以下试验数据中,预测变量为 time,即服用药物之后的时间。响应…

MATLAB如何画数据分布曲线,Matlab绘制累积分布函数(CDF)

CDF示例代码&#xff1a; cdf.mfunction [xTime,yPercentage]cdf(initValue,step,endValue,sample); xTime[]; yPercentage[]; totalNumlength(sample); for iinitValue:step:endValue templength(find(sample<i))/totalNum; xTime[xTime,i]; yPercentage[yPercentage,temp]…

【得物技术】如何测试概率性事件 - 二项分布置信区间

前言 &#xfeff; 日常开发测试可能会遇到这样一种情况&#xff0c;有一个接口或方法概率触发&#xff0c;那么需要多少次抽样&#xff0c;落在一个什么区间内&#xff0c;才能断定是否按照设定概率进行呢&#xff1f; &#xfeff; 本文将以二项分布作为研究手段&#xf…

python画累积分布图_python累积分布图

在与@EOL进行了决定性的讨论之后,我想使用随机高斯样本作为摘要发布我的解决方案(左上角): import numpy as np import matplotlib.pyplot as plt from math import ceil, floor, sqrt def pdf(x, mu=0, sigma=1): """ Calculates the normal distributions p…

2021-10-24 我的第五次java作业:二项分布和双骰子赌博问题

我的第五次java作业 题目&#xff1a; 二项分布是n次独立试验中成功次数k的离散概率分布&#xff0c;其中每次试验成功的概率为p。利用Java Math类中提供的数学函数&#xff0c;给出二项分布X~B(n, p, k)的实现代码并进行测试。例如&#xff0c;当用户给定n20, p0.1, k5的概率…

记一次使用Cobar踩到的坑

起因 起因是因为日志里经常报出锁等待超时的错误&#xff0c;并且这个是环环相扣的&#xff0c;一个锁等待会直接引发另外的锁等待&#xff0c;所以危害非常严重&#xff0c;影响非常深远。寻找原因发现是C3P0报出了DEADLOCK&#xff0c;如下图所示&#xff1a; 分析 可以…

Cobar介绍及配置

原文地址为&#xff1a; Cobar介绍及配置 from&#xff1a;http://code.alibabatech.com/wiki/display/cobar/Home Skip to end of metadata Page restrictions applyAttachments:1Added by kimi Lv, last edited by 邱 硕 on 十月 18, 2012 (view change) Comment: Go to st…

用cobar搭建分布式数据库

周末针对最新的项目需求进行cobar的搭建并针对实际状况做了demo演示 一、需求 1、大数据量&#xff0c;邮件发送记录需要记录&#xff0c;一年可能累计4亿的数据 2、需要按照邮箱进行邮件发送明细的查询以及发送记录的查询 二、问题 1、单库分表分区已经解决不了存储以及查…

用cobar搭建分布式数据库 .

周末针对最新的项目需求进行cobar的搭建并针对实际状况做了demo演示 一、需求 1、大数据量&#xff0c;邮件发送记录需要记录&#xff0c;一年可能累计4亿的数据 2、需要按照邮箱进行邮件发送明细的查询以及发送记录的查询 二、问题 1、单库分表分区已经解决不了存储以及查…

开源的分布式数据库中间件系统Mycat和阿里巴巴Cobar的对比

mycat 不得不说的缘分 原创 2016年04月15日 15:48:17 27834 1&#xff0c;愕然回首&#xff0c;它在灯火阑珊处 关于mysql集群中间件&#xff0c;以前写在应用程序里面&#xff0c;由开发人员实现&#xff0c;在配置文件里面写多个数据源&#xff0c;写库一个数据源&#xff0…

分布式数据中间件TDDL、Amoeba、Cobar、MyCAT架构比较

框架比较 TDDL Amoeba Cobar MyCat 点评 TDDL不同于其它几款产品&#xff0c;并非独立的中间件&#xff0c;只能算作中间层&#xff0c;是以Jar包方式提供给应用调用。属于JDBC Shard的思想&#xff0c;网上也有很多其它类似产品。 另外&#xff0c;网上有关于TDDL的图&#x…

TDDL、Amoeba、Cobar、MyCAT架构比较

布式数据库中间件TDDL、Amoeba、Cobar、MyCAT架构比较分 比较了业界流行的MySQL分布式数据库中间件&#xff0c;关于每个产品的介绍&#xff0c;网上的资料比较多&#xff0c;本文只是对几款产品的架构进行比较&#xff0c;从中可以看出中间件发展和演进路线 框架比较 TDDL Am…

Cobar使用文档(可用作MySQL大型集群解决方案)

转&#xff1a;http://blog.csdn.net/shagoo/article/details/8191346 最近好不容易抽空研究了下Cobar&#xff0c;感觉这个产品确实很不错&#xff08;在文档方面比Amoeba强多了&#xff09;&#xff0c;特此推荐给大家。Cobar是阿里巴巴研发的关系型数据的分布式处理系统&am…

Cobar的架构与实践

Cobar是提供分布式数据库服务的中间件&#xff0c;是阿里巴巴B2B前台应用访问数据库的统一入口。本文讲述的就是Cobar的架构演变与应用实践。 2008年&#xff0c;阿里巴巴B2B成立了平台技术部&#xff0c;为各个业务部门的产品提供底层的基础平台。这些平台涵盖Web框架、消息…

alibaba的COBAR真是强大.

最近好不容易抽空研究了下Cobar&#xff0c;感觉这个产品确实很不错&#xff08;在文档方面比Amoeba强多了&#xff09;&#xff0c;特此推荐给大家。Cobar是阿里巴巴研发的关系型数据的分布式处理系统&#xff0c;该产品成功替代了原先基于Oracle的数据存储方案&#xff0c;目…

Alibaba的COBAR真是强大

&#xfeff;&#xfeff; 最近好不容易抽空研究了下Cobar&#xff0c;感觉这个产品确实很不错&#xff08;在文档方面比Amoeba强多了&#xff09;&#xff0c;特此推荐给大家。Cobar是阿里巴巴研发的关系型数据的分布式处理系统&#xff0c;该产品成功替代了原先基于Oracle的…

Cobar Client的使用

cobar client是出自阿里的产品&#xff0c;cobar client只需要引入jar包即可&#xff0c;不需要建立服务。下面的地址是cobar client的帮助文档 http://code.alibabatech.com/docs/cobarclient/zh/ http://www.kuqin.com/system-analysis/20120212/318089.html 分库分表都…

Cobar介绍

概述 Cobar是关系型数据的分布式处理系统&#xff0c;它可以在分布式的环境下看上去像传统数据库一样为您提供海量数据服务。 产品在阿里巴巴B2B公司已经稳定运行了3年以上。目前已经接管了3000个MySQL数据库的schema&#xff0c;为应用提供数据服务。据最近统计cobar集群目前…