tf.slice()是TensorFlow库中分割张量的一个函数,其定义为def slice(input_, begin, size, name=None):。tf.slice()函数的那些参数设置实在是不好理解,查了好多资料才理解,所以这边记录一下。

1.官方注释

官方的注释如下:

  1. """Extracts a slice from a tensor.
  2. This operation extracts a slice of size `size` from a tensor `input` starting
  3. at the location specified by `begin`. The slice `size` is represented as a
  4. tensor shape, where `size[i]` is the number of elements of the 'i'th dimension
  5. of `input` that you want to slice. The starting location (`begin`) for the
  6. slice is represented as an offset in each dimension of `input`. In other
  7. words, `begin[i]` is the offset into the 'i'th dimension of `input` that you
  8. want to slice from.
  9. Note that @{tf.Tensor.__getitem__} is typically a more pythonic way to
  10. perform slices, as it allows you to write `foo[3:7, :-2]` instead of
  11. `tf.slice([3, 0], [4, foo.get_shape()[1]-2])`.
  12. `begin` is zero-based; `size` is one-based. If `size[i]` is -1,
  13. all remaining elements in dimension i are included in the
  14. slice. In other words, this is equivalent to setting:
  15. `size[i] = input.dim_size(i) - begin[i]`
  16. This operation requires that:
  17. `0 <= begin[i] <= begin[i] + size[i] <= Di for i in [0, n]

翻译一下就是:

tf.slice()函数的作用就是从张量中提取想要的切片。此操作从由begin指定位置开始的张量input中提取一个尺寸size的切片.切片size被表示为张量形状,其中size[i]是你想要分割的input的第i维的元素的数量.切片的起始位置(begin)表示为每个input维度的偏移量.换句话说,begin[i]是你想从中分割出来的input的“第i个维度”的偏移量。

请注意,tf.Tensor.__getitem__通常是执行切片的python方式,因为它允许您写foo[3:7, :-2],而不是tf.slice([3, 0], [4, foo.get_shape()[1]-2]).

begin是基于零的;size是一个基础.如果size[i]是-1,则维度i中的所有其余元素都包含在切片中.

换句话说,这相当于设置:

  1. size[i] = input.dim_size(i) - begin[i]

该操作要求:

  1. 0 <= begin[i] <= begin[i] + size[i] <= Di for i in [0, n]

看完注释还是挺懵的,下面看看解释。

2.参数解释

  1. def slice(input_, begin, size, name=None):
  2. ...
  3. return gen_array_ops._slice(input_, begin, size, name=name)
  • input_

    input_类型为一个tensor,表示的是输入的tensor,也就是被切的那个
  • begin

    begin是一个int32或int64类型的tensor,表示的是每一个维度的起始位置
  • size

    size是一个int32或int64类型的tensor,表示的是每个维度要拿的元素数
  • name=None

    name是操作的名称,可写可不写
  • return

    返回一个和输入类型一样的tensor

3.例子

还是通过例子来讲解会比较容易理解

  • 例1
  1. t = tf.constant([[[1, 1, 1], [2, 2, 2]],
  2. [[3, 3, 3], [4, 4, 4]],
  3. [[5, 5, 5], [6, 6, 6]]])
  4. tf.slice(t, [1, 0, 0], [1, 1, 3]) # 输出[[[3, 3, 3]]]

首先作为一个3维数组t,要先明白他的shape是[3,2,3].

这个shape是怎么来的呢?咱们把这个t分解一下看就好理解了。那一大堆有括号的t,只看它最外面的括号的话,可以看成是:

  1. t = [A, B, C] #这是第一维度

然后每一个里面有两个东西,可以写成:

  1. A = [i, j], B = [k, l], C = [m, n] #这是第二维度

最后,这i, j, k, l, m, n里面分别是:

  1. i = [1, 1, 1], j = [2, 2, 2], k = [3, 3 ,3], l = [4, 4, 4], m = [5, 5, 5], n = [6, 6, 6] # 这是第三维度

所以shape就是中括号 [ ] 的层级里单位的数量。

对于t来说,最外面括号里有3个东西,分别是A, B, C。这三个东西每个里面有两个玩意儿, i和j, k和l, m和n。他们里面每一个又有3个数字。所以t的shape是[3,2,3]。

有了这个基础,我们再来看例子:

  1. t = tf.constant([[[1, 1, 1], [2, 2, 2]],
  2. [[3, 3, 3], [4, 4, 4]],
  3. [[5, 5, 5], [6, 6, 6]]])
  4. tf.slice(t, [1, 0, 0], [1, 1, 3]) # begin = [1, 0, 0]

有了这个基础,我们再来看例子:

  1. tf.slice(t, [1, 0, 0], [1, 1, 3]) # begin = [1, 0, 0]

注意一下,python的数组index是从0开始的。

这里根据顺序我们知道,begin是[1, 0, 0], size是[1, 1, 3]. 他们两个数组的意义是从左至右,每一个数字代表一个维度。上面说了begin的意思是起始位置,那么[1, 0, 0]的意思是在3个维度中,每个维度从哪里算起。

第一维度是[A, B, C]。 begin里[1, 0, 0]是1,也就是从B算起。其次第二维度里B = [k, l](注意啊,我这里只写了B = [k, l],可不代表只有B有用,如果size里第一个数字是2的话,B和C都会被取的),begin里第二个数是0,也就是从k算起。第三维度k = [3, 3 ,3],begin里第三个数是0,就是从第一个3算起。

到现在都能看懂吧?知道了这三个起始点之后,再来看size。

size的意思是每个维度的大小,也就是每个维度取几个元素。size的应该是最后输出的tensor的shape。

例子里面:

  1. tf.slice(t, [1, 0, 0], [1, 1, 3]) # size = [1, 1, 3]

size里第一个是1,意思是在第一个维度取1个元素。t = [A, B, C] begin是起算是B,取一个那就是B了呗。那么第一维度结果就是[B]

size第二个也是1,第二维度B = [k, l], begin里起算是k,取一个是k。那么第二维度结果是[[k]]。

size第三个是3,第三维度k = [3, 3 ,3],begin里起算是第一个3。三个3取3个数,那就要把三个3都取了,所以是

  1. [[[3, 3, 3]]]

看懂了吗?是不是有点像代数?[B]里把B换成[k], 再把k换成[3, 3 ,3]。最后注意中括号的数量,和size一样是[1, 1, 3].

  • 例2
  1. t = tf.constant([[[1, 1, 1], [2, 2, 2]], [[3, 3, 3], [4, 4, 4]], [[5, 5, 5], [6, 6, 6]]])
  2. tf.slice(t, [1, 0, 0], [-1, -1, -1])

对于这种情况,源代码注释中有一句话:

  1. If `size[i]` is -1, all remaining elements in dimension i are included in the slice. In other words, this is equivalent to setting: `size[i] = input.dim_size(i) - begin[i]`

也就是说,如果size输入值是-1的话,在那个维度剩下的数都会slice走。上面的例子中,begin是[1, 0, 0]。三个维度都是-1的话,那么结果: 第一维度是[B,C];第二维度是[[k, l], [m, n]]; 第三维度是[[[3,3,3], [4,4,4]], [[5,5,5], [6,6,6]]]

  • 例3
  1. import tensorflow as tf
  2. sess = tf.Session()
  3. input = tf.constant([[[[1, 1, 1], [2, 2, 2]],
  4. [[3, 3, 3], [4, 4, 4]],
  5. [[5, 5, 5], [6, 6, 6]]],
  6. [[[1, 1, 1], [2, 2, 2]],
  7. [[3, 3, 3], [4, 4, 4]],
  8. [[5, 5, 5], [6, 6, 6]]]])
  9. print(input)
  10. output=tf.slice(input,[0,0,0,1],[2,3,2,1])
  11. print(output)
  12. print(sess.run(output))

参考

[1] tf.slice()到底怎么切的,看不懂你掐死我

[2] TensorFlow分割:tf.slice函数

码字不易,如果您觉得有帮助,麻烦点个赞再走呗~

tf.slice()函数详解(极详细)的更多相关文章

  1. oracle常用函数详解(详细)

    转自:https://www.cnblogs.com/lxl57610/p/7442130.html Oracle SQL 提供了用于执行特定操作的专用函数.这些函数大大增强了 SQL 语言的功能.函 ...

  2. python3 内置函数详解

    内置函数详解 abs(x) 返回数字的绝对值,参数可以是整数或浮点数,如果参数是复数,则返回其大小. # 如果参数是复数,则返回其大小. >>> abs(-25) 25 >&g ...

  3. python pandas字符串函数详解(转)

     pandas字符串函数详解(转)——原文连接见文章末尾 在使用pandas框架的DataFrame的过程中,如果需要处理一些字符串的特性,例如判断某列是否包含一些关键字,某列的字符长度是否小于3等等 ...

  4. memset函数详解

    语言中memset函数详解(2011-11-16 21:11:02)转载▼标签: 杂谈 分类: 工具相关  功 能: 将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值, 块的大 ...

  5. fork()函数详解

    linux中fork()函数详解(原创!!实例讲解) (转载)    一.fork入门知识 一个进程,包括代码.数据和分配给进程的资源.fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程 ...

  6. C++ 虚函数详解

    C++ 虚函数详解 这篇文章主要是转载的http://blog.csdn.net/haoel/article/details/1948051这篇文章,其中又加入了自己的理解和难点以及疑问的解决过程,对 ...

  7. Python内置函数详解

    置顶   内置函数详解 https://docs.python.org/3/library/functions.html?highlight=built#ascii https://docs.pyth ...

  8. linux select函数详解

    linux select函数详解 在Linux中,我们可以使用select函数实现I/O端口的复用,传递给 select函数的参数会告诉内核: •我们所关心的文件描述符 •对每个描述符,我们所关心的状 ...

  9. (转)fock函数详解

    转自:http://www.cnblogs.com/bastard/archive/2012/08/31/2664896.html linux中fork()函数详解  一.fork入门知识 一个进程, ...

随机推荐

  1. Java IO: 并发IO

    原文链接 作者: Jakob Jenkov 译者: 李璟 有时候你可能需要并发地处理输入和输出.换句话说,你可能有超过一个线程处理输入和产生输出.比如,你有一个程序需要处理磁盘上的大量文件,这个任务可 ...

  2. js mvvm:闲来无事,实现一个只具最基本数据双向绑定的mvvm

    近期项目内用knockoutjs. 想模拟实现数据双向绑定的基本功能. 只具有最基本的功能,且很多细节未曾考虑,也未优化精简. 能想到的缺少的模块 1事件监听,自定义访问器事件 2模版 3父子级 编码 ...

  3. NopCommerce上二次开发 触发器记录

    最近要在NopCommerce上二次开发. 开发也就算了,该项目的架构设计很好,但性能不可谓不低. 扯远了,为了保持项目以后升级顺利,开次开发不允许在原项目基础上大改,只能以插件形式开发…… 因一个功 ...

  4. SQLite数据库迁移MySQL(MariaDB)完整步骤

    第一步(SQLite导出数据库): 命令方式导出数据库 > .output d:/data/lagou.sql //导出路径及文件名 > .dump //开始导出 修改lagou.sql文 ...

  5. Angular系列一:Angular程序架构

    Angular程序架构 Angular程序架构 组件:一段带有业务逻辑和数据的Html服务:用来封装可重用的业务逻辑指令:允许你向Html元素添加自定义行为模块: 环境搭建 安装nodeJs安装好no ...

  6. 添砖加瓦:几种常见的数据摘要算法(MD5、CRC32、SHA1和SHA256)

    1.算法概述 数据摘要算法是密码学算法中非常重要的一个分支,它通过对所有数据提取指纹信息以实现数据签名.数据完整性校验等功能,由于其不可逆性,有时候会被用做敏感信息的加密.数据摘要算法也被称为哈希(H ...

  7. 修改xampp中phpmyadmin用户管理

    用相关软件打开位于D:/xampp/phpMyAdmin文件夹中的config.inc.php文件. 搜索$cfg['Servers'][$i]['auth_type'] = 'config'; 将其 ...

  8. Selenium的Web自动化测试(送源码)

    8.1  Selenium自动化测试准备 1.Selenium介绍 Selenium是一个Web开源自动化测试框架,页面级操作,模拟用户真实操作,API从系统层面触发事件. Selenium 1.0  ...

  9. u-boot的环境变量详解

    u-boot的环境变量      u-boot的环境变量是使用u-boot的关键,它可以由你自己定义的,但是其中有一些也是大家经常使用,约定熟成的,有一些是u-boot自己定义的,更改这些名字会出现错 ...

  10. LSTM 句子相似度分析

    使用句子中出现单词的Vector加权平均进行文本相似度分析虽然简单,但也有比较明显的缺点:没有考虑词序且词向量区别不明确.如下面两个句子: "北京的首都是中国"与"中国的 ...