如何理解Axis?

简介: 前言只有光头才能变强。回顾前面:从零开始学TensorFlow【01-搭建环境、HelloWorld篇】什么是TensorFlow?TensorFlow读写数据不知道大家最开始接触到axis的时候是怎么样的,反正我是挺难理解的..我们可以发现TensorFlow的很多API都有axis这个参数,如果我们对axis不了解,压根不知道API是怎么搞的。

前言

只有光头才能变强。

回顾前面:

不知道大家最开始接触到axis的时候是怎么样的,反正我是挺难理解的..我们可以发现TensorFlow的很多API都有axis这个参数,如果我们对axis不了解,压根不知道API是怎么搞的。

一句话总结axis:axis可以方便我们将数据进行不同维度的处理

一、理解axis

如果你像我一样,发现API中有axis这个参数,但不知道是什么意思。可能就会搜搜axis到底代表的什么意思。于是可能会类似搜到下面的信息:

使用0值表示沿着每一列或行标签索引值向下执行方法(axis=0代表往跨行)

使用1值表示沿着每一行或者列标签模向执行对应的方法(axis=1代表跨列)

但我们又知道,我们的数组不单单只有二维的,还有三维、四维等等。一旦维数超过二维,就无法用简单的行和列来表示了

所以,可以用我下面的方式进行理解:

  • axis=0将最开外头的括号去除,看成一个整体,在这个整体上进行运算
  • axis=1将第二个括号去除,看成一个整体,在这个整体上进行运算
  • ...依次类推

话不多说,下面以例子说明~

1.1二维数组之concat

首先,我们来看个concat的例子,concat第一个参数接收val,第二个参数接收的是axis


def learn_concat():

    # 二维数组
    t1 = tf.constant([[1, 2, 3], [4, 5, 6]])
    t2 = tf.constant([[7, 8, 9], [10, 11, 12]])
    
    with tf.Session() as sess:
        
        # 二维数组针对 axis 为0 和 1 的情况
        print(sess.run(tf.concat([t1, t2], 0)))
        print(sess.run(tf.concat([t1, t2], 1)))

ok,下面以图示的方式来说明。现在我们有两个数组,分别是t1和t2:

两个数组,t1和t2

首先,我们先看axis=0的情况,也就是tf.concat([t1, t2], 0)。从上面的描述,我们知道,先把第一个括号去除,然后将其子内容看成一个整体,在这个整体下进行想对应的运算(这里我们就是concat)。

二维数组 axis=0的concat操作

所以最终的结果是:


[
    [1 2 3],
    [4 5 6],
    [7 8 9],
    [10 11 12]
]

接着,我们再看axis=1的情况,也就是tf.concat([t1, t2], 1)。从上面的描述,我们知道,先把第二个括号去除,然后将其子内容看成一个整体,在这个整体下进行想对应的运算(这里我们就是concat)。

axis=1理解 二维数组 concat

所以最终的结果是:


[
    [1, 2, 3, 7, 8, 9]
    [4, 5, 6, 10, 11, 12]
]

1.2三维数组之concat

接下来我们看一下三维的情况


def learn_concat():

    # 三维数组    
    t3 = tf.constant([[[1, 2], [2, 3]], [[4, 4], [5, 3]]])
    t4 = tf.constant([[[7, 4], [8, 4]], [[2, 10], [15, 11]]])

    with tf.Session() as sess:

        # 三维数组针对 axis 为0 和 1 和 -1 的情况
        print(sess.run(tf.concat([t3, t4], 0)))
        print(sess.run(tf.concat([t3, t4], 1)))
        print(sess.run(tf.concat([t3, t4], -1)))

ok,下面也以图示的方式来说明。现在我们有两个数组,分别是t3和t4:

两个数组,t3和t4

首先,我们先看axis=0的情况,也就是tf.concat([t3, t4], 0)。从上面的描述,我们知道,先把第一个括号去除,然后将其子内容看成一个整体,在这个整体下进行想对应的运算(这里我们就是concat)。

axis=0理解 三维数组 concat

所以最终的结果是:


[
    [
        [1 2]
        [2 3]
    ]
    [
        [4 4]
        [5 3]
    ]
    [
        [7 4]
        [8 4]
    ]
    [
        [2 10]
        [15 11]
    ]
]

接着,我们再看axis=1的情况,也就是tf.concat([t3, t4], 1)。从上面的描述,我们知道,先把第二个括号去除,然后将其子内容看成一个整体,在这个整体下进行想对应的运算(这里我们就是concat)。

axis=1理解 三维数组 concat

所以最终的结果是:


[
    [
        [1 2]
        [2 3]
        [7 4]
        [8 4]
    ]
    [
        [4 4]
        [5 3]
        [2 10]
        [15 11]
    ]
]

最后,我们来看一下axis=-1这种情况,在文档也有相关的介绍:

As in Python, the axis could also be negative numbers. Negative axis
are interpreted as counting from the end of the rank, i.e.,
axis + rank(values)-th dimension

所以,对于我们三维的数组而言,那axis=-1实际上就是axis=2,下面我们再来看一下这种情况:

axis=-1理解 三维数组 concat

最终的结果是:


[
 [
  [1 2 7 4]
  [2 3 8 4]
 ]
 [
  [4 4 2 10]
  [5 3 15 11]
 ]
]

除了concat以外,其实很多函数都用到了axis这个参数,再举个例子:


>>> item = np.array([[1,4,8],[2,3,5],[2,5,1],[1,10,7]])
>>> item
array([[1, 4, 8],
       [2, 3, 5],
       [2, 5, 1],
       [1, 10, 7]])

>>> item.sum(axis = 1)
array([13, 10,  8, 18])

>>> item.sum(axis = 0)
array([ 6, 22, 21])

参考资料:

最后

下一篇是TensorBoard~

乐于输出干货的Java技术公众号:Java3y。公众号内有200多篇原创技术文章、海量视频资源、精美脑图,不妨来关注一下!

觉得我的文章写得不错,不妨点一下

目录
相关文章
|
6月前
|
计算机视觉 Python
`np.ones()` 颜色解释
`np.ones()` 颜色解释
42 2
|
5月前
|
数据采集 Python
【随手记】np.random.choice()函数
【随手记】np.random.choice()函数
75 0
|
6月前
|
安全 数据挖掘
Excel 公式中 TAN 函数的用处
Excel 公式中 TAN 函数的用处
|
人工智能 Cloud Native Devops
1 分钟搞懂什么是 XY 问题
1 分钟搞懂什么是 XY 问题
314 0
|
机器学习/深度学习 编解码 人工智能
ATC 模型转换动态 shape 问题案例
ATC(Ascend Tensor Compiler)是异构计算架构 CANN 体系下的模型转换工具:它可以将开源框架的网络模型(如 TensorFlow 等)以及 Ascend IR 定义的单算子描述文件转换为昇腾 AI 处理器支持的离线模型;模型转换过程中,ATC 会进行算子调度优化、权重数据重排、内存使用优化等具体操作,对原始的深度学习模型进行进一步的调优,从而满足部署场景下的高性能需求,使其能够高效执行在昇腾 AI 处理器上。
215 0
|
Python
Python|动态规划统计正方形子矩阵
Python|动态规划统计正方形子矩阵
78 0
|
算法 索引 Python
零基础Python教程046期 矩阵行列互换算法,二维数组的典型应用
零基础Python教程046期 矩阵行列互换算法,二维数组的典型应用
150 0
|
Java
矩阵重叠(Java实现)
矩阵重叠(Java实现)
146 1
矩阵重叠(Java实现)
|
Python
numpy重新学习系列(11)---如何用np.linspace生成等间距的N个数字
numpy重新学习系列(11)---如何用np.linspace生成等间距的N个数字
222 0
numpy重新学习系列(11)---如何用np.linspace生成等间距的N个数字
python 绘图时显示不同的数学符号alpha,beta,偏导、求和等等
在使用python进行绘图时,当涉及当一些数学计算时,常常需要为我们的x、y轴以及标题添加标签,而一些特殊的数学计算符号往往在键盘上无法找到。特此,为了以后寻找方面,将一些常用的数学计算符号等进行汇总:
python 绘图时显示不同的数学符号alpha,beta,偏导、求和等等