data:image/s3,"s3://crabby-images/d0df3/d0df31779e7d96dab90927cc9bafb5eb8db7627d" alt=""
1.基于Logistic回归和Sigmoid函数的分类
2.基于最优化方法的最佳回归系数确定
2.1 梯度上升法
参考:机器学习——梯度下降算法
2.2 训练算法:使用梯度上升找到最佳参数
Logistic回归梯度上升优化算法
1 | def loadDataSet(): |
1 | dataMat,labelMat = loadDataSet() |
1 | [[ 4.12414349] |
2.3 分析数据:画出决策边界
画出数据集和Logistic回归最佳拟合直线的函数
1 | def plotBestFit(wei): #画出数据集和Logistic回归最佳拟合直线的函数 |
data:image/s3,"s3://crabby-images/b6c62/b6c6205c7b8b5084f81842ac54245c4e7ffaa440" alt=""
1 | dataMat,labelMat = loadDataSet() |
2.4 训练算法:随梯度上升
1 | def stocGradAscent0(dataMatrix, classLabels): #随机梯度上升算法 |
1 | dataMat,labelMat = loadDataSet() |
data:image/s3,"s3://crabby-images/36e70/36e703ed2e2f212af447046ce478ff20ef79bf71" alt=""
改进的随机梯度上升算法
1 | def stocGradAscent1(dataMatrix, classLabels, numIter=150): |
data:image/s3,"s3://crabby-images/1f2bc/1f2bc1d6435e2e3a8b3bfc0219e0542f235b541a" alt=""
data:image/s3,"s3://crabby-images/de99b/de99b926d0d43eb0d64ceea431564377d180fd26" alt=""
data:image/s3,"s3://crabby-images/aecbe/aecbec14303839da992227fb40c32db01d72b8f3" alt=""
示例:从疝气病症预测病马的死亡率
1.准备数据:处理数据中的缺失值
data:image/s3,"s3://crabby-images/c9f70/c9f7044b6372330297379f801f1cd7c3900adbea" alt=""
data:image/s3,"s3://crabby-images/7c5d0/7c5d0ec78d579854c39078cfab7fd4dfea52683d" alt=""
2.测试算法:使用Logistic回归进行分类
1 | def classifyVector(inX, weights): #输入回归系数和特征向量,计算出Sigmoid值,如果大于0.5则返回1,否则返回0 |