锋盈数科-知识库 Logo
首页
软件开发
计算机基础
Hello Halo
新手必读
关于本知识库
登录 →
锋盈数科-知识库 Logo
首页 软件开发 计算机基础 Hello Halo 新手必读 关于本知识库
登录
  1. 首页
  2. 软件开发
  3. python
  4. BP神经网络及其Python和MATLAB实现预测

BP神经网络及其Python和MATLAB实现预测

0
  • python
  • 发布于 2024-09-27
  • 11 次阅读
黄健
黄健

BP神经网络及其Python和MATLAB实现预测

引言

BP神经网络(Back Propagation Neural Network),即反向传播神经网络,是一种通过反向传播算法进行监督学习的多层前馈网络。这种网络能够通过不断地调整和改变神经元的连接权重,达到对特定任务的学习和优化。由于其高度的灵活性和适应性,BP神经网络在模式识别、函数逼近、优化问题等多个领域有着广泛的应用。本文将详细介绍BP神经网络的基本原理,并通过Python和MATLAB的示例代码展示其在时间序列预测中的应用。

BP神经网络的基本原理

BP神经网络主要由输入层、隐藏层和输出层组成。输入层接收外部信号和数据,隐藏层进行信息处理,输出层产生预测结果。在训练过程中,网络通过前向传播计算输出值,并通过反向传播算法调整权重和偏置,以减小输出误差。

1. 前向传播

在前向传播过程中,输入数据通过输入层进入网络,经过隐藏层处理,最后由输出层输出预测结果。每个神经元接收来自前一层神经元的加权输入,并通过激活函数计算输出。输出层的输出即为网络的预测值。

2. 反向传播

反向传播是BP神经网络的核心算法,用于根据输出误差调整网络的权重和偏置。首先,计算输出层的误差,然后利用误差反向传播到隐藏层,再逐层向前传播,直到输入层。在反向传播过程中,使用梯度下降等优化算法来更新权重和偏置,以减小误差。

Python实现BP神经网络预测

在Python中,我们可以使用Keras库来构建和训练BP神经网络。Keras是一个高层神经网络API,它可以运行在TensorFlow、CNTK或Theano之上,以简化神经网络的构建、训练和评估过程。

示例代码

以下是一个使用Keras库构建简单BP神经网络进行时间序列预测的示例代码。

import numpy as np
import matplotlib.pyplot as plt
from keras.models import Sequential
from keras.layers import Dense
from sklearn.model_selection import train_test_split

# 随机生成模拟数据
np.random.seed(42)
input_dim = 1
output_dim = 1
X = np.random.rand(1000, input_dim)
y = 3 * X ** 2 + 0.5 * np.sin(2 * np.pi * X)

# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 创建Sequential模型
model = Sequential()
model.add(Dense(64, activation='relu', input_shape=(input_dim,)))
model.add(Dense(32, activation='relu'))
model.add(Dense(output_dim, activation='linear'))

# 编译模型
model.compile(loss='mean_squared_error', optimizer='adam')

# 训练模型
history = model.fit(X_train, y_train, epochs=100, batch_size=32, validation_split=0.2)

# 使用模型进行预测
predictions = model.predict(X_test)

# 可视化预测结果与实际值对比
plt.figure(figsize=(10, 6))
plt.scatter(range(1, len(y_test) + 1), y_test, color='blue', linewidth=1, label='Actual Values')
plt.plot(range(1, len(y_test) + 1), predictions, color='red', linewidth=1, label='Predictions')
plt.xlabel('Input Feature')
plt.ylabel('Output Feature')
plt.legend()
plt.title('Actual vs Predicted Values')
plt.savefig('plot.png')

# 计算并打印RMSE
from sklearn.metrics import mean_squared_error
rmse = np.sqrt(mean_squared_error(y_test, predictions))
print(f"Root Mean Squared Error (RMSE): {
     rmse:.2f}")

在这个示例中,我们首先生成了一些非线性相关的数据,并将其划分为训练集和测试集。然后,我们构建了一个包含两个隐藏层的BP神经网络,并使用均方误差作为损失函数和Adam优化器来训练模型。最后,我们使用训练好的模型对测试集进行预测,并可视化预测结果与实际值的对比。

MATLAB实现BP神经网络预测

MATLAB是一个广泛应用于数学、工程和科学计算的商业数学软件,内置了大量用于神经网络设计的工具箱,使得在MATLAB中实现BP神经网络变得相对容易。

示例代码

以下是一个使用MATLAB的Neural Network Toolbox来构建和训练BP神经网络进行时间序列预测的示例代码。

% 清理环境
clear; clc; close all;

% 随机生成模拟数据
rng(42); % 设置随机数生成器种子
input_dim = 1;
output_dim = 1;
X = rand(1000, input_dim);
y = 3 * X.^2 + 0.5 * sin(2 * pi * X);

% 划分训练集和测试集
cv = cvpartition(size(X, 1), 'HoldOut', 0.2);
idxTrain = training(cv);
idxTest = test(cv);
X_train = X(idxTrain, :);
y_train = y(idxTrain);
X_test = X(idxTest, :);
y_test = y(idxTest);

% 创建BP神经网络
net = feedforwardnet(10); % 创建一个具有10个神经元的隐藏层的网络

% 配置训练参数
net.trainFcn = 'trainlm'; % 使用Levenberg-Marquardt优化算法
net.divideParam.trainRatio = 70/100;
net.divideParam.valRatio = 15/100;
net.divideParam.testRatio = 15/100;

% 训练网络
[net, tr] = train(net, X_train', y_train'); % 注意MATLAB要求输入是列向量

% 使用训练好的网络进行预测
y_pred = net(X_test');

% 可视化预测结果与实际值对比
figure;
plot(y_test, 'bo-', 'DisplayName', 'Actual Values');
hold on;
plot(y_pred, 'r*-', 'DisplayName', 'Predictions');
legend show;
xlabel('Sample Index');
ylabel('Output Value');
title('Actual vs Predicted Values');
grid on;

% 计算并打印RMSE
rmse = sqrt(mean((y_pred - y_test).^2));
fprintf('Root Mean Squared Error (RMSE): %.2f\n', rmse);

在这个MATLAB示例中,我们首先使用rng函数设置了随机数生成器的种子,以确保每次运行代码时生成的数据相同。然后,我们生成了一些模拟数据,并将其划分为训练集和测试集。接着,我们使用feedforwardnet函数创建了一个具有单个隐藏层的BP神经网络,该隐藏层包含10个神经元。之后,我们设置了网络的训练函数为Levenberg-Marquardt优化算法,并配置了训练参数。

在训练网络时,我们使用了train函数,并注意到MATLAB要求输入数据是列向量,因此我们对X_train和y_train进行了转置。训练完成后,我们使用训练好的网络对测试集进行了预测,并将预测结果与实际值进行了可视化对比。最后,我们计算了预测结果的均方根误差(RMSE),并将其打印到控制台。

通过这个MATLAB示例,我们可以看到使用MATLAB的Neural Network Toolbox来构建和训练BP神经网络进行时间序列预测是相对直观和简单的。这个工具箱提供了丰富的函数和工具来支持神经网络的设计、训练和评估,使得用户可以轻松地实现复杂的神经网络模型。

原文链接: https://blog.csdn.net/hai40587/article/details/140747034

标签: #Python 23
相关文章

XGBOOST算法Python实现(保姆级) 2024-09-29 16:36

摘要 XGBoost算法(eXtreme Gradient Boosting)在目前的Kaggle、数学建模和大数据应用等竞赛中非常流行。本文将会从XGBOOST算法原理、Python实现、敏感性分析和实际应用进行详细说明。 目录 0 绪论 一、材料准备 二、算法原理 三、算法Python实现

Python 神器:wxauto 库——解锁微信自动化的无限可能 2024-09-29 11:21

📝个人主页🌹:誓则盟约 ⏩收录专栏⏪:机器学习 🤡往期回顾🤡:“探索机器学习的多面世界:从理论到应用与未来展望” 🌹🌹期待您的关注 🌹🌹

【python】python代码打包工具cx_Freeze的介绍、原理、用法及实战案例分析 2024-09-29 11:21

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦\~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,PyQt5和Tk

python基础 --- 爬虫前篇 2024-09-29 11:21

python 文章目录 python 变量 * 变量类型 输出 运行程序 ctrl+shift+f10 命名规范:字母,数字,下划线 开头不能是数字 注释: ctrl+? 字典 键key:值value * 修改字典的信息 字典添加一个键值对

NumPy的基本特性 2024-09-26 17:57

NumPy作为Python中用于科学计算的基础库,不仅提供了强大的多维数组对象,还包含了一系列用于操作这些数组的函数和工具。它极大地简化了数组操作,提高了数据处理的效率和灵活性,是数据科学、机器学习、图像处理等领域不可或缺的工具。以下是对NumPy的深入探索,包括其基本特性、高级功能、应用场景以及性

网络自动化:利用Python和Ansible实现网络配置管理 2024-09-26 17:57

网络自动化:利用Python和Ansible实现网络配置管理 在当今快速变化的IT环境中,网络自动化已成为提升运维效率、减少人为错误、加速服务交付的关键技术之一。Python和Ansible作为两种强大的工具,在网络配置管理中发挥着重要作用。本文将深入探讨如何利用Python和Ansible实现网络

目录

IT 外包服务商

  • 意见投递
  • zyf6619

软件开发应用

主菜单

  • 首页
  • 软件开发
  • 计算机基础
  • Hello Halo
  • 新手必读
  • 关于本知识库
Copyright © 2024 your company All Rights Reserved. Powered by Halo.