python中的np.random.permutation函数怎么使用
本文小编为大家详细介绍“python中np.random.permutation函数怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“python中np.random.permutation函数怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
一:函数介绍
np.random.permutation() 总体来说他是一个随机排列函数,就是将输入的数据进行随机排列,官方文档指出,此函数只能针对一维数据随机排列,对于多维数据只能对第一维度的数据进行随机排列。
简而言之:np.random.permutation函数的作用就是按照给定列表生成一个打乱后的随机列表
在处理数据集时,通常可以使用该函数进行打乱数据集内部顺序,并按照同样的顺序进行标签序列的打乱。
二:实例
2.1 直接处理数组或列表数
importnumpyasnpdata=np.array([1,2,3,4,5,6,7])a=np.random.permutation(data)b=np.random.permutation([5,0,9,0,1,1,1])print(a)print("data:",data)print(b)
2.2 间接处理:不改变原数据(对数组下标的处理)
label=np.array([1,2,3,4,5,6,7])a=np.random.permutation(np.arange(len(label)))print("Label[a]:",label[a])
补:一般只能用于N维数组 只能将整数标量数组转换为标量索引
why?label1[a1] label1是列表,a1是列表下标的随机排列 但是! 列表结构没有标量索引 label1[a1]报错
label1=[1,2,3,4,5,6,7]print(len(label1))a1=np.random.permutation(np.arange(len(label1)))#有结果print(a1)print("Label1[a1]:",label1[a1])#这列表结构没有标量索引所以会报错
2.3 实例:鸢尾花数据中对鸢尾花的随机打乱(可以直接用)
fromsklearnimportsvmfromsklearnimportdatasets#sklearn的数据集iris=datasets.load_iris()iris_x=iris.datairis_y=iris.targetindices=np.random.permutation(len(iris_x))#此时打乱的是数组的下标的排序print(indices)print(indices[:-10])#到倒数第10个为止print(indices[-10:])#最后10个#print(type(iris_x))<class'numpy.ndarray'>#9:1分类#iris_x_train=iris_x[indices[:-10]]#使用的数组打乱后的下标#iris_y_train=iris_y[indices[:-10]]#iris_x_test=iris_x[indices[-10:]]#iris_y_test=iris_y[indices[-10:]]
数组下标 即标量索引的重新分布情况: 下标是0开始
读到这里,这篇“python中np.random.permutation函数怎么使用”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注主机评测网行业资讯频道。
下一篇:Spring?MVC启动之HandlerMapping作用及实现方法是什么
输入法切换键是哪个键?输入法切
冬月是哪一个月?冬月是什么意思
个人所得税退税金额怎么算出来的
输入法全角和半角有什么区别?输
a4纸尺寸是多少厘米?a4纸的由来
个人所得税扣除标准?个人所得税
输入法哪个好用?输入法介绍
卡拉OK是哪个国家发明的?卡拉OK
mikutools原神网页版入口链接?m
关机特别慢什么原因?电脑和手机