python 在机器学习中应用函数
浅述python中argsort()函数的用法
(1).先定义一个array数据
- 1 import numpy as np
- 2 x=np.array([1,4,3,-1,6,9])
(2).现在我们可以看看argsort()函数的具体功能是什么:
- x.argsort()
输出定义为y=array([3,0,2,1,4,5])。
我们发现argsort()函数是将x中的元素从小到大排列,提取其对应的index(索引),然后输出到y。例如:x[3]=-1最小,所以y[0]=3,x[5]=9最大,所以y[5]=5。
上面这个不难理解,不熟悉的可以去python环境下自己尝试。
(3).由于在程序中遇到了类似于np.argsort()[num]的形式,一直看不明白,就自己去python环境自己试了下:
ps:这里的num的绝对值小于等于x中元素的个数
当num>=0时,np.argsort()[num]就可以理解为y[num];
当num<0时,np.argsort()[num]就是把数组y的元素反向输出,例如np.argsort()[-1]即输出x中最大值对应的index,np.argsort()[-2]即输出x中第二大值对应的index,依此类推。。
直观的实验才能看到效果,下面是我拿上面例子做的验证:
这是当num为负值时的输出。
这个是num>=0时的输出。
2.Python-Numpy的tile函数用法
(1).函数的定义与说明
函数格式tile(A,reps)
A和reps都是array_like
A的类型众多,几乎所有类型都可以:array, list, tuple, dict, matrix以及基本数据类型int, string, float以及bool类型。
reps的类型也很多,可以是tuple,list, dict, array, int, bool.但不可以是float, string, matrix类型。
(2).函数操作示例
- >>> tile(1,2)
- array([1, 1])
- >>> tile((1,2,3),3)
- array([1, 2, 3, 1, 2, 3, 1, 2, 3])
- >>> tile(a,2)
- array([[1, 2, 3, 1, 2, 3],
- [4, 5, 5, 4, 5, 5]])
- >>> b=[1,3,5]
- >>> tile(b,[2,3])
- array([[1, 3, 5, 1, 3, 5, 1, 3, 5],
- [1, 3, 5, 1, 3, 5, 1, 3, 5]])
- >>> a=[[1,2,3],[5,4]]
- >>> tile(a,[2,3])
- array([[[1, 2, 3], [5, 4], [1, 2, 3], [5, 4], [1, 2, 3], [5, 4]],
- [[1, 2, 3], [5, 4], [1, 2, 3], [5, 4], [1, 2, 3], [5, 4]]])
3.python的二维数组操作
需要在程序中使用二维数组,网上找到一种这样的用法:

- #创建一个宽度为3,高度为4的数组
- #[[0,0,0],
- # [0,0,0],
- # [0,0,0],
- # [0,0,0]]
- myList = [[0] * 3] * 4

但是当操作myList[0][1] = 1时,发现整个第二列都被赋值,变成
[[0,1,0],
[0,1,0],
[0,1,0],
[0,1,0]]
为什么...一时搞不懂,后面翻阅The Python Standard Library 找到答案
list * n—>n shallow copies of list concatenated, n个list的浅拷贝的连接
例:

- >>> lists = [[]] * 3
- >>> lists
- [[], [], []]
- >>> lists[0].append(3)
- >>> lists
- [[3], [3], [3]]

[[]]是一个含有一个空列表元素的列表,所以[[]]*3表示3个指向这个空列表元素的引用,修改任何
一个元素都会改变整个列表:
所以需要用另外一种方式进行创建多维数组,以免浅拷贝:

- >>> lists = [[] for i in range(3)]
- >>> lists[0].append(3)
- >>> lists[1].append(5)
- >>> lists[2].append(7)
- >>> lists
- [[3], [5], [7]]

之前的二维数组创建方式为:
- myList = [([0] * 3) for i in range(4)
4.python zeros()使用(from numpy import *)
该函数的功能是创建给定类型的矩阵,并初始化为0。

- #一维数组
- zeros(3)
- #二维数组
- zeros((2,3))
- #或
- zeros([2,3])

dtype:数组数据类型,默认为float

- #使用默认类型
- b=zeros(3)
- type(b)
- #转换为int类型
- b=zeros(3)
- type(b)

zeros_like:返回和输入大小相同,类型相同,用0填满的数组

- <pre name="code" class="python">
#一维- a=array([2,3])
- zeros_like(a)
- #二维
- a=array([[2,3],[3,4]])
- zeros_like(a)

ones_like:返回和输入大小相同,数据类型相同,用1填满的数组

- #一维
- a=array([2,3])
- ones_like(a)
- #二维
- a=array([[2,3],[3,4]])
- ones_like(a)

empty_like:返回和输入大小相同,数据类型相同,但是是未初始化的数组(数据随机)

- #一维
- a=array([2,3])
- empty_like(a)
- empty_like(a, int)
- #二维
- a=array([[2,3],[3,4]])
- empty_like(a)
- empty_like(a, int)

ones:返回一个和输入大小相同,数据类型相同,初始化为1的数组
- np.ones(5)
- np.ones((2,1))
- s=(2,2)
- np.ones(s)
empty:返回一个新的未初始化的数组
- np.empty([2,2])
- np.empty([2,2],dtype=int)
python 在机器学习中应用函数的更多相关文章
- python开发_python中的函数定义
下面是我做的几个用列: #python中的函数定义,使用和传参 def_str = '''\ python中的函数以如下形式声明: def 函数名称([参数1,参数2,参数3......]): 执行语 ...
- python unittest框架中addCleanup函数详解
接上一篇doCleanups说明,这次介绍下另一个很好用的函数:addCleanup 还是老规矩,看官方文档说明: addCleanup(function, *args, **kwargs)¶ Add ...
- python 利用matplotlib中imshow()函数绘图
matplotlib 是python最著名的2D绘图库,它提供了一整套和matlab相似的命令API,十分适合交互式地进行制图.而且也可以方便地将它作为绘图控件,嵌入GUI应用程序中.通过简单的绘图语 ...
- (转)python类class中_init_函数以及参数self的简单解释
1)_init_函数(方法) #-*- encoding:utf-8 -*- class NewClass(object): def __init__(self,name): print self s ...
- python通过mongoengine中connect函数连接多个数据库
mongoengine支持程序同时连接多个数据库,这些数据库可以位于一个或多个mongo之中,通过alias名称区分不同的连接即可. 可以通过switch_db切换到不同的数据库,进行读写操作,swi ...
- python和numpy中sum()函数的异同
转载:https://blog.csdn.net/amuchena/article/details/89060798和https://www.runoob.com/python/python-func ...
- Python -- 使用模块中的函数
在确定自己不会导入多个同名函数(从不同模块导入)的情况下,你可能不希望在每次调用函数的时候,都要写上模块的名字.那么,可以使用import命令的另外一种形式: >>> from ma ...
- 关于python使用threadpool中的函数单个参数和多个参数用法举例
1.对单个元素的函数使用线程池: # encoding:utf-8 __author__='xijun.gong' import threadpool def func(name): print 'h ...
- Python函数式编程中map()、reduce()和filter()函数的用法
Python中map().reduce()和filter()三个函数均是应用于序列的内置函数,分别对序列进行遍历.递归计算以及过滤操作.这三个内置函数在实际使用过程中常常和“行内函数”lambda函数 ...
随机推荐
- Java线程池ThreadPoolExecutor使用和分析
线程池是可以控制线程创建.释放,并通过某种策略尝试复用线程去执行任务的一种管理框架,从而实现线程资源与任务之间的一种平衡. 以下分析基于 JDK1.7 转自: http://www.cnblogs. ...
- Linux 线程Demo
#include <stdio.h> #include <pthread.h> struct char_print_params { char character; int c ...
- SSM框架整合思路
SSM框架整合思路 Spring在整合中起到的作用(面试时常问到) Spring管理持久层的mapper. Spring管理业务层的service,service可以调用mapper接口.Spring ...
- [转] JPA 2.0 with EclipseLink - 教程
原文: http://www.vogella.com/articles/JavaPersistenceAPI/article.html Lars Vogel Version 2.2 Copyright ...
- 【转】java使用java.lang.management监视和管理 Java 虚拟机
原文地址:https://blog.csdn.net/zhongweijian/article/details/7619383 软件包 java.lang.management 提供管理接口,用于监视 ...
- 使用Netfilter进行数据包分析
#include <linux/init.h>#include <linux/module.h>#include <linux/skbuff.h>#include ...
- java有序列表
关于有序和无序的定义: 有序:有序列表中的元素具有某种内在的关联,这种关联定义了列表之间的顺序 无序:无序列表中的元素按使用者所选择得任意方式排序 索引:索引列表为他的元素维护一段连续的数字索引值 有 ...
- 【Linux】- Systemd 命令篇
转自:阮一峰的网络日志 Systemd 是 Linux 系统工具,用来启动守护进程,已成为大多数发行版的标准配置. 一.由来 历史上,Linux 的启动一直采用init进程. 下面的命令用来启动服务. ...
- Linux 进程间通信 有名管道(fifo)
有名管道特点: 1)无名管道只能用于具有亲缘关系的进程之间,这就限制了无名管道的使用范围 2)有名管道可以使互不相关的两个进程互相通信. 3)有名管道可以通过路径名来指出,并且在文件系统中可见,但内容 ...
- Linux 父子进程实现复制文件内容到另一个文件内
1. 子进程先拷贝前一半 ,父进程一直阻塞到子进程拷贝完再拷贝后一半 /* 子进程先拷贝前一半文件,父进程先阻塞等待子进程拷贝完前一半内容, * 然后父进程在拷贝,后一半内容 * */ #includ ...