机器学习2-python基础综合实践-线性逻辑斯蒂回归分类器

数据和代码

http://pan.baidu.com/s/1dENAUTr

代码

"""
Created on July 9, 2018
@author : Li Guojing
"""

import  pandas as pd
import matplotlib.pyplot as plt
import numpy as np
from sklearn.linear_model import LogisticRegression

#获得训练文件中的数据
df_train = pd.read_csv('Datasets/Breast-Cancer/breast-cancer-train.csv')
#读取测试文件
df_test= pd.read_csv('Datasets/Breast-Cancer/breast-cancer-test.csv')
#选取'Clump Thickness'与'Cell Size'作为特征,构建测试集中的正负分类样本。
df_test_negative=df_test.loc[df_test['Type'] == 0][['Clump Thickness', 'Cell Size']]
df_test_positive=df_test.loc[df_test['Type'] == 1][['Clump Thickness', 'Cell Size']]


#绘制良性肿瘤样本点,标记为红色的o。
plt.scatter(df_test_negative['Clump Thickness'], df_test_negative['Cell Size'], marker='o', s=200, c='red')
#绘制恶性肿瘤样本点,标记为黑色的x。
plt.scatter(df_test_positive['Clump Thickness'], df_test_positive['Cell Size'], marker='x', s=150, c='black')
plt.xlabel('Clump Thickness')
plt.ylabel('Cell Size')


# #利用numpy中的random函数随机采样支线的截距和系数
# intercept = np.random.random([1])#返回一个[0, 1.0)的浮点数
# coef = np.random.random([2])#返回两个[0, 1.0)的浮点数
lx = np.arange(0, 12)
# ly = (- intercept - lx * coef[0])/coef[1]
# #绘制一条随机直线。
# plt.plot(lx, ly, c='yellow')

# plt.show()

#使用sklearn中的逻辑斯蒂回归分类器。
lr = LogisticRegression()
#使用训练样本学习直线的系数和截距。
lr.fit(df_train[['Clump Thickness', 'Cell Size']], df_train['Type'])
print('Testing accuracy:', lr.score(df_test[['Clump Thickness', 'Cell Size']], df_test['Type']))

intercept = lr.intercept_
coef = lr.coef_[0, :]

#原本这个分类面应该是lx * coef[0] + ly * coef[1] + intercept = 0,映射到2二维平面上之后应该是
ly = (-intercept - lx * coef[0]) / coef[1]

plt.plot(lx, ly, c='green')
plt.show()

分类结果

Testing accuracy: 0.9371428571428572
使用所有训练样本得到的二类分类器(绿色直线)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值