当前位置:网站首页>【机器学习】逻辑回归代码练习
【机器学习】逻辑回归代码练习
2022-07-29 09:02:00 【51CTO】
是中国大学慕课《机器学习》的“逻辑回归”章节的课后代码。
课程地址:
https://www.icourse163.org/course/WZU-1464096179
课程完整代码:
https://github.com/fengdu78/WZU-machine-learning-course
代码修改并注释:黄海广,[email protected]
逻辑回归
在这一次练习中,我们将要实现逻辑回归并且应用到一个分类任务。我们还将通过将正则化加入训练算法,来提高算法的鲁棒性,并用更复杂的情形来测试它。
在训练的初始阶段,我们将要构建一个逻辑回归模型来预测,某个学生是否被大学录取。设想你是大学相关部分的管理者,想通过申请学生两次测试的评分,来决定他们是否被录取。现在你拥有之前申请学生的可以用于训练逻辑回归的训练样本集。对于每一个训练样本,你有他们两次测试的评分和最后是被录取的结果。为了完成这个预测任务,我们准备构建一个可以基于两次测试评分来评估录取可能性的分类模型。
让我们从检查数据开始。
Exam 1 | Exam 2 | Admitted | |
0 | 34.623660 | 78.024693 | 0 |
1 | 30.286711 | 43.894998 | 0 |
2 | 35.847409 | 72.902198 | 0 |
3 | 60.182599 | 86.308552 | 1 |
4 | 79.032736 | 75.344376 | 1 |
让我们创建两个分数的散点图,并使用颜色编码来可视化,如果样本是正的(被接纳)或负的(未被接纳)。

看起来在两类间,有一个清晰的决策边界。现在我们需要实现逻辑回归,那样就可以训练一个模型来预测结果。
Sigmoid 函数
代表一个常用的逻辑函数(logistic function)为形函数(Sigmoid function),公式为:
合起来,我们得到逻辑回归模型的假设函数:
让我们做一个快速的检查,来确保它可以工作。

棒极了!现在,我们需要编写代价函数来评估结果。代价函数:
现在,我们要做一些设置,和我们在练习1在线性回归的练习很相似。
让我们来检查矩阵的维度来确保一切良好。
让我们计算初始化参数的代价函数(为0)。
看起来不错,接下来,我们需要一个函数来计算我们的训练数据、标签和一些参数的梯度。
Gradient descent(梯度下降)
- 这是批量梯度下降(batch gradient descent)
- 转化为向量化计算:
注意,我们实际上没有在这个函数中执行梯度下降,我们仅仅在计算一个梯度步长。在练习中,一个称为“fminunc”的Octave函数是用来优化函数来计算成本和梯度参数。由于我们使用Python,我们可以用SciPy的“optimize”命名空间来做同样的事情。
我们看看用我们的数据和初始参数为0的梯度下降法的结果。
现在可以用SciPy's truncated newton(TNC)实现寻找最优参数。
让我们看看在这个结论下代价函数计算结果是什么个样子~
接下来,我们需要编写一个函数,用我们所学的参数w来为数据集X输出预测。然后,我们可以使用这个函数来给我们的分类器的训练精度打分。逻辑回归模型的假设函数:
当
大于等于0.5时,预测 y=1
当小于0.5时,预测 y=0 。
我们的逻辑回归分类器预测正确,如果一个学生被录取或没有录取,达到89%的精确度。不坏!记住,这是训练集的准确性。我们没有保持住了设置或使用交叉验证得到的真实逼近,所以这个数字有可能高于其真实值(这个话题将在以后说明)。
正则化逻辑回归
在训练的第二部分,我们将要通过加入正则项提升逻辑回归算法。如果你对正则化有点眼生,或者喜欢这一节的方程的背景,请参考在"exercises"文件夹中的"ex2.pdf"。简而言之,正则化是成本函数中的一个术语,它使算法更倾向于“更简单”的模型(在这种情况下,模型将更小的系数)。这个理论助于减少过拟合,提高模型的泛化能力。这样,我们开始吧。
设想你是工厂的生产主管,你有一些芯片在两次测试中的测试结果。对于这两次测试,你想决定是否芯片要被接受或抛弃。为了帮助你做出艰难的决定,你拥有过去芯片的测试数据集,从其中你可以构建一个逻辑回归模型。
和第一部分很像,从数据可视化开始吧!
Test 1 | Test 2 | Accepted | |
0 | 0.051267 | 0.69956 | 1 |
1 | -0.092742 | 0.68494 | 1 |
2 | -0.213710 | 0.69225 | 1 |
3 | -0.375000 | 0.50219 | 1 |
4 | -0.513250 | 0.46564 | 1 |

这个数据看起来可比前一次的复杂得多。特别地,你会注意到其中没有线性决策界限,来良好的分开两类数据。一个方法是用像逻辑回归这样的线性技术来构造从原始特征的多项式中得到的特征。让我们通过创建一组多项式特征入手吧。
Accepted | Ones | F10 | F20 | F21 | F30 | F31 | F32 | F40 | F41 | F42 | F43 | |
0 | 1 | 1 | 0.051267 | 0.002628 | 0.035864 | 0.000135 | 0.001839 | 0.025089 | 0.000007 | 0.000094 | 0.001286 | 0.017551 |
1 | 1 | 1 | -0.092742 | 0.008601 | -0.063523 | -0.000798 | 0.005891 | -0.043509 | 0.000074 | -0.000546 | 0.004035 | -0.029801 |
2 | 1 | 1 | -0.213710 | 0.045672 | -0.147941 | -0.009761 | 0.031616 | -0.102412 | 0.002086 | -0.006757 | 0.021886 | -0.070895 |
3 | 1 | 1 | -0.375000 | 0.140625 | -0.188321 | -0.052734 | 0.070620 | -0.094573 | 0.019775 | -0.026483 | 0.035465 | -0.047494 |
4 | 1 | 1 | -0.513250 | 0.263426 | -0.238990 | -0.135203 | 0.122661 | -0.111283 | 0.069393 | -0.062956 | 0.057116 | -0.051818 |
现在,我们需要修改第1部分的成本和梯度函数,包括正则化项。首先是成本函数:
regularized cost(正则化代价函数)
请注意等式中的"reg" 项。还注意到另外的一个“学习率”参数。这是一种超参数,用来控制正则化项。现在我们需要添加正则化梯度函数:
如果我们要使用梯度下降法令这个代价函数最小化,因为我们未对 进行正则化,所以梯度下降算法将分两种情形:
重复直到收敛重复
对上面的算法中 j=1,2,...,n 时的更新式子进行调整可得:
就像在第一部分中做的一样,初始化变量。
让我们初始学习率到一个合理值。如果有必要的话(即如果惩罚太强或不够强),我们可以之后再折腾这个。
现在,让我们尝试调用新的默认为0的的正则化函数,以确保计算工作正常。
现在我们可以使用和第一部分相同的优化函数来计算优化后的结果。
最后,我们可以使用第1部分中的预测函数来查看我们的方案在训练数据上的准确度。
虽然我们实现了这些算法,值得注意的是,我们还可以使用高级Python库像scikit-learn来解决这个问题。
这个准确度和我们刚刚实现的差了好多,不过请记住这个结果可以使用默认参数下计算的结果。我们可能需要做一些参数的调整来获得和我们之前结果相同的精确度。
参考
- Prof. Andrew Ng. Machine Learning. Stanford University

边栏推荐
- Design of distributed (cluster) file system
- Intel将逐步结束Optane存储业务 未来不再开发新产品
- Restful style details
- Application of matrix transpose
- access数据库可以被远程访问吗
- C language -- 22 one dimensional array
- 7.1-default-arguments
- WQS binary learning notes
- 2022 question bank and answers of operation certificate examination for main principals of hazardous chemical business units
- Transaction management in SQL Server
猜你喜欢

(视频+图文)机器学习入门系列-第3章 逻辑回归

LeetCode刷题(6)

Excellent Allegro skill recommendation

LeetCode刷题(6)

Leetcode question brushing (6)

LeetCode力扣题目总结(题目编号:53、3、141、面试题022、剑指offer链表中环的入口节点、20、19、牛客NC1、103、1143、牛客127)

信息系统项目管理师必背核心考点(五十三)质量等级

User identity identification and account system practice

Analysis of zorder sampling partition process in Hudi - "deepnova developer community"

6.3 references
随机推荐
Application of matrix transpose
C language -- 23 two-dimensional array
What is the key to fast multi tag user profile analysis?
(Video + graphic) introduction to machine learning series - Chapter 3 logical regression
What is the difference between the pre training model and the traditional method in sorting?
[from_bilibili_dr_can][[advanced control theory] 9_ State observer design] [learning record]
Transaction management in SQL Server
LeetCode刷题(6)
2022 P cylinder filling test simulation 100 questions simulation test platform operation
Could not receive a message from the daemon
Data is the main body of future world development, and data security should be raised to the national strategic level
Reptile practice (10): send daily news
Design of distributed (cluster) file system
Travel notes in 2022 (ongoing)
Leetcode deduction topic summary (topic No.: 53, 3, 141, interview question 022, the entry node of the link in the sword finger offer chain, 20, 19, Niuke NC1, 103, 1143, Niuke 127)
7.3-function-templates
7.1-default-arguments
(Video + graphic) introduction series to machine learning - Chapter 2 linear regression
Sword finger offer 27. image of binary tree
ERROR 1045 (28000): Access denied for user ‘ODBC‘@‘localhost‘ (using password: NO)