deep_learning_month2_week3_TensorFlow_Tutorial

2024-04-25 12:18

本文主要是介绍deep_learning_month2_week3_TensorFlow_Tutorial,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

deep_learning_month2_week3_TensorFlow_Tutorial

标签: 机器学习深度学习

代码已上传github:
https://github.com/PerfectDemoT/my_deeplearning_homework


  • deep_learning_month2_week3_TensorFlow_Tutorial
      • 1. 这个是自己随意写的小练习,然后其实可以忽略,这些代码后面是这次作业的代码与讲解
    • 现在开始看作业代码,其实这次作业主要是要我们一步步练习一下几个常用的tf语句
      • 2. 完成Loss函数的运算
      • 3. 再来看看一个神奇的函数tf.placeholder
      • 4. 接下来看看一个小实验,就是用tf实现普通的线性函数
      • 5. 下面写一个sigmoid函数(其实本质上还是调用了tf.sigmoid())
      • 6. 现在来用tf写一个cost函数:
      • 7. 下面谈谈独热编码(我看了这个英文文档,查了下这个单词,发现是第一次听说这个名词。。。是我太菜)
      • 8.现在创建矩阵,用tf.ones(),也是个tf语句小练习
      • 9. 好了,现在来用tf完整写一个机器学习代码,这个例子是用图像识别来看我们用手比划的到底是数字几(可以是0-5)
        • 1. 我们先导入数据,然后看一看它们的维度啥的
        • 2. 开始搭建,先用tf.placeholders创建两个x,y变量以便于最后用训练数据X ,Y来训练
        • 3. 现在开始初始化参数(就像我注释里说的,我暂时还不知道这个用到的tf里的随机语句和普通的随机有啥不同)
        • 4. 老套路,初始化完成之后,现在来看前向传播啦,注意中间用relu函数,最后用softmax函数
        • 5. 接下来,毫无疑问,cost函数啦
        • 6. 接下来,本来是不是要独立写一个反向传播函数?不过这次不用了,对于一个一句话的反向传播,写最后model里就好了。。。还是稳啊
        • 7. 下面用自己的图片来试试

说明:这个作业主要是为了大家训练TensorFlow,当然,里面用了softmax回归,也算是一个softmax练习把。不过其实我也不太知道这里给的TensorFlow常用语句的够不够(个人感觉是肯定不够的),所以之前也自己看官方文档写了一点,(待会就不一一分类了,直接把这个代码贴出来),总而言之,这次的作业还是以训练TensorFlow为主。

另外:我把这个最后的训练参数保存下来了,上传到了我的github里面(saveparameters),当然,保存参数的源码也在run.py里。


老规矩,先导入包

import math
import numpy as np
import tensorflow as tf
from tensorflow.python.framework import ops
import h5py
import matplotlib.pyplot as plt
import pylab
import scipy
from PIL import Image
from scipy import ndimage
import pickle as pklfrom tf_utils import load_dataset, random_mini_batches, convert_to_one_hot, predict

1. 这个是自己随意写的小练习,然后其实可以忽略,这些代码后面是这次作业的代码与讲解

#创建一个1*2的矩阵
matrix1 = tf.constant([[3,1]])
#创建一个2*1的矩阵
matrix2 = tf.constant([[1] , [5]])
#将他们相乘
produce = tf.matmul(matrix1 , matrix2)sess = tf.Session()
print(sess.run(produce))
#会话关闭
sess.close()#现在试试对于变量的操作
#我们先来做一个计数器
#先创建一个变量初始化为0
state = tf.Variable(0 , name="counter")
# 创建一个op节点,初始化为1,作用是让变量每次加一
one = tf.constant(1)
new_value = tf.add(state , one)
update = tf.assign(state , new_value) #注意,这里暂时不知道什么意思,官方文档的实例里暂时没看到
# 启动图后, 变量必须先经过`初始化` (init) op 初始化,
# 首先必须增加一个`初始化` op 到图中.
init_op = tf.initialize_all_variables()# 代码中 assign() 操作是图所描绘的表达式的一部分, 正如 add() 操作一样. 所以在调用 run() 执行表达式
# 之前, 它并不会真正执行赋值操作.
# 通常会将一个统计模型中的参数表示为一组变量. 例如, 你可以将一个神经网络的权重作为某个变量存储在一个
# tensor 中. 在训练过程中, 通过重复运行训练图, 更新这个 tensor#启动会话
with tf.Session() as sess :# 运行'init'opsess.run(init_op)# 打印'state'的初始值print(sess.run(state))print(sess.run(new_value))# 运行'op',更新'state',并打印'state'for _ in range(3):sess.run(update)print(sess.run(state))#上方为自己看官方文档做的小练习,下面开始做作业。。。

现在开始看作业代码,其实这次作业主要是要我们一步步练习一下几个常用的tf语句

2. 完成Loss函数的运算

#完成lost损失函数的运算
y_hat = tf.constant(36, name='y_hat')            # Define y_hat constant. Set to 36.是一个常量
y = tf.constant(39, name='y')                    # Define y. Set to 39loss = tf.Variable((y - y_hat)**2, name='loss')  # Create a variable for the loss是一个变量init = tf.global_variables_initializer()         # When init is run later (session.run(init)),# the loss variable will be initialized and ready to be computed
with tf.Session() as session:                    # Create a session and print the outputsession.run(init)                            # Initializes the variablesprint(session.run(loss))                     # Prints the loss# Writing and running programs in TensorFlow has the following steps:
#
# 1. Create Tensors (variables) that are not yet executed/evaluated.
# 2. Write operations between those Tensors.
# 3. Initialize your Tensors.
# 4. Create a Session.
# 5. Run the Session. This will run the operations you'd written above.
#
# Therefore, when we created a variable for the loss, we simply defined the loss as a function of other quantities, but did not evaluate its value. To evaluate it, we had to run `init=tf.global_variables_initializer()`. That initialized the loss variable, and in the last line we were finally able to evaluate the value of `loss` and print its value.a = tf.constant(2)
b = tf.constant(10)
c = tf.multiply(a,b)
sess = tf.Session()
print(sess.run(c))
print("=======================")

注意其中的注释说明:跑tf的几个步骤
Writing and running programs in TensorFlow has the following steps:

  1. Create Tensors (variables) that are not yet executed/evaluated.
  2. Write operations between those Tensors.
  3. Initialize your Tensors.
  4. Create a Session.
  5. Run the Session. This will run the operations you’d written above.

3. 再来看看一个神奇的函数tf.placeholder

这个函数,变量在声明时,不需要赋值,而是在run的时候才给他赋值

#下面来看看tf.placeholder函数
# Change the value of x in the feed_dict
# A placeholder is an object whose value you can specify only later.
# To specify values for a placeholder, you can pass in values by using a "feed dictionary" (`feed_dict` variable).
# Below, we created a placeholder for x.
# This allows us to pass in a number later when we run the session.
x = tf.placeholder(tf.int64, name = 'x')
print(sess.run(2 * x, feed_dict = {x: 3})) #这里在sess.run里才对x进行赋值
sess.close()
print("========================")

4. 接下来看看一个小实验,就是用tf实现普通的线性函数

 # #对于下面构造的函数,你可能需要用到这些
# - tf.matmul(..., ...) to do a matrix multiplication
# - tf.add(..., ...) to do an addition
# - np.random.randn(...) to initialize randomly
# GRADED FUNCTION: linear_function
def linear_function():"""Implements a linear function:Initializes W to be a random tensor of shape (4,3)Initializes X to be a random tensor of shape (3,1)Initializes b to be a random tensor of shape (4,1)Returns:result -- runs the session for Y = WX + b"""np.random.seed(1)### START CODE HERE ### (4 lines of code)X = tf.constant(np.random.randn(3 , 1) , name="X")W = tf.constant(np.random.randn(4 , 3) , name="W")b = tf.constant(np.random.randn(4 , 1) , name="b")Y = tf.add(tf.matmul(W , X) , b)### END CODE HERE #### Create the session using tf.Session() and run it with sess.run(...) on the variable you want to calculate### START CODE HERE ###sess = tf.Session()result = sess.run(Y)### END CODE HERE #### close the sessionsess.close()return result

看看输出:

#下面来测试一下
print( "result = " + str(linear_function()))
print("=================================")

5. 下面写一个sigmoid函数(其实本质上还是调用了tf.sigmoid())

#下面这里又有点好奇,这是为了熟悉而进行的训练么?难道使用的时候在主函数里直接tf.sigmoid(x)不会跑。。?(貌似tf.sigmoid()也可以,可能这里只是为了练习或者弄了一个好看的封装。。?)
# GRADED FUNCTION: sigmoid
def sigmoid(z):"""Computes the sigmoid of zArguments:z -- input value, scalar or vectorReturns:results -- the sigmoid of z"""### START CODE HERE ### ( approx. 4 lines of code)# Create a placeholder for x. Name it 'x'.x = tf.placeholder(tf.float32 , name="x")# compute sigmoid(x)sigmoid = tf.sigmoid(x)# Create a session, and run it. Please use the method 2 explained above.# You should use a feed_dict to pass z's value to x.with tf.Session() as sess:# Run session and call the output "result"result = sess.run(sigmoid, feed_dict={x : z})### END CODE HERE ###return result

跑一下检验一下:

#输出看看
print ("sigmoid(0) = " + str(sigmoid(0)))
print ("sigmoid(12) = " + str(sigmoid(12)))
print("===============================")

6. 现在来用tf写一个cost函数:

#来试试用TensorFlow写cost函数
# GRADED FUNCTION: cost
def cost(logits, labels):"""Computes the cost using the sigmoid cross entropyArguments:logits -- vector containing z, output of the last linear unit (before the final sigmoid activation)labels -- vector of labels y (1 or 0)Note: What we've been calling "z" and "y" in this class are respectively called "logits" and "labels"in the TensorFlow documentation. So logits will feed into z, and labels into y.Returns:cost -- runs the session of the cost (formula (2))"""### START CODE HERE #### Create the placeholders for "logits" (z) and "labels" (y) (approx. 2 lines)z = tf.placeholder(tf.float32 , name="z")y = tf.placeholder(tf.float32 , name="y")# Use the loss function (approx. 1 line)cost = tf.nn.sigmoid_cross_entropy_with_logits(logits = z , labels = y)# Create a session (approx. 1 line). See method 1 above.sess = tf.Session()# Run the session (approx. 1 line).cost = sess.run(cost , feed_dict={z : logits, y : labels})# Close the session (approx. 1 line). See method 1 above.sess.close()### END CODE HERE ###return cost

语句cost = tf.nn.sigmoid_cross_entropy_with_logits(logits = z , labels = y)很神奇有没有。。。一句话解决问题,,,很稳。
输出测试一下:

#好,来跑一跑这个tf的神奇的cost函数(讲道理,我看到那条语句真的震惊。。。仿佛没见过世面)
logits = sigmoid(np.array([0.2,0.4,0.7,0.9]))
cost = cost(logits, np.array([0,0,1,1]))
print ("cost = " + str(cost))
print("===================")

7. 下面谈谈独热编码(我看了这个英文文档,查了下这个单词,发现是第一次听说这个名词。。。是我太菜)

指的是在分类问题中,将存在数据类别的那一类用X表示,不存在的用Y表示,这里的X常常是1, Y常常是0。,举个例子:
比如我们有一个5类分类问题,我们有数据(xi,yi)(xi,yi),其中类别yiyi有五种取值(因为是五类分类问题),所以如果yjyj为第一类那么其独热编码为:
[1,0,0,0,0],
如果是第二类那么独热编码为:[0,1,0,0,0],也就是说只对存在有该类别的数的位置上进行标记为1,其他皆为0。这个编码方式经常用于多分类问题,特别是损失函数为交叉熵函数的时候。

用图片解释一下:

意思清楚了,现在看看tf是如何一句话解决问题的。。。

def one_hot_matrix(labels, C):"""Creates a matrix where the i-th row corresponds to the ith class number and the jth columncorresponds to the jth training example. So if example j had a label i. Then entry (i,j)will be 1.Arguments:labels -- vector containing the labelsC -- number of classes, the depth of the one hot dimensionReturns:one_hot -- one hot matrix"""### START CODE HERE #### Create a tf.constant equal to C (depth), name it 'C'. (approx. 1 line)C = tf.constant(C, name="C")# Use tf.one_hot, be careful with the axis (approx. 1 line)one_hot_matrix = tf.one_hot(labels , C , axis=0)# Create the session (approx. 1 line)sess = tf.Session()# Run the session (approx. 1 line)one_hot = sess.run(one_hot_matrix)# Close the session (approx. 1 line). See method 1 above.sess.close()### END CODE HERE ###return one_hot

对于这个函数:one_hot_matrix = tf.one_hot(labels , C , axis=0),第一个参数是一维向量,第二个参数C是这个向量里的元素的总类别数

现在来跑一跑:

#现在来跑一下
labels = np.array([1,2,3,0,2,1])
one_hot = one_hot_matrix(labels, C = 4)
print ("one_hot = " + str(one_hot))
#注意这个对于Y是竖着的
print("=====================")

8.现在创建矩阵,用tf.ones(),也是个tf语句小练习

#现在创建矩阵,让里面的元素全是1,用语句 tf.ones()
# GRADED FUNCTION: ones
def ones(shape):"""Creates an array of ones of dimension shapeArguments:shape -- shape of the array you want to createReturns:ones -- array containing only ones"""### START CODE HERE #### Create "ones" tensor using tf.ones(...). (approx. 1 line)ones = tf.ones(shape)# Create the session (approx. 1 line)sess = tf.Session()# Run the session to compute 'ones' (approx. 1 line)ones = sess.run(ones)# Close the session (approx. 1 line). See method 1 above.sess.close()### END CODE HERE ###return ones

测试一下:

#让我们看看效果
print ("ones = " + str(ones([3])))
print("=======================")

9. 好了,现在来用tf完整写一个机器学习代码,这个例子是用图像识别来看我们用手比划的到底是数字几(可以是0-5)

1. 我们先导入数据,然后看一看它们的维度啥的

这里注意要对图片0-255的数值归一化噢
然后后面还对y进行了独热编码

# Loading the dataset
#先导入数据
X_train_orig, Y_train_orig, X_test_orig, Y_test_orig, classes = load_dataset()
#展示一张图片看看
# Example of a picture
index = 0
plt.imshow(X_train_orig[index])
pylab.show()
#看到一只手,然后它的y显示它是y=5的类
print ("y = " + str(np.squeeze(Y_train_orig[:, index])))
print("=========================")#然后我们队数据进行处理,尤其是将其归一化(除以255),并且将进行独热编码
# Flatten the training and test images
X_train_flatten = X_train_orig.reshape(X_train_orig.shape[0], -1).T
X_test_flatten = X_test_orig.reshape(X_test_orig.shape[0], -1).T
# Normalize image vectors
X_train = X_train_flatten/255.
X_test = X_test_flatten/255.
# Convert training and test labels to one hot matrices
Y_train = convert_to_one_hot(Y_train_orig, 6)
Y_test = convert_to_one_hot(Y_test_orig, 6)print ("number of training examples = " + str(X_train.shape[1]))
print ("number of test examples = " + str(X_test.shape[1]))
print ("X_train shape: " + str(X_train.shape))
print ("Y_train shape: " + str(Y_train.shape))
print ("X_test shape: " + str(X_test.shape))
print ("Y_test shape: " + str(Y_test.shape))
#通过Y的列,我们可以看出,有6个类
print("=============================")

看一看其中的一幅图
数据展示

2. 开始搭建,先用tf.placeholders创建两个x,y变量以便于最后用训练数据X ,Y来训练
# 现在开始搭建一个神经网络,当然,是用tf,并且最后使用softmax函数
# GRADED FUNCTION: create_placeholders
def create_placeholders(n_x, n_y):"""Creates the placeholders for the tensorflow session.Arguments:n_x -- scalar, size of an image vector (num_px * num_px = 64 * 64 * 3 = 12288)n_y -- scalar, number of classes (from 0 to 5, so -> 6)Returns:X -- placeholder for the data input, of shape [n_x, None] and dtype "float"Y -- placeholder for the input labels, of shape [n_y, None] and dtype "float"Tips:- You will use None because it let's us be flexible on the number of examples you will for the placeholders.In fact, the number of examples during test/train is different."""### START CODE HERE ### (approx. 2 lines)X = tf.placeholder(tf.float32, shape = (n_x,None))Y = tf.placeholder(tf.float32, shape = (n_y,None))### END CODE HERE ###return X, Y

测试一下:

#,我们已经建立X,Y,现在看看
X, Y = create_placeholders(12288, 6)
print ("X = " + str(X))
print ("Y = " + str(Y))
print("======================")
3. 现在开始初始化参数(就像我注释里说的,我暂时还不知道这个用到的tf里的随机语句和普通的随机有啥不同)
#下面我们开始初始化参数吧(注意看初始化的那个函数,暂时还不太清楚这样和普通的随机初始化有什么不同)
# GRADED FUNCTION: initialize_parameters
def initialize_parameters():"""Initializes parameters to build a neural network with tensorflow. The shapes are:W1 : [25, 12288]b1 : [25, 1]W2 : [12, 25]b2 : [12, 1]W3 : [6, 12]b3 : [6, 1]Returns:parameters -- a dictionary of tensors containing W1, b1, W2, b2, W3, b3"""tf.set_random_seed(1)  # so that your "random" numbers match ours### START CODE HERE ### (approx. 6 lines of code)W1 = tf.get_variable("W1", [25 , 12288] , initializer = tf.contrib.layers.xavier_initializer())b1 = tf.get_variable("b1" , [25 , 1] , initializer = tf.zeros_initializer())W2 = tf.get_variable("W2" , [12 , 25] , initializer = tf.contrib.layers.xavier_initializer())b2 = tf.get_variable("b2", [12,1], initializer = tf.zeros_initializer())W3 = tf.get_variable("W3", [6,12], initializer = tf.contrib.layers.xavier_initializer())b3 = tf.get_variable("b3", [6,1], initializer = tf.zeros_initializer())### END CODE HERE ###parameters = {"W1": W1,"b1": b1,"W2": W2,"b2": b2,"W3": W3,"b3": b3}return parameters

初始化完了,测试一下,必须的:

# 下面输出看看
tf.reset_default_graph()
with tf.Session() as sess:parameters = initialize_parameters()print("W1 = " + str(parameters["W1"]))print("b1 = " + str(parameters["b1"]))print("W2 = " + str(parameters["W2"]))print("b2 = " + str(parameters["b2"]))# 我们可以看到,这些随机初始化好的参数并没有被赋值print("=======================")
4. 老套路,初始化完成之后,现在来看前向传播啦,注意中间用relu函数,最后用softmax函数
# GRADED FUNCTION: forward_propagation
def forward_propagation(X, parameters):"""Implements the forward propagation for the model: LINEAR -> RELU -> LINEAR -> RELU -> LINEAR -> SOFTMAXArguments:X -- input dataset placeholder, of shape (input size, number of examples)parameters -- python dictionary containing your parameters "W1", "b1", "W2", "b2", "W3", "b3"the shapes are given in initialize_parametersReturns:Z3 -- the output of the last LINEAR unit"""# Retrieve the parameters from the dictionary "parameters"W1 = parameters['W1']b1 = parameters['b1']W2 = parameters['W2']b2 = parameters['b2']W3 = parameters['W3']b3 = parameters['b3']### START CODE HERE ### (approx. 5 lines)              # Numpy Equivalents:Z1 = tf.add(tf.matmul(W1 , X) , b1)  # Z1 = np.dot(W1, X) + b1A1 = tf.nn.relu(Z1)  # A1 = relu(Z1)Z2 = tf.add(tf.matmul(W2 , A1) , b2)  # Z2 = np.dot(W2, a1) + b2A2 = tf.nn.relu(Z2)  # A2 = relu(Z2)Z3 = tf.add(tf.matmul(W3 , A2) , b3)  # Z3 = np.dot(W3,Z2) + b3### END CODE HERE ###return Z3

大家注意看,这里面没有缓存各层的Z和A,这或许就是tf的神奇之处之一

前向传播完成,现在测试一下:

# 前向传播完成,现在来试试
tf.reset_default_graph()
with tf.Session() as sess:X, Y = create_placeholders(12288, 6)parameters = initialize_parameters()Z3 = forward_propagation(X, parameters)print("Z3 = " + str(Z3))# 不知道大家发现没,这里竟然没有要我们缓存各层的Z和A,那我们待会反向传播咋办?或许这就是tf的神奇之处。。。
5. 接下来,毫无疑问,cost函数啦
# GRADED FUNCTION: compute_cost
def compute_cost(Z3, Y):"""Computes the costArguments:Z3 -- output of forward propagation (output of the last LINEAR unit), of shape (6, number of examples)Y -- "true" labels vector placeholder, same shape as Z3Returns:cost - Tensor of the cost function"""# to fit the tensorflow requirement for tf.nn.softmax_cross_entropy_with_logits(...,...)logits = tf.transpose(Z3)labels = tf.transpose(Y)### START CODE HERE ### (1 line of code)#注意这里是用的softmax函数cost = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits = logits , labels = labels))### END CODE HERE ###return cost

注意一个地方:在tf.nn.softmax_cross_entropy_with_logits的外面套了一个tf.reduce_mean,一开始我就没有加这个,结果就有点问题(会该诉你得到的是个向量,并且还是个维度不确定的向量,不过维度不确定好像是前面初始化的原因)。

下面输出看看

# 还是稳啊,cost直接一行
tf.reset_default_graph()with tf.Session() as sess:X, Y = create_placeholders(12288, 6)parameters = initialize_parameters()Z3 = forward_propagation(X, parameters)cost = compute_cost(Z3, Y)print("cost = " + str(cost))print("==================")
6. 接下来,本来是不是要独立写一个反向传播函数?不过这次不用了,对于一个一句话的反向传播,写最后model里就好了。。。还是稳啊

另外,说明一下在其中的反向传播过程:
After you compute the cost function. You will create an “optimizer” object. You have to call this object along with the cost when running the tf.session. When called, it will perform an optimization on the given cost with the chosen method and learning rate.
意思是这个optimizer里面存的是把cost最小化并且乘以了学习率

def model(X_train, Y_train, X_test, Y_test, learning_rate=0.0001,num_epochs=1500, minibatch_size=32, print_cost=True):"""Implements a three-layer tensorflow neural network: LINEAR->RELU->LINEAR->RELU->LINEAR->SOFTMAX.Arguments:X_train -- training set, of shape (input size = 12288, number of training examples = 1080)Y_train -- test set, of shape (output size = 6, number of training examples = 1080)X_test -- training set, of shape (input size = 12288, number of training examples = 120)Y_test -- test set, of shape (output size = 6, number of test examples = 120)learning_rate -- learning rate of the optimizationnum_epochs -- number of epochs of the optimization loopminibatch_size -- size of a minibatchprint_cost -- True to print the cost every 100 epochsReturns:parameters -- parameters learnt by the model. They can then be used to predict."""ops.reset_default_graph()  # to be able to rerun the model without overwriting tf variablestf.set_random_seed(1)  # to keep consistent resultsseed = 3  # to keep consistent results(n_x, m) = X_train.shape  # (n_x: input size, m : number of examples in the train set)n_y = Y_train.shape[0]  # n_y : output sizecosts = []  # To keep track of the cost# Create Placeholders of shape (n_x, n_y)### START CODE HERE ### (1 line)X, Y = create_placeholders(n_x , n_y)### END CODE HERE #### Initialize parameters### START CODE HERE ### (1 line)#这里由于上面已经定了各层神经网络的规模,所以不需要参数(下次自己用这里得改)parameters = initialize_parameters()### END CODE HERE #### Forward propagation: Build the forward propagation in the tensorflow graph### START CODE HERE ### (1 line)Z3 = forward_propagation(X , parameters)### END CODE HERE #### Cost function: Add cost function to tensorflow graph### START CODE HERE ### (1 line)cost = compute_cost(Z3 , Y)### END CODE HERE #### Backpropagation: Define the tensorflow optimizer. Use an AdamOptimizer.### START CODE HERE ### (1 line)optimizer = tf.train.AdamOptimizer(learning_rate=learning_rate).minimize(cost)### END CODE HERE #### Initialize all the variablesinit = tf.global_variables_initializer()# Start the session to compute the tensorflow graphwith tf.Session() as sess:# Run the initializationsess.run(init)# Do the training loop# 这是训练循环次数for epoch in range(num_epochs):epoch_cost = 0.  # Defines a cost related to an epoch#看看用mini-batch得分多少组num_minibatches = int(m / minibatch_size)  # number of minibatches of size minibatch_size in the train setseed = seed + 1minibatches = random_mini_batches(X_train, Y_train, minibatch_size, seed)# 这里是使用mini-batch,将训练样本分组for minibatch in minibatches:# Select a minibatch(minibatch_X, minibatch_Y) = minibatch# IMPORTANT: The line that runs the graph on a minibatch.# Run the session to execute the "optimizer" and the "cost", the feedict should contain a minibatch for (X,Y).### START CODE HERE ### (1 line)_, minibatch_cost = sess.run([optimizer , cost] , feed_dict={X : minibatch_X , Y : minibatch_Y})### END CODE HERE ###epoch_cost += minibatch_cost / num_minibatches #有个问题,最后那个组的大小一般会小于其他的组,那这个比例岂不是会更大# Print the cost every epochif print_cost == True and epoch % 100 == 0:print("Cost after epoch %i: %f" % (epoch, epoch_cost))if print_cost == True and epoch % 5 == 0:costs.append(epoch_cost)# plot the costplt.plot(np.squeeze(costs))plt.ylabel('cost')plt.xlabel('iterations (per tens)')plt.title("Learning rate =" + str(learning_rate))plt.show()# lets save the parameters in a variableparameters = sess.run(parameters)print("Parameters have been trained!")# Calculate the correct predictionscorrect_prediction = tf.equal(tf.argmax(Z3), tf.argmax(Y))# Calculate accuracy on the test setaccuracy = tf.reduce_mean(tf.cast(correct_prediction, "float"))print("Train Accuracy:", accuracy.eval({X: X_train, Y: Y_train}))print("Test Accuracy:", accuracy.eval({X: X_test, Y: Y_test}))return parameters

挺长,里面有两个地方,在英文文档中有专门说明:
For instance, for gradient descent the optimizer would be:

optimizer = tf.train.GradientDescentOptimizer(learning_rate = learning_rate).minimize(cost)

To make the optimization you would do:

 _ , c = sess.run([optimizer, cost], feed_dict={X: minibatch_X, Y: minibatch_Y})

对于这个’_’ 是一个习惯用法:把之后不需要用到的结果变量用’_’储存,表示这个值之后是不需要用到的

然后呢,,,然后就开始训练了,不过,做好心理准备,要好几分钟
然后下面是自己写的保存训练好的参数的代码,如果要提取的话,见下方

print("现在开始训练参数(要一会噢,五六分钟吧)")
parameters = model(X_train, Y_train, X_test, Y_test)#保存好训练好的参数
file = open('saveparameters.txt', 'w')
file.write(str(parameters))
file.close()
# #读取
# file = open('saveparameters.txt','r')
# saveparameters = file.read()
# parameters = eval(saveparameters)
# f.close()

然后cost曲线如图:
cost

7. 下面用自己的图片来试试

直接上代码

#现在开始可以用自己的图来测试效果啦,用手比一个数字,然后就可以识别了:
## START CODE HERE ## (PUT YOUR IMAGE NAME)
my_image = "thumbs_up.jpg"
## END CODE HERE ### We preprocess your image to fit your algorithm.
fname = "images/" + my_image
image = np.array(ndimage.imread(fname, flatten=False))
my_image = scipy.misc.imresize(image, size=(64,64)).reshape((1, 64*64*3)).T
my_image_prediction = predict(my_image, parameters)plt.imshow(image)
print("Your algorithm predicts: y = " + str(np.squeeze(my_image_prediction)))

这篇关于deep_learning_month2_week3_TensorFlow_Tutorial的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/934661

相关文章

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

简单的Q-learning|小明的一维世界(3)

简单的Q-learning|小明的一维世界(1) 简单的Q-learning|小明的一维世界(2) 一维的加速度世界 这个世界,小明只能控制自己的加速度,并且只能对加速度进行如下三种操作:增加1、减少1、或者不变。所以行动空间为: { u 1 = − 1 , u 2 = 0 , u 3 = 1 } \{u_1=-1, u_2=0, u_3=1\} {u1​=−1,u2​=0,u3​=1}

简单的Q-learning|小明的一维世界(2)

上篇介绍了小明的一维世界模型 、Q-learning的状态空间、行动空间、奖励函数、Q-table、Q table更新公式、以及从Q值导出策略的公式等。最后给出最简单的一维位置世界的Q-learning例子,从给出其状态空间、行动空间、以及稠密与稀疏两种奖励函数的设置方式。下面将继续深入,GO! 一维的速度世界 这个世界,小明只能控制自己的速度,并且只能对速度进行如下三种操作:增加1、减

win10不用anaconda安装tensorflow-cpu并导入pycharm

记录一下防止忘了 一、前提:已经安装了python3.6.4,想用tensorflow的包 二、在pycharm中File-Settings-Project Interpreter点“+”号导入很慢,所以直接在cmd中使用 pip install -i https://mirrors.aliyun.com/pypi/simple tensorflow-cpu下载好,默认下载的tensorflow

稀疏自编码器tensorflow

自编码器是一种无监督机器学习算法,通过计算自编码的输出与原输入的误差,不断调节自编码器的参数,最终训练出模型。自编码器可以用于压缩输入信息,提取有用的输入特征。如,[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]四比特信息可以压缩成两位,[0,0],[1,0],[1,1],[0,1]。此时,自编码器的中间层的神经元个数为2。但是,有时中间隐藏层的神经元

Tensorflow实现与门感知机

感知机是最简单的神经网络,通过输入,进行加权处理,经过刺激函数,得到输出。通过输出计算误差,调整权重,最终,得到合适的加权函数。 今天,我通过tensorflow实现简单的感知机。 首先,初始化变量:     num_nodes = 2     output_units = 1     w = tf.Variable(tf.truncated_normal([num_nodes,output

Tensorflow lstm实现的小说撰写预测

最近,在研究深度学习方面的知识,结合Tensorflow,完成了基于lstm的小说预测程序demo。 lstm是改进的RNN,具有长期记忆功能,相对于RNN,增加了多个门来控制输入与输出。原理方面的知识网上很多,在此,我只是将我短暂学习的tensorflow写一个预测小说的demo,如果有错误,还望大家指出。 1、将小说进行分词,去除空格,建立词汇表与id的字典,生成初始输入模型的x与y d

Deepin Linux安装TensorFlow

Deepin Linux安装TensorFlow 1.首先检查是否有Python,一般deepin系统都自带python的。   2.安装pip Sudo appt-get install pip来安装pip,如果失败就先更新一下sudo apt-get updata,然后再sudo apt-get install pip,如果定位失败,就sudo apt-get install pyth

Deep Ocr

1.圈出内容,文本那里要有内容.然后你保存,并'导出数据集'. 2.找出deep_ocr_recognition_training_workflow.hdev 文件.修改“DatasetFilename := 'Test.hdict'” 310行 write_deep_ocr (DeepOcrHandle, BestModelDeepOCRFilename) 3.推理test.hdev

终止distributed tensorflow的ps进程

1.直接终止: $ ps -ef | grep python | grep 文件名 | awk {'print $2'} | xargs kill文件名为当前运行的程序,名称如:distribute.py 2.查找pid,后kill: $ ps -ef | grep python | grep 文件名 | awk {'print $2'}$ kill -9 <pid>