根据成绩预测大学生能否被高校录取

github源码和数据下载

1、首先,导入库,并且读取数据集。原来数据集是 .txt 结尾的。
    由于原始数据中并没有给出每一列的列的名字,所以,我们自己加一个 “Exam 1”、"“Exam 2”、“Admitted”,我们最好列举前几行数据,确认一下是否读入了数据,并且,看一下数据的维度:

import numpy as np
import pandas as pd
import matplotlib.pyplot as pltimport os# 路径
path = 'LogiReg_data.txt'
# 原文件没有表头,加一个表头:'Exam1','Exam2','Admitted'
pdData = pd.read_csv(path, header=None, names=['Exam 1', 'Exam 2', 'Admitted'])
# 输出读取数据
print(pdData)
pdData.head()
pdData.shape
结果:
在这里插入图片描述

2.将数据分成正负样本,利用散点图,大致看一下数据分布(不是必要步骤,而且因为数据只有两个维度,才添加了此步骤)

# 录取
positive = pdData[pdData['Admitted'] == 1]
# 未录取
negative = pdData[pdData['Admitted'] == 0]# fig表示窗口,ax表示坐标轴
fig, ax = plt.subplots(figsize=(10, 5))
# 散布点,c='b'表示蓝色。 marker='x'表示标记  label左为左上角的标签
ax.scatter(positive['Exam 1'], positive['Exam 2'], s=30, c='b', marker='o', label='Admitted')
ax.scatter(negative['Exam 1'], negative['Exam 2'], s=30, c='r', marker='x', label='Not Admitted')
ax.legend()
ax.set_xlabel('Exam 1 Score')
ax.set_ylabel('Exam 2 Score')# 绘图
plt.show()
绘图结果:
在这里插入图片描述
补充说明一下:Admitted 是标签,当标签为 1 时,认为是正样本;标签为 0 时,认为是负样本。而 pd Data[‘Admitted’] == 1,是一堆 True 和 false

3、逻辑回归
此部分,我们主要建立一个分类器:也就是求解 theta 值。然后设定阈值,根据阈值,判断是否被录取。
主要步骤如下:

(1)、定义 sigmoid 函数

# 定义sigmoid函数
def sigmoid(z):return 1 / (1 + np.exp(-z))

sigmoid 函数是将预测值(比如线性回归中的结果),映射为概率的一个函数。形式为:
在这里插入图片描述

# creates a vector containing 20 equally spaced values from -10 to 10
nums = np.arange(-10, 10, step=1)
fig, ax = plt.subplots(figsize=(12, 4))
ax.plot(nums, sigmoid(nums), 'r')
# 绘图
plt.show()

其中,自变量 z 为任意值,而 g(z) 的值域为 (0,1),(0,1)也就是对应着概率的大小。曲线图如下
在这里插入图片描述

(2)定义模型,也就是预测函数

# 定义模型函数
# X 是样本数据,它的每一行都是一个样本,每一列为样本的某一个特征。
# theta 表示参数,它是我们通过学习获得的,其中,对于每一个特征,都对应一个 theta
def model(X, theta):return sigmoid(np.dot(X, theta.T))

在这里插入图片描述
将 sigmoid () 函数的自变量 z 变成上式。其中,X 是样本数据,它的每一行都是一个样本,每一列为样本的某一个特征。theta 表示参数,它是我们通过学习获得的,其中,对于每一个特征,都对应一个 theta ,即
在这里插入图片描述
其中,为偏置项,因此,要在原始数据上补上一列,值为 1 ,是为了形式上的统一,方便矩阵运算,

# 在第 0 列,插入一列,名称为"Onces",数值全为 1
pdData.insert(0, 'Onces', 1)
# X:训练数据   Y:目标值
# 将数据的panda表示形式转换为对进一步计算有用的数组
# 这个方法过时会有警告
orig_data = pdData.as_matrix()
cols = orig_data.shape[1]
X = orig_data[:, 0:cols - 1]
y = orig_data[:, cols - 1:cols]
# 初始化theta
theta = np.zeros([1, 3])X.shape, y.shape, theta.shape

(3) 定义损失函数

损失函数是将对数似然函数,乘以一个负号。乘以负号是为了将求解梯度上升转换为求解梯度下降
在这里插入图片描述
这是整体的一个损失,但是,不同的样本量,总损失肯定是不同的,因此,为了确定一个统一标准,使用平均损失,即将总损失除以样本个数,
在这里插入图片描述

# 定义损失函数
def cost(X, y, theta):left = np.multiply(-y, np.log(model(X, theta)))right = np.multiply((1 - y), np.log(1 - model(X, theta)))return np.sum(left - right) / (len(X))

使用print输出下面结果,结果是0.69314718055994529

# 将数值带入计算损失值
cost(X, y, theta)

(4)梯度的计算与参数的更新

计算梯度的目的是寻找极值,确定损失函数如何进行优化,使损失函数的值越来越小。
在这里插入图片描述
参数的更新策略为:
在这里插入图片描述

我们需要通过迭代来计算梯度,然后,梯度的计算什么时候停止呢?这里有三种停止策略:

1、设置固定的迭代次数

2、设置损失函数的阈值,当达到一定阈值时,就停止迭代。

3、通过梯度的变化率来判断:设置前后两次梯度相差的阈值,如果小于该阈值,停止迭代。

相关代码如下:

# 计算梯度
# 计算每个参数的梯度方向
def gradient(X, y, theta):grad = np.zeros(theta.shape)error = (model(X, theta) - y).ravel()for j in range(len(theta.ravel())):  # for each parmeterterm = np.multiply(error, X[:, j])grad[0, j] = np.sum(term) / len(X)return grad# 设置三种策略
STOP_ITER = 0
STOP_COST = 1
STOP_GRAD = 2def stopCriterion(type, value, threshold):# 设定三种停止策略if type == STOP_ITER:return value > thresholdelif type == STOP_COST:return abs(value[-1] - value[-2]) < thresholdelif type == STOP_GRAD:# linalg=linear(线性)+algebra(代数),norm则表示范数return np.linalg.norm(value) < thresholdimport numpy.random# 洗牌
def shuffleData(data):np.random.shuffle(data)cols = data.shape[1]X = data[:, 0:cols - 1]y = data[:, cols - 1:]return X, yimport timedef descent(data, theta, batchSize, stopType, thresh, alpha):#  梯度下降init_time = time.time()# 迭代次数i = 0# batchk = 0X, y = shuffleData(data)# 计算的梯度grad = np.zeros(theta.shape)# 损失值costs = [cost(X, y, theta)]while True:grad = gradient(X[k:k + batchSize], y[k:k + batchSize], theta)# 取batch数量个数据k += batchSize# 这个 n 是在运行的时候指定的,为样本的个数if k >= n:k = 0# 重新洗牌X, y = shuffleData(data)# 参数更新theta = theta - alpha * grad# 计算新的损失costs.append(cost(X, y, theta))i += 1if stopType == STOP_ITER:value = ielif stopType == STOP_COST:value = costselif stopType == STOP_GRAD:value = gradif stopCriterion(stopType, value, thresh):breakreturn theta, i - 1, costs, grad, time.time() - init_timedef runExpe(data, theta, batchSize, stopType, thresh, alpha):# import pdb; pdb.set_trace();theta, iter, costs, grad, dur = descent(data, theta, batchSize, stopType, thresh, alpha)name = "Original" if (data[:, 1] > 2).sum() > 1 else "Scaled"name += " data - learning rate: {} - ".format(alpha)if batchSize == n:strDescType = "Gradient"elif batchSize == 1:strDescType = "Stochastic"else:strDescType = "Mini-batch ({})".format(batchSize)name += strDescType + " descent - Stop: "if stopType == STOP_ITER:strStop = "{} iterations".format(thresh)elif stopType == STOP_COST:strStop = "costs change < {}".format(thresh)else:strStop = "gradient norm < {}".format(thresh)name += strStopprint("***{}\nTheta: {} - Iter: {} - Last cost: {:03.2f} - Duration: {:03.2f}s".format(name, theta, iter, costs[-1], dur))fig, ax = plt.subplots(figsize=(12, 4))ax.plot(np.arange(len(costs)), costs, 'r')ax.set_xlabel('Iterations')ax.set_ylabel('Cost')ax.set_title(name.upper() + ' - Error vs. Iteration')return theta

这样,就可以运行结果了。运行的类型有很多种,首先,终止迭代的方式有三种,而选择样本的方式同样有三种:
(1)批量梯度下降,也就是一下子考虑所有的样本,这样的话,速度慢,但是容易得到最优解;
(2)随机梯度下降,每次只利用一个样本,这样的方式迭代速度很快,不过难以保证每次的迭代都是朝着收敛的方向;
(3)小批量梯度下降,即 mini-batch ,每次更新选择一小部分,比如 16个样本,32 个样本等等,这样的方式很实用,但应该先对数据进行洗牌,打乱顺序。

运行一下:

# 选择的梯度下降方法是基于所有样本的
# 当n值指定为10的时候,相当于整体对于梯度下降,为什么呢?因为我的数据样本就10个.
# 传进来的数据是按照迭代次数进行停止的,
# 指定迭代次数的参数是thresh=5000.学习率是alpha=0.000001.
n = 10
runExpe(orig_data, theta, n, STOP_ITER, thresh=5000, alpha=0.000001)
plt.show()

当n值指定为10的时候,相当于整体对于梯度下降,为什么呢?因为我的数据样本就10个.
传进来的数据是按照迭代次数进行停止的,指定迭代次数的参数是thresh=5000.学习率是alpha=0.000001.

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

如果采用随机梯度下降(每次只使用一个样本),或者小批量梯度下降(每次采用 mini-batch),会产生如下的效果——波动太大

# 设定阈值 1E-6, 差不多需要110 000次迭代
runExpe(orig_data, theta, n, STOP_COST, thresh=0.000001, alpha=0.001)
plt.show()
运行结果:

有至少两种解决方案:

(1)将学习率调小一点,情况肯定会有所改善

(2)对数据去均值化。将数据按其属性(按列进行)减去其均值,然后除以其方差。最后得到的结果是,对每个属性/每列来说所有数据都聚集在0附近,方差值为1。

from sklearn import preprocessing as ppscaled_data = orig_data.copy()
scaled_data[:, 1:3] = pp.scale(orig_data[:, 1:3])

最终的结果是:波动不再明显,并且收敛速度加快,最终获得的损失函数的值会更小。不再一一列举实验

4、精度判断

预测

# 设定阈值
def predict(X, theta):return [1 if x >= 0.5 else 0 for x in model(X, theta)]scaled_X = scaled_data[:, :3]
y = scaled_data[:, 3]
predictions = predict(scaled_X, theta)
correct = [1 if ((a == 1 and b == 1) or (a == 0 and b == 0)) else 0 for (a, b) in zip(predictions, y)]
accuracy = (sum(map(int, correct)) % len(correct))
print('accuracy = {0}%'.format(accuracy))

预测结果
在这里插入图片描述

这个结果是可以改善了,如果迭代的次数更多,这个精度会更高。


github源码和数据下载

本文参考文章:https://blog.csdn.net/dengheCSDN/article/details/79054091

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/49154.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【超详细】5位运动员参加了10米台跳水比赛,有人让他们预测比赛结果

题目 5位运动员参加了10米台跳水比赛&#xff0c;有人让他们预测比赛结果&#xff1a; A选手说&#xff1a;B第二&#xff0c;我第三&#xff1b; B选手说&#xff1a;我第二&#xff0c;E第四&#xff1b; C选手说&#xff1a;我第一&#xff0c;D第二&#xff1b; D选手说&am…

马上高考了,我用Python分析出了10年内高考最难的年份

网络上关于哪年高考难度最大的争议从未中断&#xff1a; 于是我决定用python对2010年至2020年的高考数据进行分析&#xff0c;多角度分析得出全国卷最难的年份。 以某高考大省理科成绩为例&#xff0c;我从网络上爬取了从2010年至2020年之间的理科成绩数据&#xff0c;存入csv文…

活动星投票最美空姐网络评选微信的投票方式线上免费投票

如何进行“最美空姐”的投票活动_投票小程序投票_投票助力方式 大家在选择投票小程序之前&#xff0c;可以先梳理一下自己的投票评选活动是哪种类型&#xff0c;目前有匿名投票、图文投票、视频投票、赛事征集投票等。 我们现在要以“最美空姐”为主题进行一次投票活动&#xf…

记第一次Python数据分析练习——2018年“泰迪杯”数据分析职业技能大赛B题(2021/5/20)

文章目的 本人目前是应用统计专业大二(2021/5/20)的本科生&#xff0c;上学期上过Python课&#xff0c;但说实话讲的不深&#xff0c;过了一个学期也基本上忘光了。 最近深刻地觉得计算机专业真是好啊&#xff0c;以后我也要当程序员.JPG &#xff0c;最近开始和老板参加点小…

【意料之中】北大 “韦神”斩获100万奖金

来源&#xff1a;达摩院&#xff0c;编辑&#xff1a;nhyilin 仅用于学术分享&#xff0c;版权属于原作者 前一段时间&#xff0c;韦神就因为一段采访火了。这次韦神又入了达摩院奖杯名单中&#xff0c;不得不说实力真的强。 10月14日&#xff0c;2021达摩院青橙奖公布获奖名单…

《绝地求生》玩家排名预测(2万5千字~大型综合实战)

《绝地求生》玩家排名预测 1. 项目背景2. 数据集介绍3. 项目评估方式3.1 评估方式3.2 MAE(Mean Absolute Error)介绍 4. 项目实现&#xff08;数据分析RFlightGBM&#xff09;4.1 获取数据、基本数据信息查看4.2 数据基本处理4.2.1 数据缺失值处理4.2.2 特征数据规范化处理4.2.…

2019年‘泰迪杯’数据分析职业技能大赛A题——个人代码分享

目录 题目 任务 1 数据预处理与统计 任务 2 数据分析与可视化 代码展示 任务一 任务二 题目 任务 1 数据预处理与统计 任务 1.1 对数据作必要的预处理&#xff0c;在报告中列出处理步骤&#xff0c;将处理后的结 国保存为“task1_1.csv”。 任务 1.2 统计每个大类商品…

2020泰迪杯数据分析技能赛B题-新冠疫情数据分析

任务 1 数据的基本处理 任务 1.1 根据附件 1“城市疫情”中的数据统计各城市自首次通报确诊病 例后至 6 月 30 日的每日累计确诊人数、累计治愈人数和累计死亡人数&#xff0c;将结果 保存为“task1_1.csv”&#xff0c;第一行为字段名&#xff0c;按城市、日期、累计确诊人数…

【论文阅读】提升的自动作文评分通过Prompt预测和匹配

摘要 自动作文评分的目标时自动得评估文章的质量。它是自然语言处理领域中主要的教育应用之一。近来&#xff0c;预训练的技术被用于提升下游任务的性能表现。但是&#xff0c;通过预训练的编码器获取更好的特征&#xff0c;比如说prompts&#xff0c;是很重要的但是并没有被完…

数据分析师是青春饭吗?年龄影响很大吗?

数据分析师是青春饭吗&#xff1f;企业需要经验丰富的数据分析师&#xff0c;数据分析师是不是青春饭&#xff0c;反而是越老越吃香&#xff0c;做数据分析不在于年龄&#xff0c;年龄相对你的经验和技能、适应性、还有学习能力并不重要&#xff0c;数据分析工作并不是一蹴而就…

下一个韦神?广西桂林14岁初中生保送清华丘班,明年本硕博连读!

【导读】最近&#xff0c;初三学生官子钦和高一学生周睿哲被清华丘成桐数学领军计划录取&#xff0c;网友们围观后深深震撼&#xff1a;这就是天才。 14岁天才少年又一次震撼了网友&#xff01; 近日&#xff0c;清华大学丘成桐领军人才培养计划2023年第一批次入围认定结果公…

如何通过tushare获取数据并添加进度条,写入到本地Excel文件

tushare官网地址&#xff1a;Tushare数据 欢迎大家注册体验 安装tushare库 在命令提示符或终端中输入以下命令&#xff0c;可使用pip安装tushare库&#xff1a; pip install tushare 获取API token 在使用tushare库之前&#xff0c;需要先获取API token。在tushare官网注册…

U8如何修改单位名称和账套名称

1、修改单位名称和账套名称时需要使用系统管理员账号登录&#xff0c;系统管理员账号为1 2、登录之后点击系统管理-单位信息 3、找到需要修改的单位&#xff0c;双击即可修改 4、在弹出的弹窗中修改单位名称然后点击确定即可 5、账套名称的修改需点击系统管理-单位账套 6、…

悟空crm二次开发 新增人力资源HRM招聘需求、简历管理、公文管理、回款统计、回款管理、回款计划

悟空crm二次开发 新增人力资源HRM招聘需求、简历管理、公文管理、回款统计、回款管理、回款计划 public function createTeamData($param) {if (!is_array($param[user_id])) {$param[user_id] [intval($param[user_id])];}if (!is_array($param[types_id])) {$param[types_id…

【U8+】用友U8+自动审核自动生成的其他出入库单据

【问题需求】 用友U8中&#xff0c;客户希望调拨单、组装拆卸单、盘点单审核后&#xff0c;自动审核对应的其他出入库单。 【解决方法】 针对账套库执行&#xff0c;查询语句&#xff1a; select * from AccInformation where cSysID ST and ccaption like %自动审核%查询后…

SAP_过账提示科目要求一个成本会计分配

问题点&#xff1a; 解决方案&#xff1a; 在ECC系统&#xff0c;可通过KA02-更改成本要素&#xff0c;在缺省科目分配中设置默认的成本中心或内部订单 后台-控制-成本要素会计-主数据-成本要素-创建成本要素 在S4/HANA系统中&#xff0c;由于成本要素会计功能的变更&#xf…

【分享】用友U8无需API开发连接表单系统、CRM系统、数据库等第三方应用

用友U8用户使用场景&#xff1a; 每当用友U8有存货修改时&#xff0c;需要仓库管理员查询存货档案详情&#xff0c;然后在钉钉宜搭上查询对应货品详情并进行修改&#xff0c;确保两个系统的信息统一&#xff0c;便于销售人员调整营销策略。 但整个流程耗费一定的时间&#xff0…

总账科目 前台操作关事务代码及操作要点

目录 1、维护会计科目相关代码及要点 2、公司代码中的科目参数详解 1、维护会计科目相关代码及要点 事务代码&#xff1a;FSP0 在科目表中维护科目 操作例子&#xff1a;创建1001010100 现金-人民币 及40010001实收资本. 点保存后成功展示如下图 注意&#xff0c;后台必须的…

安卓--记账软件课程设计

安卓课程设计 记账软件课程设计 目录 1 引言............................................................................................................................................................. 2 1.1 背景............................................…

用友U8二次开发之登录

首先引用U8的登录DLL&#xff1a; 然后是调用U8的登录UI&#xff1a; UFSoft.U8.Framework.Login.UI.clsLogin U_Login new UFSoft.U8.Framework.Login.UI.clsLogin();U_Login.login("DP")其中DP是门户子系统的代码&#xff0c;如果不调用U8的业务系统功能&#xff…