从 tf.stack 讲解参数axis

前面博客中已经对 axis 进行了详细的讲解,这篇博客继续强化一下对 axis 的理解,因为矩阵运算中 axis 是一个非常重要的概念。
在这里插入图片描述

以 3D 图像为例:上面的 3D 图像的维度是 2 × 2 × 2 ,即每个小立方体(体素)存储着一个灰度值。
现在假设有以下三个 3D图像:

  1. [[[1, 2], [3, 4]], [[5, 6], [7, 8]]]
  2. [[[11, 12], [13, 14]], [[15, 16], [17, 18]]]
  3. [[[21, 22], [23, 24]], [[25, 26], [27, 28]]]

形象地展示一下第一个图像:
在这里插入图片描述

现在有一个需求:在三幅图像同样的位置提取一定体积的体素?比如,提取右上角体积为 1 × 1 × 1 的立方体,即 [1, 11, 21] 三个元素。

import tensorflow as tf

t1 = tf.constant([[[1, 2], [3, 4]], [[5, 6], [7, 8]]])
t2 = tf.constant([[[11, 12], [13, 14]], [[15, 16], [17, 18]]])
t3 = tf.constant([[[21, 22], [23, 24]], [[25, 26], [27, 28]]])

a = tf.stack([t1, t2, t3], axis=0)
b = tf.stack([t1, t2, t3], axis=-1)

with tf.Session() as sess:
    print("----1----")
    print(sess.run(a))
    print("----2----")
    print(sess.run(a[:, 0:1, 0:1, 0:1]))
    print("----3----")
    print(sess.run(b))
    print("----4----")
    # 注意维度上的区别
    print(sess.run(b[0:1, 0:1, 0:1, :]))

在这里插入图片描述

现在来对结果进行分析:
第二个输出是直接将原始3D图像堆叠,然后提取了3幅图像第一个体素;
第四个输出是将元素的对应体素先进行合并,增加一个维度,再提取这个合并的维度的所有体素。

如果想把第四种方式提取出来三个体素独立成 3幅 1 × 1 × 1 的图像可以使用下列方式:

image_T1, image_T2, label = tf.unstack(b[0:1, 0:1, 0:1, :], 3, axis=-1)
    print("***********")
    print(sess.run(image_T1))
    print(sess.run(image_T2))
    print(sess.run(label))

在这里插入图片描述

小结:
tf.stack() 矩阵拼接函数,即将秩为 R 的张量列表堆叠成一个秩为 (R+1) 的张量,而参数 axis 决定了从哪个维度堆叠, 从外到内依次为0,1,2…

将 values 中的张量列表堆叠成一个新张量,新张量比 values 中的每个张量都高一个秩,通过沿 axis 维度堆叠。给定一个形状为(A, B, C)的张量的长度 N 的列表:

如果 axis == 0,那么 output 张量将具有形状(N, A, B, C)。
如果 axis == 1,那么 output 张量将具有形状(A, N, B, C)。
如果 axis == 2,那么 output 张量将具有形状( A, B, N, C)。
如果 axis == 3,那么 output 张量将具有形状(A, B, C, N)。

tf.unstack() 是一个拆分矩阵的函数,将秩为 R 的张量的给定维度出栈为秩为 (R-1) 的张量。其中,参数 num 要与该 axis维度 元素个数相等,否则会报错。

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TensorFlow 中的 `tf.stack` 和 `tf.concat` 都可以用于将多个张量拼接成一个张量,但它们的实现方式略有不同,具体如下: - `tf.concat`: 沿着一个指定的维度将多个张量拼接起来。例如,将两个形状为 `(3, 4)` 的张量沿着第一个维度拼接起来,得到一个形状为 `(6, 4)` 的张量。`tf.concat` 的实现方式是将多个张量在指定维度上直接拼接,因此要求各个输入张量在指定维度上大小相同。 - `tf.stack`: 沿着一个新的维度将多个张量堆叠起来。例如,将两个形状为 `(3, 4)` 的张量在第三个维度上堆叠起来,得到一个形状为 `(3, 4, 2)` 的张量。`tf.stack` 的实现方式是创建一个新的维度,并在这个维度上将各个输入张量堆叠起来,因此各个输入张量的大小可以不同,但在其它维度上的大小必须相同。 下面是具体的使用示例: ```python import tensorflow as tf # 定义两个张量 a = tf.constant([1, 2, 3]) b = tf.constant([4, 5, 6]) # 使用 tf.concat 将两个张量拼接成一个张量 c = tf.concat([a, b], axis=0) print(c) # 输出 [1 2 3 4 5 6] # 使用 tf.stack 将两个张量堆叠成一个张量 d = tf.stack([a, b], axis=1) print(d) # 输出 [[1 4] [2 5] [3 6]] ``` 在上面的例子中,我们首先定义了两个形状相同的张量 `a` 和 `b`。然后我们使用 `tf.concat` 将它们沿着第一个维度拼接起来,得到一个形状为 `(6,)` 的张量 `c`;接着使用 `tf.stack` 将它们在第二个维度上堆叠起来,得到一个形状为 `(3, 2)` 的张量 `d`。可以看到,`tf.concat` 和 `tf.stack` 的输出结果是不同的,这是因为它们的实现方式不同,使用时需要根据具体的需求选择合适的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值