Tensorflow学习:基本概念

一、Tensorflow基本概念

  1、使用图(graphs)来表示计算任务

  2、在被称之为会话(Session)的上下文(context)中执行图

  3、使用tensor表示数据

  4、通过变量(Variable)维护状态

  5、使用feed和fetch可以为任意的操作赋值或者从其中获取数据

  Tensorflow是一个编程系统,使用图(graphs)来表示计算任务,图(graphs)中的节点称之为op(operation),一个op获得0个或者多个Tensor,执行计算,产生0个或多个Tensor,Tensor看作是一个n维的数组或列表。图必须在会话(Session)里被启动。

二、Python代码实现基本概念

  1、创建并运行图

1 import tensorflow as tf     # 简写方便一点
2
3 # 创建两个常量(constant)
4 m1=tf.constant([[3,3]])     #一行两列的矩阵
5 m2=tf.constant([[2],[3]])   #两行一列的矩阵
6
7 # 创建一个矩阵乘法(matmul)的op
8 product=tf.matmul(m1,m2)
9 print(product)

  运行会得到显示结果

Tensor("MatMul:0", shape=(1, 1), dtype=int32)

  结果并不是想象中的是一个具体数字,而是一个Tensor,这是因为之前提到过 图必须在会话中运行,现在我们并未使用会话,所以只能得到一个Tensor

  定义会话有两种方法

1 # method 1
2 sess=tf.Session()            # 将Session简写为sess
3 result=sess.run(product)     # 调用run方法执行图,这个触发了三个op(操作),两个常量的建立,矩阵的乘法
4 print(result)
5 sess.close()                 # 关闭会话
1  # method 2
2 with tf.Session() as sess:    # Session()后面的()因为代码提示里没有,所以很容易丢
3     result=sess.run(product)
4     print(result)             # with as的这种结构会自动关闭会话

运行显示结果为

[[15]]

  2、变量

 1 import tensorflow as tf
 2
 3 x=tf.Variable([1,2])    # 定义一个变量
 4 a=tf.constant([3,3])    # 定义一个常量
 5
 6 sub=tf.subtract(x,a)    # 增加一个减法op
 7 add=tf.add(x,sub)       # 增加一个加法op
 8
 9 init=tf.global_variables_initializer()   # 在tensorflow中使用变量要初始化,此条语句也可以初始化多个变量
10
11 with tf.Session() as sess:
12     sess.run(init)                       # 变量初始化,也要放在会话中,才能执行
13     print(sess.run(sub))
14     print(sess.run(add))

  运行将得到结果

[-2 -1]
[-1  1]

  上述代码展示了变量的定义和初始化,但还没有体现变量的本质,下面一段代码实现变量state进行5次+1的操作

 1 state=tf.Variable(0,name=‘counter‘)        # 创建一个变量初始化为0,并命名为counter。(此段代码中命名无作用)
 2 new_value = tf.add(state,1)                # 创建一个加法op,作用是使state加1
 3 update=tf.assign(state,new_value)          # 此句话是赋值op,在tensorflow中,赋值也需要对应的方法
 4 init=tf.global_variables_initializer()     # 变量初始化
 5 with tf.Session() as sess:
 6     sess.run(init)
 7     print(sess.run(state))
 8     for _ in range(5):                     # Python中对于无需关注其实际含义的变量可以用_代替,这就和for i in range(5)一样,因为这里我们对i并不关心,所以用_代替仅获取值而已。
 9         sess.run(update)
10         print(sess.run(state))

  运行,显示结果为

0
1
2
3
4
5

  3、Fetch

  所谓fetch就是进行多个op,下一段代码 sess.run中就执行了两个op

 1 import tensorflow as tf
 2
 3 input1 = tf.constant(3.0)
 4 input2 = tf.constant(2.0)
 5 input3 = tf.constant(5.0)
 6
 7 add = tf.add(input2,input3)
 8 mul=tf.multiply(input1,add)
 9
10 with tf.Session() as sess:
11     result = sess.run([mul,add])       # 执行了两个op,要注意格式
12     print(result)

  运行,结果显示为

[21.0, 7.0]

  

  4、Feed

  feed的含义就是先不输入具体数值,先用占位方法占位,在会话中调用op时,再输入具体值。

import tensorflow as tf

input1 = tf.placeholder(tf.float32)      # 使用placeholder()占位,需要提供类型
input2 = tf.placeholder(tf.float32)
output = tf.multiply(input1,input2)

with tf.Session() as sess:
    print(sess.run(output,feed_dict={input1:[8.],input2:[2.]}))  # 要使用feed,则需要在调用run()时,除了输入op,还需要以字典形式输入feed_dict

  运行,显示结果为

[ 16.]

  以上就是一些比较基本的tensorflow概念的描述和代码实现

  ps:本人初学者,有错误欢迎指出。感谢。

原文地址:https://www.cnblogs.com/wanyu416/p/8954098.html

时间: 2024-10-29 09:36:49

Tensorflow学习:基本概念的相关文章

TensorFlow学习路径【转】

作者:黄璞链接:https://www.zhihu.com/question/41667903/answer/109611087来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 前言:其实TensorFlow本身仅仅是一个分布式的高性能计算框架,想要用TF做深度学习,仅仅学习这个框架本身是没有太大意义的.因此应该将TF看作技术路线中的一个核心点,去掌握整个开发所需要的必要技术,知识.尤其是深度学习的基本原理,这对日后搭建模型,模型调参以至提出新的模型都是极其有用的.

Tensorflow学习笔记2:About Session, Graph, Operation and Tensor

简介 上一篇笔记:Tensorflow学习笔记1:Get Started 我们谈到Tensorflow是基于图(Graph)的计算系统.而图的节点则是由操作(Operation)来构成的,而图的各个节点之间则是由张量(Tensor)作为边来连接在一起的.所以Tensorflow的计算过程就是一个Tensor流图.Tensorflow的图则是必须在一个Session中来计算.这篇笔记来大致介绍一下Session.Graph.Operation和Tensor. Session Session提供了O

java学习----入门概念

1.关于java语言的基本概念 java,面向对象,跨平台,适合分布式计算,解释型语言,具有多线程处理能力和较高的安全性. JVM (java virtual machine) java虚拟机, 能够运行java bytecode的虚拟机,是java平台的一部分.JVM屏蔽来与具体os相关的信息,使得java 程序只需生成在java虚拟机上运行的bytecode 当我们运行一个程序时,JVM负责将字节码转换为特定机器代码 何为虚拟机?即抽象化的计算机 java平台: 用java语言编写的软件赖以

TensorFlow学习笔记(UTF-8 问题解决 UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte)

我使用VS2013  Python3.5  TensorFlow 1.3  的开发环境 UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte 在是使用Tensorflow读取图片文件的情况下,会出现这个报错 代码如下 # -*- coding: utf-8 -*- import tensorflow as tf import numpy as np import mat

Ext学习-基础概念,核心思想介绍

1.目标   本阶段的目标是通过学习一些基础知识来对EXTJS有个整体的了解,知道EXTJS的基础语法,核心设计思想等等 2.内容   1.基础部分学习   2.EXTJS类系统介绍   3.EXTJSMVC结构介绍   4.EXTJS数据模型介绍 3.学习流程           1.在学习之前,首先要对javaScript的基础要有个基础了解,如果不熟悉,请参考:javaScript基础之闭包   2[可选]学习了解一下EXTJS的一些常用功能:http://ziren.org/extjs/

python tensorflow 学习

Tensorflow系列--Saver的用法:http://blog.csdn.net/u011500062/article/details/51728830 Tensorflow学习系列(二): tensorflow基础:http://blog.csdn.net/vs412237401/article/details/62039686 原文地址:https://www.cnblogs.com/cxscode/p/8283361.html

分布式强化学习基础概念(Distributional RL )

分布式强化学习基础概念(Distributional RL) from: https://mtomassoli.github.io/2017/12/08/distributional_rl/ 1. Q-learning 在 Q-learning 中,我们想要优化如下的 loss: Distributional RL 的主要思想是:to work directly with the full distribution of the return rather than with its expec

用tensorflow学习贝叶斯个性化排序(BPR)

在贝叶斯个性化排序(BPR)算法小结中,我们对贝叶斯个性化排序(Bayesian Personalized Ranking, 以下简称BPR)的原理做了讨论,本文我们将从实践的角度来使用BPR做一个简单的推荐.由于现有主流开源类库都没有BPR,同时它又比较简单,因此用tensorflow自己实现一个简单的BPR的算法,下面我们开始吧. 1. BPR算法回顾 BPR算法是基于矩阵分解的排序算法,它的算法训练集是一个个的三元组$<u,i,j>$,表示对用户u来说,商品i的优先级要高于商品j.训练成

Tensorflow学习笔记(一):MNIST机器学习入门

学习深度学习,首先从深度学习的入门MNIST入手.通过这个例子,了解Tensorflow的工作流程和机器学习的基本概念. 一  MNIST数据集 MNIST是入门级的计算机视觉数据集,包含了各种手写数字的图片.在这个例子中就是通过机器学习训练一个模型,以识别图片中的数字. MNIST数据集来自 http://yann.lecun.com/exdb/mnist/ Tensorflow提供了一份python代码用于自动下载安装数据集.Tensorflow官方文档中的url打不开,在CSDN上找到了一