深度学习之向量化

一、深度学习向量化,去除for循环,增加运行速度,下面展示向量化与非向量化的速度差异

import numpy as np
#创建一个数据
#向量化版本
import time
a=np.random.rand(1000000)  #随机得到一个1000000的数组
b=np.random.rand(1000000)
time_begin=time.time() #测量当前时间
#向量化版本
c=np.dot(a,b)
time_end=time.time()
print("Vectorized version:"+str(1000*(time_end-time_begin))+"ms")


#非向量化样本
c=0
time_begin1=time.time() #测量当前时间
for i in range(1000000):
    c+=a[i]*b[i]
time_end2=time.time()

print("No-Vectorized version:"+str(1000*(time_end2-time_begin1))+"ms")

np.dot(a,b)是做矩阵乘法

np.random.rand(1000000)

可以生成任意随机数,括号里的数是生成1000000个秩为1的数组
结果如图,可见向量化速度大约是FOR循环速度的260倍快
在这里插入图片描述
二、由于Numpy库存在很对向量函数,所以在对向量进行处理时可以选择这些函数,以减少for循环的使用,从而增加程序运行速度

a=np.random.rand(1000)
b=np.maximum(a,0)

可以对a数组从大到小排序

a=np.random.rand(1000)
c=np.max(a)

可以对a数组求最大值
此外还有很多
u=np.exp()
u=np.log()
u=np.abs()等等

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值