文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python中如何进行基于BP神经网络的预测

2023-06-26 07:13

关注

今天就跟大家聊聊有关Python中如何进行基于BP神经网络的预测,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

一、Introduction

1 BP神经网络的优点

2 BP神经网络的缺点

二、实现过程

1 Demo

#%% 基础数组运算库导入import numpy as np # 画图库导入import matplotlib.pyplot as plt # 导入三维显示工具from mpl_toolkits.mplot3d import Axes3D# 导入BP模型from sklearn.neural_network import MLPClassifier# 导入demo数据制作方法from sklearn.datasets import make_classificationfrom sklearn.metrics import classification_report, confusion_matriximport seaborn as snsimport warningsfrom sklearn.exceptions import ConvergenceWarning#%%模型训练# 制作五个类别的数据,每个类别1000个样本train_samples, train_labels = make_classification(n_samples=1000, n_features=3,                            n_redundant=0,n_classes=5, n_informative=3,                            n_clusters_per_class=1,class_sep=3, random_state=10)# 将五个类别的数据进行三维显示fig = plt.figure()ax = Axes3D(fig, rect=[0, 0, 1, 1], elev=20, azim=20)ax.scatter(train_samples[:, 0], train_samples[:, 1], train_samples[:, 2], marker='o', c=train_labels)plt.title('Demo Data Map')

Python中如何进行基于BP神经网络的预测

#%% 建立 BP 模型, 采用sgd优化器,relu非线性映射函数BP = MLPClassifier(solver='sgd',activation = 'relu',max_iter = 500,alpha = 1e-3,                   hidden_layer_sizes = (32,32),random_state = 1)# 进行模型训练with warnings.catch_warnings():    warnings.filterwarnings("ignore", category=ConvergenceWarning,                            module="sklearn")    BP.fit(train_samples, train_labels)# 查看 BP 模型的参数print(BP)#%% 进行模型预测predict_labels = BP.predict(train_samples)# 显示预测的散点图fig = plt.figure()ax = Axes3D(fig, rect=[0, 0, 1, 1], elev=20, azim=20)ax.scatter(train_samples[:, 0], train_samples[:, 1], train_samples[:, 2], marker='o', c=predict_labels)plt.title('Demo Data Predict Map with BP Model')# 显示预测分数print("预测准确率: {:.4f}".format(BP.score(train_samples, train_labels)))# 可视化预测数据 print("真实类别:", train_labels[:10])print("预测类别:", predict_labels[:10])# 准确率等报表print(classification_report(train_labels, predict_labels))# 计算混淆矩阵classes = [0, 1, 2, 3]cofusion_mat = confusion_matrix(train_labels, predict_labels, classes) sns.set()figur, ax = plt.subplots()# 画热力图sns.heatmap(cofusion_mat, cmap="YlGnBu_r", annot=True, ax=ax) ax.set_title('confusion matrix')  # ax.set_xticklabels([''] + classes, minor=True)ax.set_yticklabels([''] + classes, minor=True)ax.set_xlabel('predict')  # x轴ax.set_ylabel('true')  # y轴plt.show()

Python中如何进行基于BP神经网络的预测

Python中如何进行基于BP神经网络的预测

Python中如何进行基于BP神经网络的预测

#%%# 进行新的测试数据测试test_sample = np.array([[-1, 0.1, 0.1]])print(f"{test_sample} 类别是: ", BP.predict(test_sample))print(f"{test_sample} 类别概率分别是: ", BP.predict_proba(test_sample))test_sample = np.array([[-1.2, 10, -91]])print(f"{test_sample} 类别是: ", BP.predict(test_sample))print(f"{test_sample} 类别概率分别是: ", BP.predict_proba(test_sample))test_sample = np.array([[-12, -0.1, -0.1]])print(f"{test_sample} 类别是: ", BP.predict(test_sample))print(f"{test_sample} 类别概率分别是: ", BP.predict_proba(test_sample))test_sample = np.array([[100, -90.1, -9.1]])print(f"{test_sample} 类别是: ", BP.predict(test_sample))print(f"{test_sample} 类别概率分别是: ", BP.predict_proba(test_sample))

Python中如何进行基于BP神经网络的预测

2 基于BP神经网络的乳腺癌分类预测

#%%基于BP神经网络的乳腺癌分类#基本库导入# 导入乳腺癌数据集from sklearn.datasets import load_breast_cancer# 导入BP模型from sklearn.neural_network import MLPClassifier# 导入训练集分割方法from sklearn.model_selection import train_test_split # 导入预测指标计算函数和混淆矩阵计算函数from sklearn.metrics import classification_report, confusion_matrix# 导入绘图包import seaborn as snsimport matplotlib.pyplot as plt# 导入三维显示工具from mpl_toolkits.mplot3d import Axes3D# 导入乳腺癌数据集cancer = load_breast_cancer()# 查看数据集信息print('breast_cancer数据集的长度为:',len(cancer))print('breast_cancer数据集的类型为:',type(cancer))# 分割数据为训练集和测试集cancer_data = cancer['data']print('cancer_data数据维度为:',cancer_data.shape)cancer_target = cancer['target']print('cancer_target标签维度为:',cancer_target.shape)cancer_names = cancer['feature_names']cancer_desc = cancer['DESCR']#分为训练集与测试集cancer_data_train,cancer_data_test = train_test_split(cancer_data,test_size=0.2,random_state=42)#训练集cancer_target_train,cancer_target_test = train_test_split(cancer_target,test_size=0.2,random_state=42)#测试集

Python中如何进行基于BP神经网络的预测

#%%# 建立 BP 模型, 采用Adam优化器,relu非线性映射函数BP = MLPClassifier(solver='adam',activation = 'relu',max_iter = 1000,alpha = 1e-3,hidden_layer_sizes = (64,32, 32),random_state = 1)# 进行模型训练BP.fit(cancer_data_train, cancer_target_train)#%% 进行模型预测predict_train_labels = BP.predict(cancer_data_train)# 可视化真实数据fig = plt.figure()ax = Axes3D(fig, rect=[0, 0, 1, 1], elev=20, azim=20) ax.scatter(cancer_data_train[:, 0], cancer_data_train[:, 1], cancer_data_train[:, 2], marker='o', c=cancer_target_train)plt.title('True Label Map')plt.show()# 可视化预测数据fig = plt.figure()ax = Axes3D(fig, rect=[0, 0, 1, 1], elev=20, azim=20) ax.scatter(cancer_data_train[:, 0], cancer_data_train[:, 1], cancer_data_train[:, 2], marker='o', c=predict_train_labels)plt.title('Cancer with BP Model')plt.show()

Python中如何进行基于BP神经网络的预测

#%% 显示预测分数print("预测准确率: {:.4f}".format(BP.score(cancer_data_test, cancer_target_test)))# 进行测试集数据的类别预测predict_test_labels = BP.predict(cancer_data_test)print("测试集的真实标签:\n", cancer_target_test)print("测试集的预测标签:\n", predict_test_labels)#%% 进行预测结果指标统计 统计每一类别的预测准确率、召回率、F1分数print(classification_report(cancer_target_test, predict_test_labels))

Python中如何进行基于BP神经网络的预测

#%% 计算混淆矩阵confusion_mat = confusion_matrix(cancer_target_test, predict_test_labels)# 打印混淆矩阵print(confusion_mat)# 将混淆矩阵以热力图的方式显示sns.set()figure, ax = plt.subplots()# 画热力图sns.heatmap(confusion_mat, cmap="YlGnBu_r", annot=True, ax=ax)  #  ax.set_title('confusion matrix')# x轴为预测类别ax.set_xlabel('predict')  # y轴实际类别ax.set_ylabel('true')  plt.show()

Python中如何进行基于BP神经网络的预测

注:之前还做过基于BP神经网络的人口普查数据预测,有需要的猿友私信

三、Keys

BP神经网络的要点在于前向传播和误差反向传播,来对参数进行更新,使得损失最小化。

它是一个迭代算法,基本思想是:

Python的优点有哪些

1、简单易用,与C/C++、Java、C# 等传统语言相比,Python对代码格式的要求没有那么严格;2、Python属于开源的,所有人都可以看到源代码,并且可以被移植在许多平台上使用;3、Python面向对象,能够支持面向过程编程,也支持面向对象编程;4、Python是一种解释性语言,Python写的程序不需要编译成二进制代码,可以直接从源代码运行程序;5、Python功能强大,拥有的模块众多,基本能够实现所有的常见功能。

看完上述内容,你们对Python中如何进行基于BP神经网络的预测有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网行业资讯频道,感谢大家的支持。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯