博客
关于我
TensorFlow之张量
阅读量:789 次
发布时间:2019-03-24

本文共 1730 字,大约阅读时间需要 5 分钟。

TensorFlow之张量

1. 张量的基本概念

张量(Tensor)是TensorFlow中最基本的数据结构,类似于numpy中的数组。它是一个n维数组,数据类型为tf.Tensor。张量在TensorFlow中具有两个关键属性:【type和shape】。

  • type: 数据类型,如int32、float32等。
  • shape: 形状描述张量的维度,如 (3,4)表示3行4列的矩阵。

张量的阶数(rank)从0开始计算,如0阶为标量,1阶为1维数组(列表形式),2阶为矩阵形式等。

2. 张量的创建指令

创建张量可以分为几种类型:

  • 固定值张量(Constant Tensor):

    • 使用tf.constant函数创建常数值的张量。
    • 示例代码:
      import tensorflow as tf# 创建常数张量tensor1 = tf.constant(4.0)tensor2 = tf.constant([1, 2, 3, 4])linear_squares = tf.constant([[4], [9], [16], [25]], dtype=tf.int32)# 打印张量信息print(tensor1(shape))
  • 零张量(Zero Tensor):

    • 使用tf.zeros函数创建全零值的张量。
    • 示例:
      import osos.environ['TF_CPP_MIN_LOG_LEVEL'] = '2'import tensorflow as tfzeros = tf.zeros([3, 5])zeros_like = tf.zeros_like(zeros)
  • 一张量(One Tensor):

    • 使用tf.ones函数创建全一值的张量。
    • 示例:
      one = tf.ones([3, 4])ones_like = tf.ones_like(zeros)
  • 随机值张量(Random Tensor):

    • 使用tf.random函数生成随机数。
    • 示例:
      random_tensor = tf.random_normal([3, 5])
  • 特殊张量创建操作( 其他操作):

    • tf.Variable: 创建可变张量,通常用于模型训练中的变量。
    • tf.placeholder: 用于定义模型的输入张量,具有动态形状。
  • 3. 张量的变换与操作

    3.1 类型改变

    通过使用tf.cast函数可以将张量的数据类型转换。例如,将浮点数张量转换为整数型:

    import osos.environ['TF_CPP_MIN_LOG_LEVEL'] = '2'import tensorflow as tfone = tf.ones([3, 4])cast_one = tf.cast(one, tf.int32)print(cast_one)

    3.2 形状改变

    张量可以进行静态形状或动态形状的改变。

    • 静态形状改变:使用tf.reshape函数进行张量形状的静态改变。这一步骤适用于已知形状的张量,且不改变其元素总数。
      tf.reshape(tensor, new_shape)
    • 动态形状改变:使用tf.reshape进行动态形状创建,适用于不确定大小的张量,但要确保张量元素总数不变。
      tf.reshape(tensor, new_shape)

    3.3 数学运算

    • 算术运算: 使用基本的加、减、乘、除操作。
      a = tf.constant(3.0)b = tf.constant(2.0)c = a + bprint(c)
    • 矩阵运算: 使用高级矩阵函数,如矩阵乘法。
      import numpy as npmatrix_a = np.array([[1, 2], [3, 4]])matrix_b = np.array([[5, 6], [7, 8]])tf.matmul(matrix_a, matrix_b)
    • reduce操作: 将张量按某一轴进行聚合。
      a = tf.constant([1, 2, 3, 4])b = tf.reduce_sum(a)print(b)
    • 序列操作: 如分割、重复操作等。

    这些操作为张量提供了丰富的运算能力,使其在深度学习和数据处理中极为灵活。

    转载地址:http://bnekk.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>