IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> AI实战:使用LSTM做数值序列预测 -> 正文阅读

[人工智能]AI实战:使用LSTM做数值序列预测

依赖环境

  • python3.x
  • tensorflow 2.x
  • Linux(我用的Ubuntu 18.04LTS)
  • numpy
  • pandas
  • sklearn

核心代码

搭建模型

  • 依赖库
import sys
import os
from tensorflow import keras
from tensorflow.keras.models import Model
import pandas as pd
from sklearn.model_selection import train_test_split
import numpy as np
import tensorflow as tf
from tensorflow.keras import backend as K

#tf2.0
gpus = tf.config.experimental.list_physical_devices(device_type='GPU')
tf.config.experimental.set_virtual_device_configuration(gpus[0],[tf.config.experimental.VirtualDeviceConfiguration(memory_limit=1024*1)])

  • 核心模型代码
    #搭建模型
    model = keras.models.Sequential()
    model.add(keras.layers.GRU(units=256, return_sequences=True, activation='tanh', input_shape=(train_X.shape[1],1)))
    model.add(keras.layers.GRU(units=64, return_sequences=False))
    model.add(keras.layers.Dropout(0.5))
    model.add(keras.layers.Dense(n_forecast, activation='linear'))
    
    model.compile(loss=smape, optimizer=keras.optimizers.Adam())
    model.summary()

注意:
1、这里使用的是GRU,主要是数据量较少,数据量特别大的话建议使用LSTM;
2、隐藏层使用256层,可以根据需要自己定义,建议不要过大或者过小;
3、loss函数选取特别重要,有量纲的话用MAE、MSE、RMSE、Huber Loss(将MSE与MAE结合起来),无量纲的话使用SMAPE、NMB;

  • 整体代码
def rnn_model(data_name, n_input, n_forecast, train_data_path, test_data_path):
    
    
    #数据加载
    X, Y = load_data('train', train_data_path, n_input, n_forecast)
    
	
    #拆分数据集
    train_X, train_Y, valid_X, valid_Y = split_data(X, Y)
    
    
    #搭建模型
    model = keras.models.Sequential()
    model.add(keras.layers.GRU(units=256, return_sequences=True, activation='tanh', input_shape=(train_X.shape[1],1)))
    model.add(keras.layers.GRU(units=64, return_sequences=False))
    model.add(keras.layers.Dropout(0.5))
    model.add(keras.layers.Dense(n_forecast, activation='linear'))
    
    model.compile(loss=smape, optimizer=keras.optimizers.Adam())
    model.summary()
    
    
    #训练模型
    print('training model')
    batch_size = 32
    epochs = 1000
    model_dir = './model_res/'
    model_path = os.path.join(model_dir, 'lstm-%s-%d-%d.h5' %(data_name, n_input, n_forecast))
    callback = keras.callbacks.EarlyStopping(monitor='val_loss', patience=10)
    checkpoint_callback = keras.callbacks.ModelCheckpoint(
                                filepath=model_path,
                                save_weights_only=True,
                                monitor='val_loss',
                                mode='min',
                                save_best_only=True)

    model.fit(x = train_X, 
            y = train_Y, 
            batch_size = batch_size, 
            epochs = epochs, 
            callbacks=[callback, checkpoint_callback], 
            verbose = 2, 
            shuffle = True, 
            validation_data = (valid_X, valid_Y))
    
    
    #测试模型
    test_X, test_Y = load_data('test', test_data_path, n_input, n_forecast)
    y_pred = model.predict(test_X)
    scores = calcu_smape(y_pred, test_Y)
    print('-'*50)
    print('evalate result:')
    print(data_name, 'n_input: %d, n_forecast: %d, %s: %.4f' % (n_input, n_forecast, model.metrics_names, scores))
    

loss函数

def smape(y_true, y_pred):
    return 2.0 * K.mean(K.abs(y_pred - y_true) / (K.abs(y_pred) + K.abs(y_true) + 1e-31)) #* 100

其他辅助函数

def split_data(X, Y):
    
    data_index = [i for i in range(len(X))]

    train_data_index, test_data_index = train_test_split(data_index, test_size=0.2, random_state=2021)
    
    X_train, X_eval = X[train_data_index], X[test_data_index]
    y_train, y_eval = Y[train_data_index], Y[test_data_index]
    
    return X_train, y_train, X_eval, y_eval

模型概览

n_input = 48, n_forecast = 48 时的模型概览:

Layer (type)                 Output Shape              Param #
=================================================================
gru (GRU)                    (None, 432, 256)          198912
_________________________________________________________________
gru_1 (GRU)                  (None, 96)                101952
_________________________________________________________________
dropout (Dropout)            (None, 96)                0
_________________________________________________________________
dense (Dense)                (None, 48)                4656
=================================================================
Total params: 305,520
Trainable params: 305,520
Non-trainable params: 0

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-05-09 12:39:40  更:2022-05-09 12:45:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 15:54:02-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码