TensorFlow介绍之TF数据流图
  TEZNKK3IfmPf 2023年11月13日 22 0

TensorFlow介绍之TF数据流图

1. TF数据流图

1.1案例:TensorFlow实现一个加法运算

示例代码:

def tensorflow_demo():
    """
    通过简单案例来了解tensorflow的基础结构
    :return: None
    """
    # 一、原生python实现加法运算
    a = 10
    b = 20
    c = a + b
    print("原生Python实现加法运算方法1:\n", c)
    def add(a, b):
        return a + b
    sum = add(a, b)
    print("原生python实现加法运算方法2:\n", sum)

    # 二、tensorflow实现加法运算
    a_t = tf.constant(10)
    b_t = tf.constant(20)
    # 不提倡直接运用这种符号运算符进行计算
    # 更常用tensorflow提供的函数进行计算
    # c_t = a_t + b_t
    c_t = tf.add(a_t, b_t)
    print("tensorflow实现加法运算:\n", c_t)
    # 如何让计算结果出现?
    # 开启会话
    with tf.Session() as sess:
        sum_t = sess.run(c_t)
        print("在sess当中的sum_t:\n", sum_t)

    return None

注意问题:警告指出你的CPU支持AVX运算加速了线性代数计算,即点积,矩阵乘法,卷积等。可以从源代码安装TensorFlow来编译,当然也可以选择关闭

import os
os.environ['TF_CPP_MIN_LOG_LEVEL']='2'

查看tensorflow版本:

import tensorflow as tf

print(tf.__version__)

TensorFlow介绍之TF数据流图

示例代码:

import tensorflow as tf

a = tf.constant(10)
b = tf.constant(20)

# c = a + b
c = tf.add(a, b)
print(c)

运行结果:

TensorFlow介绍之TF数据流图

此时并没有出现相加得到的和,需要建立一个会话。

示例代码:

import tensorflow as tf

a = tf.constant(10)
b = tf.constant(20)

# c = a + b
c = tf.add(a, b)

with tf.Session() as sess:
    sum_t = sess.run(c)
    print('a+b=', sum_t)

TensorFlow介绍之TF数据流图

解决如下:

import tensorflow.compat.v1 as tf

a = tf.constant(10)
b = tf.constant(20)

# c = a + b
c = tf.add(a, b)

with tf.Session() as sess:
    sum_t = sess.run(c)
    print('a+b=', sum_t)

TensorFlow介绍之TF数据流图

最终解决:

import tensorflow.compat.v1 as tf

tf.disable_v2_behavior()

a = tf.constant(10)
b = tf.constant(20)

# c = a + b
c = tf.add(a, b)

with tf.Session() as sess:
    sum_t = sess.run(c)
    print('a+b=', sum_t)

TensorFlow介绍之TF数据流图

TensorFlow介绍之TF数据流图

接下来去掉报红的日志信息:

import os
os.environ['TF_CPP_MIN_LOG_LEVEL'] = '2'
import tensorflow.compat.v1 as tf

tf.disable_v2_behavior()

a = tf.constant(10)
b = tf.constant(20)

# c = a + b
c = tf.add(a, b)

with tf.Session() as sess:
    sum_t = sess.run(c)
    print('a+b=', sum_t)

TensorFlow介绍之TF数据流图

1.2 TensorFlow结构分析

TensorFlow 程序通常被组织成一个构建图阶段和一个执行图阶段。

在构建阶段,数据与操作的执行步骤被描述成一个图。

在执行阶段,使用会话执行构建好的图中的操作。

  • 图和会话 :
    • 图:这是 TensorFlow 将计算表示为指令之间的依赖关系的一种表示法
    • 会话:TensorFlow 跨一个或多个本地或远程设备运行数据流图的机制
  • 张量:TensorFlow 中的基本数据对象    【可以理解为numpy中的数组】
  • 节点:提供图当中执行的操作   【图中 的一些运算机制】

1.3 数据流图介绍

TensorFlow介绍之TF数据流图

TensorFlow是一个采用数据流图(data flow graphs),用于数值计算的开源框架。

节点(Operation)在图中表示数学操作,线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月13日 0

暂无评论

TEZNKK3IfmPf