多元线性回归
时间:2023-04-27
本文章向大家介绍多元线性回归,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
1 绪 论
2 预备知识
2.1 多元线性回归分析法基本思想
2.2 多元线性回归分析法的理论模型
2.3 多元线性回归分析的计算步骤
2.3.1 参数估计
2.3.2 假设检验
2.4 Python语言操作步骤
3 多元线性回归模型的建立与分析
3.1 数据收集与分析
3.2 模型构建
3.3 计算及结果分析
3.3.1 模型求解
3.3.2 单特征与目标的可视化
3.3.3 模型结果分析
3.3.4 相关系数检验
3.3.5 多重共线性检验
3.3.6 回归系数的显著性检验
3.3.7 模型验证
4 模型的评价
4.1 模型的优点
4.2 模型的缺点
4.3 模型的改进
5 结论与建议
参考文献:……
参考论文:
链接:https://pan.baidu.com/s/1vxPAtjoNM1V86oap9KihwA
提取码:1573
1 import pandas as pd 2 import numpy as np 3 import matplotlib.pyplot as plt 4 from sklearn.model_selection import train_test_split 5 from sklearn.model_selection import cross_val_score #导入交叉验证模块 6 from statsmodels.formula.api import ols #线性回归模型,小写的 ols 函数才会自带截距项,OLS 则不会 7 import seaborn as sns 8 plt.rcParams['font.sans-serif'] = ['SimHei'] 9 plt.rcParams['axes.unicode_minus'] = False 10 11 class Multiple_linear_regression(): 12 def __init__(self,path): 13 try: 14 self.df = pd.read_csv(path) 15 except: 16 self.df=pd.read_excel(path) 17 print(self.df.head()) 18 19 def Single_factor_scatter_plot(self): 20 for i in self.df: 21 if i==self.df.iloc[:,-1].name: 22 continue 23 else: 24 self.df.plot(x=i, y=self.df.iloc[:,-1].name, kind='scatter', title=f'因素{i}与{self.df.iloc[:,-1].name}的散点图') 25 plt.show() 26 27 def Correlation_coefficient_matrix_and_thermodynamic_diagram(self): 28 # df.corr().to_csv('相关系数矩阵.csv') 29 print(self.df.corr()) 30 heatmap = sns.heatmap(self.df.corr(), cmap='inferno', center=0.01) 31 plt.show() 32 33 def Vif_test(self): 34 # 共线性检测,vif检验,方差膨胀因子 35 def vif(df, col_i): 36 """ 37 df: 整份数据 38 col_i:被检测的列名 39 """ 40 cols = list(df.columns) 41 cols.remove(col_i) 42 cols_noti = cols 43 formula = col_i + '~' + '+'.join(cols_noti) 44 r2 = ols(formula, df).fit().rsquared 45 # 其实就是多元线性回归建模步骤,只是取出了参数 R 平方而已 46 test = 1. / (1. - r2) 47 return test 48 49 print('vif检验结果') 50 print(' 变量 vif检验值') 51 vif_value = [] 52 for i in self.df: 53 print(i.center(7) + ' ', str(vif(df=self.df, col_i=i))) 54 vif_value.append(vif(df=self.df, col_i=i)) 55 plt.bar([x for x in self.df], vif_value, color='teal') 56 plt.axhline(10, color='red', lw=2, label="参考线") 57 plt.title("VIF检验结果") 58 plt.xlabel("变量") 59 plt.ylabel("VIF_value") 60 plt.show() 61 62 def Model(self): 63 st='' 64 for k in self.df: 65 if k == self.df.iloc[:, -1].name: 66 continue 67 else: 68 st += ''.join(k) + '+' 69 xy=f'{self.df.iloc[:, -1].name}~{st[0:-1]}' 70 lm = ols(xy, data=self.df).fit() 71 print(lm.summary())
1 import MLR 2 a=MLR.Multiple_linear_regression(path='house.csv') 3 4 a.Single_factor_scatter_plot() 5 a.Correlation_coefficient_matrix_and_thermodynamic_diagram() 6 a.Vif_test() 7 a.Model()
原文地址:https://www.cnblogs.com/hongbao/p/17360428.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- PHP PDOStatement::nextRowset讲解
- PHP _construct()函数讲解
- PHP PDOStatement::rowCount讲解
- Python 如何对文件目录操作
- Python字符串split及rsplit方法原理详解
- Laravel框架文件上传功能实现方法示例
- python中如何写类
- 什么是PHP7中的孤儿进程与僵尸进程
- Python爬虫小例子——爬取51job发布的工作职位
- 详解PHP素材图片上传、下载功能
- Python enumerate() 函数如何实现索引功能
- python打开文件的方式有哪些
- PHP实现二维数组按照指定的字段进行排序算法示例
- python怎么自定义捕获错误
- Codeforces Round #677 (Div. 3)