1、知识点

"""
tensorflow前端系统:定义程序的图结构,主要是利用一些API实现
tensorflow后端系统:运算图结构
numpy的reshape,在原始数据做修改,并没有创建新的数据对象
1、安装:按照官方文档安装
a)安装python,pip
b)升级 python -m pip install --upgrade pip
c)win10安装CPU版本tensorflow ,pip install https://storage.googleapis.com/tensorflow/windows/cpu/tensorflow-1.12.0-cp36-cp36m-win_amd64.whl
2、报警告1:FutureWarning: Conversion of the second argument of issubdtype from
解决方法:pip install h5py==2.8.0rc1
报警告2:Your CPU supports instructions that this TensorFlow binary was not compiled to use: AVX2 FMA
解决方法:
import os
os.environ['TF_CPP_MIN_LOG_LEVEL'] = '2'
3、tensorflow结构
椭圆代表张量,简称tensor:tensorflow中所有的数据都封装在tensor中
方块,简称operation(op):专门运算的操作节点,所有的操作都是op
图(graph):整个程序的结构
会话(Session):运算程序的图 4、a)图:运行程序的结构
图默认已经注册,一组表示 tf.Operation计算单位的对象和tf.Tensor。表示操作之间流动的数据单元的对象
获取调用:
tf.get_default_graph()
op、sess或者tensor 的graph属性
图的作用:主要给程序分配内存 图的创建:
1、创建默认的图:graph = tf.get_default_graph()
2、自定义图: g = tf.Graph() b)op:只要使用tensorflow的api定义的函数都是OP c)张量(tensor):就指代的是数据,op是tensor的载体 d)会话(Session):相当于桥梁,将图和计算资源连接起来
会话作用:
1、运行图的结构
2、分配资源计算
3、掌握资源(变量的资源,队列,线程) 注意:一个会话只能运行一个图结构 ,但可以在Session中指定图去运算
查看会话的资源情况:tf.Session(config=tf.ConfigProto(log_device_placement=True))
启动会话:sess.run()
关闭会话:sess.close() 启动会话(sess.run()):
1、run()中的参数必须是tensor或者op类型
2、如果变量想转换为tensor类型,可以和tensor做运算,提升数据类型
3、实时的提供数据进行训练,feed_dict与placeholder结合使用
4、placeholder是一个占位符 Session一般返回异常值:
1、RuntimeError:如果它Session处于无效状态(例如已关闭)。
2、TypeError:如果fetches或feed_dict键是不合适的类型。
3、ValueError:如果fetches或feed_dict键无效或引用 Tensor不存在。 5、张量(tensor):是tensorflow基本的数据格式。类似于numpy
张量的阶和数据类型: 包含:name,shape,dype
张量的属性:graph,op,name,shape
张量形状表示:
0维:() 1维:(5) 2维:(5,6) 3维:(2,3,4)
张量形状:包含动态形状和静态形状
1、动态形状:一种描述张量在执行过程中的一种形状
tf.reshape:创建一个具有不同形状的新张量
2、静态形状:创建一个张量,初始状态的形状
tf.Tensor.get_shape:获取静态形状
tf.Tensor.set_shape():更新tensor对象的静态形状
注意:1、静态形状固定了,就不能再次设置形状,只能使用动态形状,但会创建一个新的张量
2、动态形状改变,数据数量一定要匹配 6、运算API:正太分布主要通过平均值和标准差进行表示
1、生成张量:tf.zeros() 、tf.ones() 、tf.constant()
2、随机值张量:
正太分布(高斯分布)随机值:tf.random_normal()
截断的正太分布(高斯分布)随机值:tf.truncated_normal()
3、张量数据类型变换:
tf.cast(x,dtype) 万能转换类型
tf.squeeze()
4、拼接:tf.concat(values,axis) 7、变量:tf.Variable(),是一种OP,是一种特殊的张量,能够进行存储持久化,他的值就是张量,默认被训练
1、变量必须都初始化,且要在session中运行 tf.global_variables_initializer() 8、视图(tensorboard):首先将程序图结构序列化成一个event文件,然后通过tensorboard读取这个event文件
1、tf.summary.FileWriter("",graph=)
SCALARS:显示0维读值,如准确率,损失值
GRAPHS:显示程序图图结构
HISTOGRAPHS:高维的值,如权重,偏置
2、报错:No dashboards are active for the current data set
原因:因为没有读取到event文件,所以检查运行语句中logdir是否正确: tensorboard --logdir="./tmp/" """

2、代码

# coding = utf-8
import tensorflow as tf
import os
os.environ['TF_CPP_MIN_LOG_LEVEL'] = '' #变量op
def vari():
a = tf.constant([1,2,3])
var = tf.Variable(tf.random_normal([2,3],mean=0.0,stddev=1.0))
print(a,var)
init_op = tf.global_variables_initializer() #变量初始化
with tf.Session() as sess:
sess.run(init_op) #运行初始化变量
file = tf.summary.FileWriter("./tmp", graph=sess.graph)
print(sess.run([a, var])) #图的创建
def createGraph():
g = tf.Graph()
#with表示设定上下文环境
with g.as_default():
c = tf.constant(11.0)
print(c.graph) def addTest():
a = tf.constant(5.0)
b = tf.constant(6.0)
s = tf.add(a,b)
# print(s)
graph = tf.get_default_graph() #主要是分配内存
# print(graph)
plt = tf.placeholder(tf.float32,[None,3]) #None表示样本数不固定
with tf.Session() as sess:
print(sess.run(plt,feed_dict={plt:[[1,2,3],[4,5,6]]}))
#print(sess.run(s))
print(s.eval()) #使用eval()取值
#打印的地址一致
print(a.graph)
print(s.graph)
print(sess.graph) def shape():
plt = tf.placeholder(tf.float32,[None,2])
plt.set_shape([3,2]) #静态修改 if __name__ == '__main__':
vari()

tensorflow简介与结构介绍的更多相关文章

  1. 上门洗车APP --- Androidclient开发 之 项目结构介绍

    上门洗车APP --- Androidclient开发 之 项目结构介绍 前言 尽管公司项目较紧,但还是抽空给大家继续更新. o_O"~ 欢迎大家的关注,非常高兴和大家共同学习.前面给大家分 ...

  2. 第四百一十六节,Tensorflow简介与安装

    第四百一十六节,Tensorflow简介与安装 TensorFlow是什么 Tensorflow是一个Google开发的第二代机器学习系统,克服了第一代系统DistBelief仅能开发神经网络算法.难 ...

  3. Linux实战教学笔记07:Linux系统目录结构介绍

    第七节 Linux系统目录结构介绍 标签(空格分隔):Linux实战教学笔记 第1章 前言 windows目录结构 C:\windows D:\Program Files E:\你懂的\精品 F:\你 ...

  4. Magento学习第一课——目录结构介绍

    Magento学习第一课--目录结构介绍 一.Magento为何强大 Magento是在Zend框架基础上建立起来的,这点保证了代码的安全性及稳定性.选择Zend的原因有很多,但是最基本的是因为zen ...

  5. Poi之Word文档结构介绍

    1.poi之word文档结构介绍之正文段落 一个文档包含多个段落,一个段落包含多个Runs,一个Runs包含多个Run,Run是文档的最小单元 获取所有段落:List<XWPFParagraph ...

  6. vue学习笔记(三)——目录结构介绍

    1.初始目录结构如下: 2.目录结构介绍 目录/文件 说明 build 最终发布的代码存放位置. config 配置目录,包括端口号等.我们初学可以使用默认的. node_modules npm 加载 ...

  7. Vue 入门之目录结构介绍

    Vue 是一套用于构建用户界面的渐进式框架,与其它大型的页面框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合.另一方面,当 ...

  8. .NET Core实战项目之CMS 第十三章 开发篇-在MVC项目结构介绍及应用第三方UI

    作为后端开发的我来说,前端表示真心玩不转,你如果让我微调一个位置的样式的话还行,但是让我写一个很漂亮的后台的话,真心做不到,所以我一般会选择套用一些开源UI模板来进行系统UI的设计.那如何套用呢?今天 ...

  9. 25 Zabbix系统数据表结构介绍

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 25 Zabbix系统数据表结构介绍 自学Zabbix之路15.1 Zabbix数据库表结构简单解 ...

随机推荐

  1. Java 基本的数据类型(8种)

    1.Java 基本的数据类型(8种) 整型:byte .short .int .long 浮点型:float .double 字符型:char 布尔型:boolean

  2. Vi 入门简易教程

    首先,请注意,以下所讲的,全部是键盘在英文输入模式下.如果键盘是在中文输 入模式,全部的指令不正确. vi 有两种模式: Command Mode(指令模式) and Insert Mode(我姑且称 ...

  3. ANSIBLE自动化管理工具

    ansible 基础 自动化运维工具 官网:https://www.ansible.com/ 官方文档:https://docs.ansible.com/ ansible 特性 1. 模块化:调用特定 ...

  4. kubernetes之NFS动态提供Kubernetes后端存储卷

    StorageClass作为对存储资源的抽象定义, 对用户设置的NFS申请屏蔽后端存储的细节, 一方面减少了用户对于存储资源细节的关注, 另一方面减轻了管理员手工管理pv的工作, 由系统自动完成pv的 ...

  5. Thinkphp清除缓存文件

    Thinkphp的缓存在开发中是非常烦人的,因为有的时候因为缓存的问题而出现的错误是非常难找的.删除缓存更是麻烦,还要去文件夹下删除.如果是linux开发服务器的话还要登陆服务器进行删除.所以这个时候 ...

  6. 使用OmniDiskSweeper清理MAC

    Mac 经常提示我磁盘空间已满,管理磁盘空间. 然后我就管理了一下,发现系统竟占90个G,有点懵逼.然后网上查了资料 使用了一个名叫OmniDiskSweeper的超级强大的工具,而且还是免费的,它能 ...

  7. .ko文件

    ko文件介绍 .ko文件是kernel object文件(内核模块),该文件作用是把内核的部分功能移动到内核外边,需要的时候插入内核,不需要时卸载. 内核模块实现一些函数,作为回调函数注册到内核中.在 ...

  8. GIT 工作流程常用用命令大全

    一.Git基本工作流程 1.Git工作区域   2.向仓库中添加文件流程 二.Git初始化及仓库创建和操作 1.Git安装之后需要进行一些基本信息设置 a.设置用户名:git  config -- g ...

  9. 【vs2015发布程序】

    1.选中网站右键,选择发布Web应用 2.发布目标选择自定义 3.配置文件名称 4.发布方式选择File System,选择发布的程序存放路径 5.

  10. HDU 6047 - Maximum Sequence | 2017 Multi-University Training Contest 2

    /* HDU 6047 - Maximum Sequence [ 单调队列 ] 题意: 起初给出n个元素的数列 A[N], B[N] 对于 A[]的第N+K个元素,从B[N]中找出一个元素B[i],在 ...