MachineLearning:四、逻辑回归in python

原创 2016年08月29日 15:41:38

前面讲了logistic的理论部分,这里我参照《机器学习实战》写了logistic的实现部分。如果对logistic不清楚,请看逻辑回归。 我建立了一个逻辑回归的类,类中包含三个主要函数:

  • fit:拟合模型.
  • predict:进行预测
  • score:求错误率

数据我使用预测患有疝病的马的存活问题。这里面的数据包含368个样本和28个特征。下面是详细代码,我的github上面有数据和代码:logistic regression
下面是具体代码,如果知道logistic原理,下面的代码并不难理解

# -*- coding: utf-8 -*-
"""python
Created on Fri Apr  8 23:59:45 2016

@author: wq

逻辑回归
"""
from numpy import  *


class LogisticRegression():
    '''
    二项逻辑回归模型

    参数
    --------

    '''
    def __init__(self, alpha=1):
        '''
        初始化
        参数
        ---------
        alpha,梯度下降迭代步长
        '''
        self.alpha = alpha
        self.weights = []     #模型权值

    def sigmoid(self, inX):
        #print inX
        return 1/(1+sum(exp(-inX)))

    def fit(self, dataMatrix, classLabels):
        '''根据训练数据拟合模型

        参数
        ------------
        dataMatrix:
            训练样本属性矩阵
            类型:array
        classLabels:
            训练样本标签
            类型:list

        '''
        row,col = dataMatrix.shape
        if len(self.weights) == 0:
            weights = ones(col)   #初始化权值矩阵2
        else:
            weights = self.weights
        diff = weights      #权值变化矩阵,初始化为权值矩阵
        j = 0 #迭代次数
        while(abs(max(diff))>0.001):     #当权值变化很小的时停止迭代。
            dataIndex = range(row)
            for i in range(row):
                alpha = 4/(self.alpha+i)+0.0001    #alpha随着每次迭代,下降。参数趋于稳定
                randIndex = int(random.uniform(0,len(dataIndex)))#随机选取训练对象
                h = self.sigmoid(sum(dataMatrix[randIndex]*weights))#sigmoid求值
                error = classLabels[randIndex] - h      #误差项

                diff = weights      
                weights = weights + alpha * error * dataMatrix[randIndex]#权值更新
                diff = weights - diff                #权值差异
                del(dataIndex[randIndex])
        self.weights = weights
        #print weights

    def predict(self,dataList):
        '''
        训练的二项逻辑回归预测

        参数
        --------
        dataList:
            待预测样本属性,
            类型:list
        '''
        if len(self.weights) == 0:
            raise KeyError,("没有进行模型训练")#如果没有进行fit预测,抛出异常
        prob = self.sigmoid(sum(dataList*self.weights))#概率
        if prob > 0.5:return 1
        else: return 0

    def score(self,dataMatrix, classLabels):
        '''
        评价模型性能


        参数
        ------------
        dataMatrix:
            测试样本属性举证
            属性:array
        classLabels:
            测试样本类别,这里只有1、0两类
            属性:list

        return
        ---------
        errorRate:错误率
        '''
        numData = len(dataMatrix)
        errorCount = 0
        j = 0 #行数记录,
        for line in dataMatrix:
            #print '预测结果',self.predict(line)
            #print '样本标签',classLabels[j]
            if int(self.predict(line)) != int(classLabels[j]):
                errorCount += 1
            j += 1
        #print errorCount
        errorRate = (float(errorCount)/numData)
        print "the error rate of this test is: %f" % errorRate
        return errorRate

if __name__=='__main__':
    frTrain = open('horseColicTraining.txt')#读取数据
    frTest = open('horseColicTest.txt')

    #读取训练集
    trainingSet = []; trainingLabels = []
    for line in frTrain.readlines():
        line = line.strip().split('\t')
        trainingSet.append(map(float, line)[:-1])
        trainingLabels.append(float(line[21]))

    #读取测试集
    testSet = [];testLabels = []
    for line in frTest:
        line = line.strip().split('\t')
        testSet.append(map(float, line)[:-1])
        testLabels.append(line[21])

    #实例化
    clf = LogisticRegression(1.0)
    #迭代10次
    for i in range(10):
        clf.fit(array(trainingSet), trainingLabels)
        clf.score(array(testSet), testLabels)

参考资料

《机器学习实战》

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

MachineLearning—Logistic Regression(四)-逻辑回归应用于手写数字识别

之前的文章对逻辑回归已经进行了较为详尽的介绍,在此我们为了更为迅速方便的理解逻辑回归在手写数字识别当中的应用,我们仅仅做简单快速的回顾。逻辑回归通常应用于二分类问题,而经过拓展其也可以应用于多分类问题...

MachineLearning:三、聊聊逻辑回归

在Machine Learning中,逻辑斯蒂回归(Logistic Regression)是十分经典的方法,简称LR,虽然名字叫回归,但是这是线性分类模型而不是回归模型。这里面涉及到一些知识点,包括...

二,机器学习算法之逻辑回归(python实现)

逻辑回归(Logistic Regression)是目前流行最广泛的算法之一。 1. 何为逻辑回归:        逻辑回归主要思想是根据现有的训练集(数据)进行分类,判断这些数据属于哪一个类...

python/逻辑回归

正则化方法,防止过拟合,提高泛化能力在机器学习算法中,常常将原始数据集分为三部分:training data、validation data 、testing data。 其中validation ...

Python实现逻辑回归

Python实现逻辑回归

机器学习 Python实现逻辑回归

# -*- coding: cp936 -*- from numpy import * def loadDataSet(): dataMat = []; labelMat = [] ...

逻辑回归+牛顿法 python实现

请先了解以下逻辑回归 http://blog.csdn.net/pakko/article/details/37878837 #!/usr/bin/python # -*- coding: u...

Logistic Regression 逻辑回归算法例子,python代码实现

转载自原文 逻辑回归 Logistic Regression 虽然名字叫做逻辑回归 Logistic regression ,但它是一种分类算法。对于文本处理方便,逻辑回归是一种非常强大的分类器。...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)