入门框架时的常见问题

学习框架的原因?

  • 方便、易用

学习框架的哪些知识点?

  • 掌握一个项目的基本流程,就知道需要学习哪些知识点了

迅速学习框架的方法

  • 根据项目每块流程的需要针对性的学
  • 可以看官方的入门教程

TensorFlow快速入门思维导图

(图)

TensorFlow的高级API

TF SLIM:一个可以定义、训练和评估复杂模型的轻量库(用到的时候详细说)

TF Learn(tf.contrib.learn):类似于scikit-learn的接口

其他:Keras等

TensorFlow学习要点

  • 数据类型
  • 运行机制
  • 数据的I/O
  • 模型的训练
  • 模型的保存
  • 模型的调用

TensorFlow的基本开发流程

项目流程

数据预处理->模型训练->模型保存->模型预测

  • 数据预处理:数据准备、数据清洗、特征工程、归一化处理
  • 神经网络与传统的机器学习不同,不需要做大量特征工程之后喂入特征,只需要设置好网络结构,输入原始数据即可完成训练。
  • 可以先对原始数据做归一化的处理,避免训练误差。

编写TensorFlow的两个步骤

  1. 构建计算图graph
  2. 使用Session去执行graph中的operation

其中涉及的基本定义

Tensor

  1. 类型化的多维数组,是图的边

  2. ???是N维的矩阵,可以看做一种符号化的句柄,指向存储运算结果吗,执行之后返回的基本类型,例如numpy的数组、list等

  3. 创建方法:

    1. tf.zeros()
    2. tf.ones()
    3. tf.fill()
    4. tf.constant()
    5. tf.random_uniform()
    6. tf.random_normal()
    7. ......
  4. 三个属性:rank、shape、data_type

    • Rank:指的是数据的数据的维度,与线性代数中的rank不是一个概念

      (图)

      rank = 0(标量)、1(向量)、2(矩阵)、3~n(n维Tensor)

      注意rank与shape之间的关系!

    • Shape:指的是Tensor每个维度数据的个数,可以用Python的list/tuple表示

      Rank和Shape之间的关系:

      (图)

    • Data_type:是指单个数据的类型。常用DT_FLOAT,也就是32位的浮点数。

      所有的Types如下:

      (图)

Operation

  1. 执行计算的单元,图的节点
  2. 是一个符号化的运算过程,是TensorFlow中的基本单元。是Graph中的计算节点,输入和输出均为Tensor
  3. 创建方法:
    1. tf.add()
    2. ......

Graph

  1. 一张有边与点的图,其表示了需要进行计算的任务

  2. TensorFlow中使用tf.Graph表示可计算的图,图是由操作Operation和张量Tensor构成的,其中Operation表示图的节点(即为运算单元),而Tensor则表示图的边(即为在Op之间流动的数据单元)

  3. 创建方法:

    • tf.Graph._ init _()(MK语法限制,下划线无空格):创建一个新的空Graph

    • 在TF中本身存在一个默认的Graph,若直接使用则不需要再创建图

    • 在with中调用tf.Graph().as_default()这个方法,可以设置默认的计算图

      (图)

Session

  1. 称之为会话的上下文,用于执行图

  2. 提供Operation执行和Tensor求值的环境

    (图)

  3. 分布式运算的使用,指定GPU/CPU

  4. 释放资源

    • 调用session.close()方法

      (图)

    • 使用with tf.Session()创建上下文(Context)来执行,当上下文退出时,资源将自动释放

      (图)

三大基本概念之间的关系如下:

(图)

Tensor和Operation都是Graph的对象,Operation是图的节点,而Tensor作为边,将Op连接起来。而Graph又必须在Session中才能执行

例子一

(图)

  • 在Tf中定义和执行这个计算图的操作时分开来的。
  • 创建一个完整的计算过程:
    1. 创建Tensor
    2. 添加Operation
    3. 创建Session,运行Graph
  • 这个图里有3个Operation,输入不是Operation但是输出是,因为输出可以执行计算,但是输入不行。
  • Operation添加之后不会立即执行,TensorFlow将等待所有的Operation均添加到Graph中后,根据最终的输出需要运算相应的Operation。

TensorFlow中的基本函数

Veriable

  1. 作用:保存并且更新参数,保存在内存中

(未完待续)

TensorFlow学习笔记(1)—— 基本概念与框架的更多相关文章

  1. TensorFlow学习笔记(一)

    [TensorFlow API](https://www.tensorflow.org/versions/r0.12/how_tos/variable_scope/index.html) Tensor ...

  2. Tensorflow学习笔记2019.01.22

    tensorflow学习笔记2 edit by Strangewx 2019.01.04 4.1 机器学习基础 4.1.1 一般结构: 初始化模型参数:通常随机赋值,简单模型赋值0 训练数据:一般打乱 ...

  3. tensorflow学习笔记——使用TensorFlow操作MNIST数据(2)

    tensorflow学习笔记——使用TensorFlow操作MNIST数据(1) 一:神经网络知识点整理 1.1,多层:使用多层权重,例如多层全连接方式 以下定义了三个隐藏层的全连接方式的神经网络样例 ...

  4. tensorflow学习笔记——自编码器及多层感知器

    1,自编码器简介 传统机器学习任务很大程度上依赖于好的特征工程,比如对数值型,日期时间型,种类型等特征的提取.特征工程往往是非常耗时耗力的,在图像,语音和视频中提取到有效的特征就更难了,工程师必须在这 ...

  5. TensorFlow学习笔记——LeNet-5(训练自己的数据集)

    在之前的TensorFlow学习笔记——图像识别与卷积神经网络(链接:请点击我)中了解了一下经典的卷积神经网络模型LeNet模型.那其实之前学习了别人的代码实现了LeNet网络对MNIST数据集的训练 ...

  6. TensorFlow学习笔记4-线性代数基础

    TensorFlow学习笔记4-线性代数基础 本笔记内容为"AI深度学习".内容主要参考<Deep Learning>中文版. \(X\)表示训练集的设计矩阵,其大小为 ...

  7. TensorFlow学习笔记1-入门

    TensorFlow学习笔记1-入门 作者: YunYuan *** 写在前面 本笔记是我学习TensorFlow官方文档中文版的读书笔记,由于尚未搭建好Github的个人博客的评论功能,故尚不方便与 ...

  8. Tensorflow学习笔记No.4.1

    使用CNN卷积神经网络(1) 简单介绍CNN卷积神经网络的概念和原理. 已经了解的小伙伴可以跳转到Tensorflow学习笔记No.4.2学习如和用Tensorflow实现简单的卷积神经网络. 1.C ...

  9. X-Cart 学习笔记(二)X-Cart框架1

    目录 X-Cart 学习笔记(一)了解和安装X-Cart X-Cart 学习笔记(二)X-Cart框架1 X-Cart 学习笔记(三)X-Cart框架2 X-Cart 学习笔记(四)常见操作 四.X- ...

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

    简介 上一篇笔记:Tensorflow学习笔记1:Get Started 我们谈到Tensorflow是基于图(Graph)的计算系统.而图的节点则是由操作(Operation)来构成的,而图的各个节 ...

随机推荐

  1. Java HotSpot(TM) 64-Bit Server VM warning: Sharing is only supported for boot loader classes because bootstrap classpath has been appended

    Java HotSpot(TM) 64-Bit Server VM warning: Sharing is only supported for boot loader classes because ...

  2. C# 读取Excel 单元格是日期格式

    原文地址:https://www.cnblogs.com/liu-xia/p/5230768.html DateTime.FromOADate(double.Parse(range.Value2.To ...

  3. 石子合并(NOI1995)题解

    题目描述 在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分. 试设计出1个算法,计算出将N堆石子合并成1 ...

  4. C博客作业01--分支丶顺序结构

    1.本章学习总结 1.1学习内容总结 分支结构 if else-if语句与switch语句都具有选择判断的功能,但是在使用时又有所区别,按题目的不同要求与题意选择不同语句. if else-if语句表 ...

  5. 关于python的深拷贝和浅拷贝

    写类函数的时候出了一个错,原代码写在这里: def Update(self, wm, vm, ts, pos, vn, att): # 上一时刻位置,速度 pos_pre = pos self.pos ...

  6. 【2019.12.04】SDN上机第6次作业

    实验拓扑 通过图形化界面建立拓扑 先清除网络拓扑 sudo mn -c 生成Python语句 #!/usr/bin/python from mininet.net import Mininet fro ...

  7. Linux学习笔记(一)

    操作系统(operation system,os) 主要作用是管理好硬件设备,并为用户和应用程序提供一个简单的接口, 以便于使用,作为中间人,连接软件和硬件 操作系统linux发展历程 unix-&g ...

  8. C#中将xml文件反序列化为实例时采用基类还是派生类的问题

    基类: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ...

  9. VS2013下开发VC++程序,编译时提示错误error MSB8020: The build tools for v140 (Platform Toolset = 'v140') 的解决方案

    1. 问题描述: 提示如下错误:error MSB8020: The builds tools for v140 (Platform Toolset = 'v140') cannot be found ...

  10. sci会议和sci期刊区别是什么

    sci会议和sci期刊区别是什么?从名称上来看就很明显了,一个是学术会议,一个是学术期刊,是不同的学术研究载体,不论是会议论文还是期刊论文,都是受认可的,就目前来看,发表期刊论文的作者要偏多一些,主要 ...