取前90%个数据作为训练集 train_num = int(len(data) * 0.90) # 90%-99.8%用于验证 val_num = int(len(data) * 0.998) # 最后1%用于测试 inputs_feature = temp # (5)划分训练集和验证集 # 窗口为20条数据,预测下一时刻 history_size = 20 target_size = 0 # 训练集 x_train, y_train = database(inputs_feature.values, 0, train_num, history_size, target_size) # 验证集 x_val, y_val = database(inputs_feature.values, train_num, val_num, history_size, target_size) # 测试集 x_test, y_test = database(inputs_feature.values, val_num, None, history_size, target_size) # 查看数据信息 print('x_train.shape:', x_train.shape) # x_train.shape: (109125, 20, 1) # (6)构造tf数据集 # 训练集 train_ds = tf.data.Dataset.from_tensor_slices((x_train, y_train)) train_ds = train_ds.shuffle(10000).batch(128) # 验证集 val_ds = tf.data.Dataset.from_tensor_slices((x_val, y_val)) val_ds = val_ds.batch(128) # 查看数据信息 sample = next(iter(train_ds)) print('x_batch.shape:', sample[0].shape, 'y_batch.shape:', sample[1].shape) print('input_shape:', sample[0].shape[-2:]) # x_batch.shape: (128, 20, 1) y_batch.shape: (128,) # input_shape: (20, 1) inputs = keras.Input(shape=sample[0].shape[-2:]) x = keras.layers.LSTM(16, return_sequences=True)(inputs) x = keras.layers.Dropout(0.2)(x) x = keras.layers.LSTM(8)(x) x = keras.layers.Activation('relu')(x) outputs = keras.layers.Dense(1)(x) model = keras.Model(inputs, outputs) model.summary() opt = keras.optimizers.RMSprop(learning_rate=0.001, rho=0.9) model.compile(optimizer=opt, loss='mae', metrics=['mae']) # (9)模型训练 epochs = 100 early_stop = EarlyStopping(monitor='val_loss', patience=5, verbose=1) # 训练模型,并使用 EarlyStopping 回调函数 history = model.fit(train_ds, epochs=epochs, validation_data=val_ds, callbacks=[early_stop]) # (12)预测 y_predict = model.predict(x_test)# 对测试集的特征值进行预测 print(y_predict)具体介绍该模型
时间: 2023-12-06 15:44:01 浏览: 174
这段代码实现了一个基于LSTM的时间序列预测模型。首先,将原始数据集划分为训练集、验证集和测试集,并将其转化为模型可接受的形式。然后,构建了一个包含两个LSTM层的神经网络模型,并使用RMSprop优化器和平均绝对误差(MAE)损失函数进行编译。接着,使用EarlyStopping回调函数来监控验证集上的损失函数值,以便在模型过拟合之前停止训练。最后,使用训练好的模型对测试集进行预测,并输出预测结果。该模型的目标是预测时间序列中下一个时刻的数值。
阅读全文