第一 基础

1. 定义变量

#定义维度为[2,3], 平均值为·1, 标准差为1,类型为float32,名称为w1的服从正态分布的变量

w1 = tf.Variable(tf.random_normal(2, 3), stddev=1, seed=1, dtype=tf.float32, name='w1')

#定义维度为[2,3],平均值为1,标准差为1,类型为float32,名称为w1的服从正态分布的变量,偏离平均值超过两个标准差则重新生成

w1 = tf.Variable(tf.truncated_normal(2, 3), stddev=1, seed=1, dtype=tf.float32, name='w1')

2.定义常量

#定义值为[[1,2], [4,5]], 类型为float32, 名称为x的常量

x = tf.constant([[1, 2], [4, 5]], dtype=tf.float32, name='x')

3.定义占位符

#定义类型为float32,维度为[None, 2], 名称为x的占位符

x = tf.placeholder(tf.float32, shape=(None, 2), name='x')

4.开启回话

init_op = tf.initialize_all_variables()

with tf.Session() as sess:

  sess.run(init_op)

第二  优化

1.非线性与激活函数

INPUT_NODE = 2

OUTPUT_NODE = 1

LAYER1_NODE = 3

x = tf.placeholder(tf.float32, shape=(None, INPUT_NODE), name='x-input')

_y = tf.placeholder(tf.float32, shape=(None, OUTPUT_NODE), name='y-output')

weight1 = tf.Variable(tf.truncated_normal(INPUT_NODE, LAYER1_NODE), dtype=tf.float32, name='weight1')

biases1 = tf.Variable(tf.constant(0.1, shape=LAYER1_NODE), dtype=tf.float32, name='biases1')

weight2 = tf.Variable(tf.truncated_normal(LAYER1_NODE, OUTPUT_NODE), dtype=tf.float32, name='weight2')

biases2 = tf.Variable(tf.constant(0.1, shape=OUTPUT_NODE), dtype=tf.float32, name='biases2')

layer1 = tf.nn.relu(tf.matmul(x, weight1) + biases1)

y = tf.matmul(layer1, weight2) + biases2

2.交叉熵损失函数

(1)不封装写法

cross_entropy = -tf.reduce_mean(_y * tf.log(tf.clip_by_value(y, 1e-10, 1.0)))

train_step = tf.train.AdamOptimizer(0.001).minimize(cross_entropy)

(2)封装写法

cross_entropy = tf.nn.softmax_cross_entropy_with_logits(y, _y)

train_step = tf.train.AdamOptimizer(0.001).minimize(cross_entropy)

3.均方误差损失函数

mse = tf.reduce_mean(tf.square(_y - y))

train_step = tf.train.AdamOptimizer(0.001).minimize(mse)

4.自定义损失函数

LOSS_MORE = 10

LOSS_LESS = 1

loss = tf.reduce_sum(tf.select(tf.greater(y, _y), (y- _y) * LOSS_MORE, (_y - y) * LOSS_LESS))

train_step = tf.train.AdamOptimizer(0.001).minimize(loss)

5.指数衰减学习率

LEARNING_RATE_BASE = 0.1

LEARNING_RATE_DECAY = 0.99

ALL_SIZE = 10000

BATCH_SIZE = 10

global_step = tf.Variable(0, trainable=False)

learning_rate = tf.train.exponential_decay(LEARNING_RATE_BASE, global_step, ALL_SIZE/BATCH_SIZE, LEARNING_RATE_DECAY)

train_step = tf.train.GradientDescentOptimizer(learning_rate).minimize(loss, global_step=global_step)

6.过拟合问题与正则化

REGULARIZATION_RATE = 0.0001

regularizer = tf.contrib.layers.l2_regularizer(REGULARIZATION_RATE)

regularization = regularizer(weight1) + regularizer(weight2)

loss = cross_entropy + regularization

7.滑动平均模型

MOVING_AVERAGE_DECAY = 0.99

ema = tf.traim.ExponentialMovingAverage(MOVING_AVERAGE_DECAY, global_step)

ema_op = ema.apply(tf.trainable_variables())

TensorFlow总结的更多相关文章

  1. Tensorflow 官方版教程中文版

    2015年11月9日,Google发布人工智能系统TensorFlow并宣布开源,同日,极客学院组织在线TensorFlow中文文档翻译.一个月后,30章文档全部翻译校对完成,上线并提供电子书下载,该 ...

  2. tensorflow学习笔记二:入门基础

    TensorFlow用张量这种数据结构来表示所有的数据.用一阶张量来表示向量,如:v = [1.2, 2.3, 3.5] ,如二阶张量表示矩阵,如:m = [[1, 2, 3], [4, 5, 6], ...

  3. 用Tensorflow让神经网络自动创造音乐

    #————————————————————————本文禁止转载,禁止用于各类讲座及ppt中,违者必究————————————————————————# 前几天看到一个有意思的分享,大意是讲如何用Ten ...

  4. tensorflow 一些好的blog链接和tensorflow gpu版本安装

    pading :SAME,VALID 区别  http://blog.csdn.net/mao_xiao_feng/article/details/53444333 tensorflow实现的各种算法 ...

  5. tensorflow中的基本概念

    本文是在阅读官方文档后的一些个人理解. 官方文档地址:https://www.tensorflow.org/versions/r0.12/get_started/basic_usage.html#ba ...

  6. kubernetes&tensorflow

    谷歌内部--Borg Google Brain跑在数十万台机器上 谷歌电商商品分类深度学习模型跑在1000+台机器上 谷歌外部--Kubernetes(https://github.com/kuber ...

  7. tensorflow学习

    tensorflow安装时遇到gcc: error trying to exec 'as': execvp: No such file or directory. 截止到2016年11月13号,源码编 ...

  8. 【转】TensorFlow练习20: 使用深度学习破解字符验证码

    验证码是根据随机字符生成一幅图片,然后在图片中加入干扰象素,用户必须手动填入,防止有人利用机器人自动批量注册.灌水.发垃圾广告等等 . 验证码的作用是验证用户是真人还是机器人:设计理念是对人友好,对机 ...

  9. 【转】机器学习教程 十四-利用tensorflow做手写数字识别

    模式识别领域应用机器学习的场景非常多,手写识别就是其中一种,最简单的数字识别是一个多类分类问题,我们借这个多类分类问题来介绍一下google最新开源的tensorflow框架,后面深度学习的内容都会基 ...

  10. 【转】Ubuntu 16.04安装配置TensorFlow GPU版本

    之前摸爬滚打总是各种坑,今天参考这篇文章终于解决了,甚是鸡冻\(≧▽≦)/,电脑不知道怎么的,安装不了16.04,就安装15.10再升级到16.04 requirements: Ubuntu 16.0 ...

随机推荐

  1. 爬取伯乐在线文章(五)itemloader

    ItemLoader 在我们执行scrapy爬取字段中,会有大量的CSS或是Xpath代码,当要爬取的网站多了,要维护起来很麻烦,为解决这类问题,我们可以根据scrapy提供的loader机制. 导入 ...

  2. 【vue】vue中ref用法

    1.获取当前元素: 例子: <div class="pop pos-a" :style="{ left: pop_x + 'px' ,top: pop_y + 'p ...

  3. 七彩爱心灯手机APP

    安卓IDE3.20以后不包含sdk,需要更新重新下载. 1 下载工程 https://github.com/Dongvdong/Lovelamp_app 2打开工程 如果换了工程移动换了文件夹 (1) ...

  4. tomcat (选号)公司tomcat无页面解决

    问:我现在的有的解决方法就是把上一次war包下下载下来,在重启tomcat 答:那不行,更新war包就没有意义了,你都没排查故障  就直接说war包少东西?主页都没有..还能少主页也不是404.war ...

  5. XSS高级利用

    XSS会话劫持 (1)Cookie简介 Cookie是能够让网站服务器把少量文本数据存储到客户端的硬盘.内存,或者是从客户端的硬盘.内存读取数据的一种技术. Cookie是一段随HTTP请求.响应一起 ...

  6. 【LOJ 3049】「十二省联考 2019」字符串问题

    这个D1T2绝对有毒... 首先我们构造一把反串的后缀自动机. 然后我们就需要找到每一个子串在SAM上的节点. 这个可以通过扫描线+树上倍增处理. 首先我们把所有的子串按照左端点排序, 然后从右往左扫 ...

  7. C#高性能二进制序列化

    二进制序列化可以方便快捷的将对象进行持久化或者网络传输,并且体积小.性能高,应用面甚至还要高于json的序列化:开始之前,先来看看dotcore/dotne自带的二进制序列化:C#中对象序列化和反序列 ...

  8. Google机器学习课程基于TensorFlow : https://developers.google.cn/machine-learning/crash-course

    Google机器学习课程基于TensorFlow  : https://developers.google.cn/machine-learning/crash-course         https ...

  9. eclipse svn 删除不了项目,合并不了问题

    window/preferences  下  Teme  >svn  svn接口选择跟删除不了有关 但是合并 需要选择 JavaHl svn 服务端 1.8 eclipse选则 http://s ...

  10. 网盘直链工具 winform版 V1.0

    软件需要.net2.0支持 win7及以上版本用户无需安装 xp用户需要安装 支持网盘:好盘 坚果云 百度云 乐视云 华为网盘 微云 新浪网盘 126disk 速度盘 乐齐盘 天空网盘 千脑网盘 可乐 ...