使用Python语言,用最简单的线性回归预测高考录取人数

2023-11-26 02:40

本文主要是介绍使用Python语言,用最简单的线性回归预测高考录取人数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 摘要
  • 相关数据
  • 线性回归模型预测
    • 1. 使用上一年的录取数预测下一年
    • 2. 使用当年的参加考试人数来预测录取人数
    • 3. 参加考试人数和时间的因素相结合
  • 展示

摘要

本文收集了2000年到2023年的高考参加考试人数以及2000年到2022年的高考录取人数,尝试通过这些数据使用最简单的线性回归来预测高考录取人数。

相关数据

年份参加考试人数/万录取人数/万
2000375.0221.0
2001454.0268.0
2002510.0320.0
2003613.0382.0
2004729.0447.0
2005877.0504.0
2006950.0546.0
20071010.0566.0
20081050.0599.0
20091020.0629.0
2010946.0657.0
2011933.0675.0
2012915.0685.0
2013912.0684.0
2014939.0697.0
2015942.0700.0
2016940.0705.0
2017940.0700.0
2018975.0790.99
20191031.0820.0
20201071.0856.0
20211078.01001.32
20221193.01014.53
20231291.0

以列表形式给出数据结构:

[375.0, 454.0, 510.0, 613.0, 729.0, 877.0, 950.0, 1010.0, 1050.0, 1020.0, 946.0, 933.0, 915.0, 912.0, 939.0, 942.0, 940.0, 940.0, 975.0, 1031.0, 1071.0, 1078.0, 1193.0, 1291.0]
[221.0, 268.0, 320.0, 382.0, 447.0, 504.0, 546.0, 566.0, 599.0, 629.0, 657.0, 675.0, 685.0, 684.0, 697.0, 700.0, 705.0, 700.0, 790.99, 820.0, 856.0, 1001.32, 1014.53]

线性回归模型预测

1. 使用上一年的录取数预测下一年

仅仅考虑每年的录取人数,忽略参考人数的影响,使用上一年的录取数预测下一年。

import numpy as np
import matplotlib.pyplot as plt
from pandas import DataFrame
from sklearn.linear_model import LinearRegression# 定义高考参考人数
x1 = np.array([375.0, 454.0, 510.0, 613.0, 729.0, 877.0, 950.0, 1010.0, 1050.0, 1020.0, 946.0, 933.0, 915.0, 912.0, 939.0, 942.0, 940.0, 940.0, 975.0, 1031.0, 1071.0, 1078.0, 1193.0, 1291.0]).reshape(-1, 1)# 定义高考录取人数
x2 = np.array([221.0, 268.0, 320.0, 382.0, 447.0, 504.0, 546.0, 566.0, 599.0, 629.0, 657.0, 675.0, 685.0, 684.0, 697.0, 700.0, 705.0, 700.0, 790.99, 820.0, 856.0, 1001.32, 1014.53]).reshape(-1, 1)# 创建线性回归模型对象
model = LinearRegression()# 训练模型
model.fit(x2[:-1], x2[1:])# 预测第二组数据的最后一个数据
last_x2 = np.array([[x2[-1][0]]])
last_y2 = model.predict(last_x2)
# 设置图表中中文字体正常显示
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
plt.scatter(range(len(x1)), [i[0] for i in x1], label='参加高考人数')
plt.scatter(range(len(x2)), [i[0] for i in x2], label='高考录取人数')
plt.scatter(23, last_y2[0][0], label='预测录取人数')
plt.plot(range(1,len(x1)), [i[0] for i in model.predict(x2)], label='拟合结果')
plt.legend()
plt.text(23-0.5, last_y2[0][0]+20, int(last_y2[0][0]))
plt.savefig('预测1.jpg')
plt.show()
print("预测值为:", last_y2[0][0])

运行结果:
在这里插入图片描述
得出的预测结果是1039。
这种尝试显然不合适,因为忽略了参加考试人数的影响。

2. 使用当年的参加考试人数来预测录取人数

import numpy as np
import matplotlib.pyplot as plt
from pandas import DataFrame
from sklearn.linear_model import LinearRegression# 定义第一组数据
x1 = np.array([375.0, 454.0, 510.0, 613.0, 729.0, 877.0, 950.0, 1010.0, 1050.0, 1020.0, 946.0, 933.0, 915.0, 912.0, 939.0, 942.0, 940.0, 940.0, 975.0, 1031.0, 1071.0, 1078.0, 1193.0, 1291.0]).reshape(-1, 1)# 定义第二组数据
x2 = np.array([221.0, 268.0, 320.0, 382.0, 447.0, 504.0, 546.0, 566.0, 599.0, 629.0, 657.0, 675.0, 685.0, 684.0, 697.0, 700.0, 705.0, 700.0, 790.99, 820.0, 856.0, 1001.32, 1014.53]).reshape(-1, 1)# 创建线性回归模型对象
model = LinearRegression()# 训练模型
model.fit(x1[:-1], x2)# 预测第二组数据的最后一个数据
last_x2 = np.array([[x1[-1][0]]])
last_y2 = model.predict(last_x2)
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
plt.scatter(range(len(x1)), [i[0] for i in x1], label='参加高考人数')
plt.scatter(range(len(x2)), [i[0] for i in x2], label='高考录取人数')
plt.scatter(23, last_y2[0][0], label='预测录取人数')
plt.plot(range(len(x1)), [i[0] for i in model.predict(x1)], label='拟合结果')
plt.legend()
plt.text(23-0.5, last_y2[0][0]+20, int(last_y2[0][0]))
plt.savefig('预测2.jpg')
plt.show()
print("预测值为:", last_y2[0][0])

运行结果:
在这里插入图片描述
得出的预测结果是986。
发现受单变量影响太大,拟合效果不好。

3. 参加考试人数和时间的因素相结合

尝试将参加考试人数和时间的因素相结合,同时进行标准化,消除量纲的影响。

import numpy as np
import matplotlib.pyplot as plt
from pandas import DataFrame
from sklearn.linear_model import LinearRegression# 定义第一组数据
x1 = np.array([375.0, 454.0, 510.0, 613.0, 729.0, 877.0, 950.0, 1010.0, 1050.0, 1020.0, 946.0, 933.0, 915.0, 912.0, 939.0, 942.0, 940.0, 940.0, 975.0, 1031.0, 1071.0, 1078.0, 1193.0, 1291.0]).reshape(-1, 1)
x1 = [[x1[i][0]/50, (i+1)] for i in range(len(x1))] # 数据除以50是为了进行标准化# 定义第二组数据
x2 = np.array([221.0, 268.0, 320.0, 382.0, 447.0, 504.0, 546.0, 566.0, 599.0, 629.0, 657.0, 675.0, 685.0, 684.0, 697.0, 700.0, 705.0, 700.0, 790.99, 820.0, 856.0, 1001.32, 1014.53]).reshape(-1, 1)
x2 = [[x2[i][0]/50] for i in range(len(x2))] # 数据除以50是为了进行标准化# 创建线性回归模型对象
model = LinearRegression()# 训练模型
model.fit(x1[:-1], x2)# 预测第二组数据的最后一个数据
last_x2 = np.array([[1291.0/50, 24]]) # 数据除以50是为了进行标准化
last_y2 = model.predict(last_x2)
plt.scatter(range(len(x1)), [i[0]*50 for i in x1], label='参加高考人数')
plt.scatter(range(len(x2)), [i[0]*50 for i in x2], label='高考录取人数')
plt.scatter(23, last_y2[0][0]*50, label='预测录取人数')
plt.plot(range(len(x1)), [i[0]*50 for i in model.predict(x1)], label='拟合结果')
plt.text(23-0.5, last_y2[0][0]*50+20, int(last_y2[0][0]*50))
plt.savefig('预测3.jpg')
plt.show()
print("预测值为:", last_y2[0][0]*50)

运行结果:
在这里插入图片描述
得出预测结果是1020。
拟合相对较好,且综合了参考人数以及时间的因素,预测结果相对可信。

展示

将所有数据绘制在一张图表中,便于展示。

import numpy as np
import matplotlib.pyplot as plt
from pandas import DataFrame
from sklearn.linear_model import LinearRegressiondata = DataFrame()
data['年份'] = range(2000, 2024)
data['参考人数'] = [375.0, 454.0, 510.0, 613.0, 729.0, 877.0, 950.0, 1010.0, 1050.0, 1020.0, 946.0, 933.0, 915.0, 912.0, 939.0, 942.0, 940.0, 940.0, 975.0, 1031.0, 1071.0, 1078.0, 1193.0, 1291.0]a = [221.0, 268.0, 320.0, 382.0, 447.0, 504.0, 546.0, 566.0, 599.0, 629.0, 657.0, 675.0, 685.0, 684.0, 697.0, 700.0, 705.0, 700.0, 790.99, 820.0, 856.0, 1001.32, 1014.53]
a.append(1020.4566124819598) # 加入预测结果
data['录取人数'] = a
data['录取人数'] = [float(i) for i in data['录取人数']]
data['参考人数'] = [float(i) for i in data['参考人数']]plt.xticks(rotation=45)
plt.title('高考数据折线图')
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
plt.xlabel('年份')
plt.ylabel('人数/万')
plt.plot(data['年份'], data['参考人数'], marker='o', markersize=3, label='参加高考人数')
for i, j in zip(data['年份'][1::2], data['参考人数'][1::2]):plt.text(i-0.5, j+20, int(j))
plt.plot(data['年份'][:-1], data['录取人数'][:-1], 'x-', markersize=3, label='高考录取人数')
plt.plot(data['年份'][-2:], data['录取人数'][-2:], 'x--', markersize=3, label='预测录取人数')
for i, j in zip(data['年份'][1::2], data['录取人数'][1::2]):plt.text(i-0.5, j+20, int(j))plt.legend()
plt.savefig('高考数据折线图.jpg')
plt.show()

运行结果:
在这里插入图片描述

这篇关于使用Python语言,用最简单的线性回归预测高考录取人数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/425001

相关文章

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁