1 Star 0 Fork 6

黄耀东/天池_道路通行时间预测LSTM

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
lstm_model.py 6.14 KB
一键复制 编辑 原始数据 按行查看 历史
xuanlei 提交于 2017-08-04 14:25 . 模型训练
# -*- coding: utf-8 -*-
"""
Created on Tue Aug 1 15:37:00 2017
@author: xuanlei
"""
import pandas as pd
import tensorflow as tf
import numpy as np
#==============================================================================
# Batch Normalization
#==============================================================================
def batch_norm_layer(x, train_phase, scope_bn):
with tf.variable_scope(scope_bn):
beta = tf.Variable(tf.constant(0.0, shape=[x.shape[-1]]), name='beta', trainable=True)
gamma = tf.Variable(tf.constant(1.0, shape=[x.shape[-1]]), name='gamma', trainable=True)
axises = np.arange(len(x.shape) - 1)
batch_mean, batch_var = tf.nn.moments(x, axises, name='moments')
ema = tf.train.ExponentialMovingAverage(decay=0.5)
def mean_var_with_update():
ema_apply_op = ema.apply([batch_mean, batch_var])
with tf.control_dependencies([ema_apply_op]):
return tf.identity(batch_mean), tf.identity(batch_var)
mean, var = tf.cond(train_phase, mean_var_with_update,
lambda: (ema.average(batch_mean), ema.average(batch_var)))
normed = tf.nn.batch_normalization(x, mean, var, beta, gamma, 1e-3)
return normed
#==============================================================================
# RNN Structure
#==============================================================================
class LSTMRNN():
#initial setting
def __init__(self, n_steps, input_size, output_size, cell_size, h1_size, h2_size, h3_size, LR,num_size, batch_size):
self.n_steps = n_steps
self.input_size = input_size
self.output_size = output_size
self.cell_size = cell_size
self.num_size = num_size
self.h1_size = h1_size
self.h2_size = h2_size
self.h3_size = h3_size
self.batch_size = batch_size
self.LR = LR
self.num_size = num_size
with tf.name_scope('inputs'):
self.xs = tf.placeholder(tf.float32, [None, n_steps, input_size], name='xs')
self.ys = tf.placeholder(tf.float32, [None, output_size], name='ys')
self.keep_prob = tf.placeholder(tf.float32, name='keep_prob')
self.train_phase = tf.placeholder(tf.bool, name='train_phase')
with tf.name_scope('in_hidden'):
self.add_input_layer()
with tf.name_scope('LSTM_Cell'):
self.add_cell_layer()
with tf.name_scope('hidden_1'):
self.add_h1_layer()
with tf.name_scope('hidden_2'):
self.add_h2_layer()
with tf.name_scope('hidden_3'):
self.add_h3_layer()
with tf.name_scope('out_hidden'):
self.add_output_layer()
with tf.name_scope('cost'):
self.compute_cost()
with tf.name_scope('train'):
self.train_op = tf.train.AdamOptimizer(learning_rate=self.LR).minimize(self.cost)
def add_input_layer(self):
with tf.name_scope('input_layer'):
l_in_x = tf.reshape(self.xs,[-1,self.input_size], name='x_input')
Ws_in = tf.Variable(tf.truncated_normal([self.input_size, self.cell_size], mean=1, stddev=0.5))
bs_in = tf.Variable(tf.zeros([self.cell_size,])+0.01)
l_in_y = tf.matmul(l_in_x,Ws_in)+bs_in
self.l_in_y = tf.reshape(l_in_y,[-1,self.n_steps,self.cell_size],name='cell_input')
def add_cell_layer(self):
with tf.name_scope('LSTM_layer'):
lstm_cell = tf.contrib.rnn.DropoutWrapper(tf.contrib.rnn.BasicLSTMCell(self.cell_size, forget_bias=1.0, state_is_tuple=True), output_keep_prob=self.keep_prob)
lstm_cells = tf.contrib.rnn.MultiRNNCell([lstm_cell]*self.num_size, state_is_tuple=True)
self.cells_init_state = lstm_cells.zero_state(self.batch_size,dtype=tf.float32)
self.cells_outputs, self.cells_final_state = tf.nn.dynamic_rnn(lstm_cells, self.l_in_y, initial_state=self.cells_init_state, time_major=False)
def add_h1_layer(self):
with tf.name_scope('h1_layer'):
h1_x = tf.reshape(self.cells_outputs, [-1,self.cell_size])
Ws_h1 = tf.Variable(tf.truncated_normal([self.cell_size, self.h1_size], mean=3, stddev=1))
bs_h1 = tf.Variable(tf.zeros([self.h1_size,])+0.01)
non_bn_h1 = tf.matmul(h1_x,Ws_h1)+bs_h1
self.h1_y = batch_norm_layer(non_bn_h1, train_phase=self.train_phase, scope_bn='bn_h1')
def add_h2_layer(self):
with tf.name_scope('h2_layer'):
h2_x = tf.reshape(self.h1_y, [-1,self.h1_size])
Ws_h2 = tf.Variable(tf.truncated_normal([self.h1_size, self.h2_size], mean=3, stddev=2))
bs_h2 = tf.Variable(tf.zeros([self.h2_size,])+0.01)
non_bn_h2 = tf.matmul(h2_x,Ws_h2)+bs_h2
self.h2_y = batch_norm_layer(non_bn_h2, train_phase=self.train_phase, scope_bn='bn_h2')
def add_h3_layer(self):
with tf.name_scope('h3_layer'):
h3_x = tf.reshape(self.h2_y, [-1,self.h2_size])
Ws_h3 = tf.Variable(tf.truncated_normal([self.h2_size, self.h3_size], mean=3, stddev=2))
bs_h3 = tf.Variable(tf.zeros([self.h3_size,])+0.01)
non_bn_h3 = tf.matmul(h3_x,Ws_h3)+bs_h3
self.h3_y = batch_norm_layer(non_bn_h3, train_phase=self.train_phase, scope_bn='bn_h3')
def add_output_layer(self):
with tf.name_scope('output_layer'):
l_out_x = tf.reshape(self.h3_y,[-1,self.h3_size],name = 'y_input')
Ws_out = tf.Variable(tf.truncated_normal([self.h3_size, self.output_size], mean=3, stddev=1))
bs_out = tf.Variable(tf.zeros([self.output_size,]))
self.pred = tf.nn.relu(tf.matmul(l_out_x,Ws_out)+bs_out)
def compute_cost(self):
#self.cost = -tf.reduce_sum(self.ys*tf.log(self.pred+0.001)+0.3*(1-self.ys)*tf.log(1-self.pred+0.001))
#重新定义回归的loss
self.cost = tf.sqrt(tf.reduce_mean(tf.square(tf.subtract(self.pred, self.ys))))
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Python
1
https://gitee.com/phonelive/TianChi_DaoLuTongXingShiJianYuCeLSTM.git
git@gitee.com:phonelive/TianChi_DaoLuTongXingShiJianYuCeLSTM.git
phonelive
TianChi_DaoLuTongXingShiJianYuCeLSTM
天池_道路通行时间预测LSTM
master

搜索帮助