Theano 中文文档 0.9 - 7.2.1 起手式 —— 代数
7.2.1 起手式 —— 代数
译者:Python 文档协作翻译小组,原文:Baby Steps - Algebra。
本文以 CC BY-NC-SA 4.0 协议发布,转载请保留作者署名和文章出处。
Python 文档协作翻译小组人手紧缺,有兴趣的朋友可以加入我们,完全公益性质。交流群:467338606。
两个标量相加
为了让我们开始使用Theano并获得我们正在使用的感觉,让我们做一个简单的函数:将两个数字加在一起。这里是你怎么做:
>>> import numpy
>>> import theano.tensor as T
>>> from theano import function
>>> x = T.dscalar('x')
>>> y = T.dscalar('y')
>>> z = x + y
>>> f = function([x, y], z)
现在我们已经创建了我们的函数,我们可以使用它:
>>> f(2, 3)
array(5.0)
>>> numpy.allclose(f(16.3, 12.1), 28.4)
True
让我们分成几个步骤。第一步是定义两个符号(变量),表示要相加的数量。注意,从现在起,我们将使用术语变量来表示“符号”(换句话说,x、y、z都是变量对象)。函数f的输出是零维度的numpy.ndarray
。
如果你正在跟着输入解释器,你可能已经注意到执行function
指令有一点点延迟。在幕后,f正在被编译成C代码。
步骤1
>>> x = T.dscalar('x')
>>> y = T.dscalar('y')
在Theano中,所有的符号必须具有类型。特别地,T.dscalar
是我们分配给“0维数组(双精度浮点数(d
)的标量
)”的类型。它是Theano的Type类型。
dscalar
不是类。因此,x或y都不是dscalar
的实例。它们是TensorVariable
的实例。然而,x和y的type
字段赋值为theano的dscalar
类型,正如你在下面看到的:
>>> type(x)
<class 'theano.tensor.var.TensorVariable'>
>>> x.type
TensorType(float64, scalar)
>>> T.dscalar
TensorType(float64, scalar)
>>> x.type is T.dscalar
True
通过使用字符串参数调用T.dscalar
,你将创建一个给定名称的变量,表示一个浮点数标量。如果你不提供参数,符号将不会命名。名称不是必需的,但它们可以帮助调试。
一会儿会更多地说到Theano的内部结构。你也可以通过查看Graph Structures了解更多。
步骤2
第二步是将x和y组合到它们的和z中:
>>> z = x + y
z是另一个变量,表示x和y相加。你可以使用pp函数精确打印与z相关的计算。
>>> from theano import pp
>>> print(pp(z))
(x + y)
步骤3
最后一步是创建一个以x和y作为输入并将z作为输出的函数:
>>> f = function([x, y], z)
function
的第一个参数是一个变量列表,它们将作为函数的输入。第二个参数是单个变量或一个变量的列表。不管哪一种情况,第二个参数是当我们应用函数时我们想要看到它的输出。f可以像普通的Python函数一样使用。
注意
作为一个捷径,你可以跳过第3步,只需使用变量的eval
方法。eval()
方法不像function()
一样灵活,但它可以完成我们在本教程中介绍的所有内容。它有额外的好处,不需要你导入function()
。下面是eval()
的工作原理:
>>> import numpy
>>> import theano.tensor as T
>>> x = T.dscalar('x')
>>> y = T.dscalar('y')
>>> z = x + y
>>> numpy.allclose(z.eval({x : 16.3, y : 12.1}), 28.4)
True
我们传递给eval()
一个字典,将theano的符号变量映射到值来替换它们,然后它返回表达式的数值。
eval()
在第一次调用变量时会变慢 - 需要调用function()
来编译后台表达式。在同一变量上对eval()
的后续调用将很快,因为变量缓存编译的函数。
两个矩阵相加
你可能已经猜到如何做到这一点。实际上,与上一个示例的唯一变化是,你需要使用矩阵类型实例化x和y:
>>> x = T.dmatrix('x')
>>> y = T.dmatrix('y')
>>> z = x + y
>>> f = function([x, y], z)
dmatrix
是双精度矩阵的类型。然后我们可以在二维数组上使用我们的新函数:
>>> f([[1, 2], [3, 4]], [[10, 20], [30, 40]])
array([[ 11., 22.],[ 33., 44.]])
变量是NumPy数组。我们也可以直接使用NumPy数组作为输入:
>>> import numpy
>>> f(numpy.array([[1, 2], [3, 4]]), numpy.array([[10, 20], [30, 40]]))
array([[ 11., 22.],[ 33., 44.]])
可以标量与矩阵相加,向量与矩阵相加,标量与向量相加等。这些操作的行为由broadcasting定义。
以下类型可以使用:
- byte:
bscalar, bvector, bmatrix, brow, bcol, btensor3, btensor4, btensor5
- 16-bit integers:
wscalar, wvector, wmatrix, wrow, wcol, wtensor3, wtensor4, wtensor5
- 32-bit integers:
iscalar, ivector, imatrix, irow, icol, itensor3, itensor4, itensor5
- 64-bit integers:
lscalar, lvector, lmatrix, lrow, lcol, ltensor3, ltensor4, ltensor5
- float:
fscalar, fvector, fmatrix, frow, fcol, ftensor3, ftensor4, ftensor5
- double:
dscalar, dvector, dmatrix, drow, dcol, dtensor3, dtensor4, dtensor5
- complex:
cscalar, cvector, cmatrix, crow, ccol, ctensor3, ctensor4, ctensor5
前面的列表并不详尽,并且可以在这里找到与NumPy数组兼容的所有类型的指南:tensor creation。
注意
你作为用户必须选择你的程序将使用32位还是64位整数(i
前缀还是l
前缀)和浮点数(f
前缀还是d
前缀)(不是系统架构来选择 )。
练习
import theano
a = theano.tensor.vector() # declare variable
out = a + a ** 10 # build symbolic expression
f = theano.function([a], out) # compile function
print(f([0, 1, 2]))
[ 0\. 2\. 1026.]
修改并执行此代码以计算此表达式:a * 2 + b * 2 + 2 * a * b。
答案
Theano 中文文档 0.9 - 7.2.1 起手式 —— 代数相关推荐
- Theano 中文文档 0.9 - 7.2.5 循环
7.2.5 循环 译者:Python 文档协作翻译小组,原文:Loop. 本文以 CC BY-NC-SA 4.0 协议发布,转载请保留作者署名和文章出处. Python 文档协作翻译小组人手紧缺,有兴 ...
- Theano 中文文档 0.9 - 7.2.6 Theano如何处理形状信息
7.2.6 Theano如何处理形状信息 译者:Python 文档协作翻译小组,原文:How Shape Information is Handled by Theano. 本文以 CC BY-NC- ...
- Theano 中文文档 0.9 - 7.2.3 Theano中的导数
7.2.3 Theano中的导数 译者:Python 文档协作翻译小组,原文:Derivatives in Theano. 本文以 CC BY-NC-SA 4.0 协议发布,转载请保留作者署名和文章出 ...
- Theano 中文文档 0.9 - 7.2.2 更多示例
7.2.2 更多示例 译者:Python 文档协作翻译小组,原文:More Examples. 本文以 CC BY-NC-SA 4.0 协议发布,转载请保留作者署名和文章出处. Python 文档协作 ...
- Theano 中文文档 0.9 - 5.3 Windows安装说明
5.3 Windows安装说明 译者:Python 文档协作翻译小组,原文:Windows Installation Instructions. 本文以 CC BY-NC-SA 4.0 协议发布,转载 ...
- Theano 中文文档 0.9 - 3. Theano一览
3. Theano一览 译者:Python 文档协作翻译小组,原文:Theano at a Glance. 本文以 CC BY-NC-SA 4.0 协议发布,转载请保留作者署名和文章出处. Pytho ...
- Theano 中文文档 0.9 - 7.2.4 条件
7.2.4 条件 译者:Python 文档协作翻译小组,原文:Conditions. 本文以 CC BY-NC-SA 4.0 协议发布,转载请保留作者署名和文章出处. Python 文档协作翻译小组人 ...
- Theano 中文文档 0.9 - 7. 教程
7. 教程 译者:Python 文档协作翻译小组,原文:Tutorial. 本文以 CC BY-NC-SA 4.0 协议发布,转载请保留作者署名和文章出处. Python 文档协作翻译小组人手紧缺,有 ...
- Theano 中文文档 0.9 - 6. 更新Theano
6. 更新Theano 译者:Python 文档协作翻译小组,原文:Updating Theano. 本文以 CC BY-NC-SA 4.0 协议发布,转载请保留作者署名和文章出处. Python 文 ...
最新文章
- php人员权限管理(RBAC)
- 我又踩坑了!如何为HttpClient请求设置Content-Type标头?
- Debug Hook
- json tcl_确定TCL中变量的类型
- cmake 在安装mysql_cmake安装mysql
- 基于JAVA+SpringMVC+MYSQL的高校教师档案管理系统
- 从C语言到C++的进阶之C到C++的转变(篇一)
- 十八年开发经验分享(二)问题解决篇(上)
- python能做什么程序-学完python可以做什么?
- 关于php编译安装扩展模块memcache的问题
- Linux下使用QQ
- 微信api接口调用-微信群管理
- NetBIOS协议和NBNS协议
- 如何把m4a转换成mp3?音频格式转换步骤
- Pwn-2018_HITB_CTF-gundam
- 基于AD9854的DDS信号发生器设计
- 使用Android Profiler连接成功后app闪退中断解决方法
- 稀疏矩阵的实现以及高斯塞达尔迭代法
- CQF平衡树——SBT论文——Size Balanced Tree
- 2020第六届“美亚杯”团队赛WP
热门文章
- (7)FPGA面试题Latch和Register区别
- Verilog实现AXI4-Lite源代码
- STM32F103:二.(4)控制SG90舵机
- c语言连续非递减子序列,最长非递减子序列的应用
- squid 的配置详解 (转)--SeriesIV
- [读书笔记] - 《深度探索C++对象模型》第2章 构造函数语意学
- orc parquet区别 spark_HIVE存储格式ORC、PARQUET对比
- 《深入理解分布式事务》第二章 MySQL 事务的实现原理
- 【高校宿舍管理系统】第零章 项目功能和技术路线
- 简单批处理与多道批处理