欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python機(jī)器學(xué)習(xí)logistic回歸代碼解析

 更新時(shí)間:2018年01月17日 15:11:20   作者:付煒超  
這篇文章主要介紹了Python機(jī)器學(xué)習(xí)logistic回歸代碼解析,具有一定借鑒價(jià)值,需要的朋友可以參考下

本文主要研究的是Python機(jī)器學(xué)習(xí)logistic回歸的相關(guān)內(nèi)容,同時(shí)介紹了一些機(jī)器學(xué)習(xí)中的概念,具體如下。

Logistic回歸的主要目的:尋找一個(gè)非線性函數(shù)sigmod最佳的擬合參數(shù)

擬合、插值和逼近是數(shù)值分析的三大工具

回歸:對(duì)一直公式的位置參數(shù)進(jìn)行估計(jì)

擬合:把平面上的一些系列點(diǎn),用一條光滑曲線連接起來(lái)

logistic主要思想:根據(jù)現(xiàn)有數(shù)據(jù)對(duì)分類邊界線建立回歸公式、以此進(jìn)行分類

sigmoid函數(shù):在神經(jīng)網(wǎng)絡(luò)中它是所謂的激勵(lì)函數(shù)。當(dāng)輸入大于0時(shí),輸出趨向于1,輸入小于0時(shí),輸出趨向0,輸入為0時(shí),輸出為0.5

梯度上升:要找到某個(gè)函數(shù)的最大值,最好的方法是沿著該函數(shù)的梯度方向探尋

收斂:隨著迭代的運(yùn)行算法的結(jié)果和真實(shí)結(jié)果的誤差越來(lái)越小,且趨向于一個(gè)固定值。

爬山算法:是完完全全的貪心算法,每次鼠目寸光的選擇一個(gè)當(dāng)前最優(yōu)解,英雌只能搜尋到局部最優(yōu)值

模擬退火算法:也是一種貪心算法但它的sou索過(guò)程引入了隨機(jī)因素,模擬退火算法以一定的概念來(lái)接受一個(gè)比當(dāng)前解要差的解,因此有可能會(huì)跳出這個(gè)局部最優(yōu)解,達(dá)到全局最優(yōu)解。

處理數(shù)據(jù)中的缺失值:

使用可用特征的均值來(lái)填補(bǔ)缺失值

使用特殊值來(lái)填補(bǔ)缺失值,如-1

忽略有缺失值的樣本

使用相似樣本的均值添補(bǔ)缺失值

使用其它機(jī)器學(xué)習(xí)算法預(yù)測(cè)缺失值

標(biāo)簽與特征不同,很難確定采用某個(gè)合適的值來(lái)替換。

#coding:utf-8
 
from numpy import *
import math
 
def loadDataSet():
  dataMat = []; labelMat = []
  fr = open('testSet.txt')
  for line in fr.readlines():
    lineArr = line.strip().split()
    dataMat.append([1.0, float(lineArr[0]), float(lineArr[1])])
    labelMat.append(int(lineArr[2]))
  return dataMat,labelMat
 
def sigmoid(inX):
  return longfloat(1.0/(1+exp(-inX))) #sigmoid函數(shù)公式
 
def gradAscent(dataMatIn, classLabels):
  #dataMatIn 一個(gè)2維的數(shù)組;classLabels 類別標(biāo)簽
  dataMatrix = mat(dataMatIn)       #轉(zhuǎn)換為矩陣
  labelMat = mat(classLabels).transpose() #得到矩陣的轉(zhuǎn)置矩陣
  m,n = shape(dataMatrix)  #讀取矩陣的長(zhǎng)度,二維矩陣,返回兩個(gè)值
  alpha = 0.001     #向目標(biāo)移動(dòng)的步長(zhǎng)
  maxCycles = 500    #迭代次數(shù) 
  weights = ones((n,1))  #ones()函數(shù)用以創(chuàng)建指定形狀和類型的數(shù)組,默認(rèn)情況下返回的類型是float64。但是,如果使用ones()函數(shù)時(shí)指定了數(shù)據(jù)類型,那么返回的就是該類型
  for k in range(maxCycles):       
    h = sigmoid(dataMatrix*weights)   #matrix mult
    error = (labelMat - h)       #vector subtraction
    weights = weights + alpha * dataMatrix.transpose()* error #matrix mult
  return weights
 
def plotBestFit(weights):
  import matplotlib as mpl
  mpl.use('Agg')         #為了防止出現(xiàn):RuntimeError: could not open display報(bào)錯(cuò)
  import matplotlib.pyplot as plt
  dataMat,labelMat=loadDataSet()
  dataArr = array(dataMat)
  n = shape(dataArr)[0] 
  xcord1 = []; ycord1 = []
  xcord2 = []; ycord2 = []
  for i in range(n):
    if int(labelMat[i])== 1:
      xcord1.append(dataArr[i,1]); ycord1.append(dataArr[i,2])
    else:
      xcord2.append(dataArr[i,1]); ycord2.append(dataArr[i,2])
  fig = plt.figure() #figure: 控制dpi、邊界顏色、圖形大小、和子區(qū)( subplot)設(shè)置
  ax = fig.add_subplot(111) # 參數(shù)111的意思是:將畫(huà)布分割成1行1列,圖像畫(huà)在從左到右從上到下的第1塊,
  ax.scatter(xcord1, ycord1, s=30, c='red', marker='s')
  ax.scatter(xcord2, ycord2, s=30, c='green')
  x = arange(-3.0, 3.0, 0.1)
  y = (-weights[0]-weights[1]*x)/weights[2]
  ax.plot(x, y)
  plt.xlabel('X1'); plt.ylabel('X2');
  plt.savefig('plotBestFit.png')  #因?yàn)槲沂球v訊云服務(wù)器,沒(méi)有圖形界面,所以我保存為圖片。
 
#隨機(jī)梯度上升算法
def stocGradAscent0(dataMatrix, classLabels):
  m,n = shape(dataMatrix)
  alpha = 0.01
  weights = ones(n)  #initialize to all ones
  for i in range(m):
    h = sigmoid(sum(dataMatrix[i]*weights))
    error = classLabels[i] - h
    weights = weights + alpha * error * dataMatrix[i] #回歸系數(shù)的更新操作
  return weights
 
#改進(jìn)的隨機(jī)梯度上升算法
def stocGradAscent1(dataMatrix, classLabels, numIter=150):  #較之前的增加了一個(gè)迭代次數(shù)作為第三個(gè)參數(shù),默認(rèn)值150
  m,n = shape(dataMatrix)
  weights = ones(n)  
  for j in range(numIter):
    dataIndex = range(m)
    for i in range(m):
      alpha = 4/(1.0+j+i)+0.0001  
      randIndex = int(random.uniform(0,len(dataIndex)))  #樣本隨機(jī)選擇
      h = sigmoid(sum(dataMatrix[randIndex]*weights))
      error = classLabels[randIndex] - h
      weights = weights + alpha * error * dataMatrix[randIndex] #回歸系數(shù)的更新操作
      del(dataIndex[randIndex])
  return weights
 
#以回歸系數(shù)和特征向量作為輸入計(jì)算對(duì)應(yīng)的sigmoid值
def classifyVector(inX, weights):
  prob = sigmoid(sum(inX*weights))
  if prob > 0.5: return 1.0        #如果sigmoid值大于0.5函數(shù)返回1,否則返回0
  else: return 0.0
 
#打開(kāi)測(cè)試集和訓(xùn)練集,并對(duì)數(shù)據(jù)進(jìn)行格式化處理的函數(shù)
def colicTest():
  frTrain = open('horseColicTraining.txt'); frTest = open('horseColicTest.txt')
  trainingSet = []; trainingLabels = []
  for line in frTrain.readlines():
    currLine = line.strip().split('\t')
    lineArr =[]
    for i in range(21):
      lineArr.append(float(currLine[i]))
    trainingSet.append(lineArr)
    trainingLabels.append(float(currLine[21]))
  trainWeights = stocGradAscent1(array(trainingSet), trainingLabels, 1000) #計(jì)算回歸系數(shù)向量
  errorCount = 0; numTestVec = 0.0
  for line in frTest.readlines():
    numTestVec += 1.0
    currLine = line.strip().split('\t')
    lineArr =[]
    for i in range(21):
      lineArr.append(float(currLine[i]))
    if int(classifyVector(array(lineArr), trainWeights))!= int(currLine[21]):
      errorCount += 1
  errorRate = (float(errorCount)/numTestVec)
  print "the error rate of this test is: %f" % errorRate
  return errorRate
#調(diào)用函數(shù)colicTest()10次,并求結(jié)果的平均值
def multiTest():
  numTests = 10; errorSum=0.0
  for k in range(numTests):
    errorSum += colicTest()
  print "after %d iterations the average error rate is: %f" % (numTests, errorSum/float(numTests))

總結(jié)

以上就是本文關(guān)于Python機(jī)器學(xué)習(xí)logistic回歸代碼解析的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!

相關(guān)文章

  • Python文件操作之合并文本文件內(nèi)容示例代碼

    Python文件操作之合并文本文件內(nèi)容示例代碼

    眾所周知Python文件處理操作方便快捷,下面這篇文章主要給大家介紹了關(guān)于Python文件操作之合并文本文件內(nèi)容的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • python高級(jí)特性和高階函數(shù)及使用詳解

    python高級(jí)特性和高階函數(shù)及使用詳解

    Python很棒,它有很多高級(jí)用法值得細(xì)細(xì)思索,學(xué)習(xí)使用。這篇文章主要介紹了python高級(jí)特性和高階函數(shù)及使用詳解,需要的朋友可以參考下
    2018-10-10
  • 使用django-crontab實(shí)現(xiàn)定時(shí)任務(wù)的示例

    使用django-crontab實(shí)現(xiàn)定時(shí)任務(wù)的示例

    這篇文章主要介紹了使用django-crontab實(shí)現(xiàn)定時(shí)任務(wù),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02
  • 在Python中使用CasperJS獲取JS渲染生成的HTML內(nèi)容的教程

    在Python中使用CasperJS獲取JS渲染生成的HTML內(nèi)容的教程

    這篇文章主要介紹了在Python中使用CasperJS獲取JS渲染生成的HTML內(nèi)容的教程,需要先用JavaScript創(chuàng)建一個(gè)接口文件,需要的朋友可以參考下
    2015-04-04
  • 使用Cython中prange函數(shù)實(shí)現(xiàn)for循環(huán)的并行

    使用Cython中prange函數(shù)實(shí)現(xiàn)for循環(huán)的并行

    Cython中提供了一個(gè)prange函數(shù),專門用于循環(huán)的并行執(zhí)行。這個(gè) prange的特殊功能是Cython獨(dú)一無(wú)二的,并且prange只能與for循環(huán)搭配使用,不能獨(dú)立存在。本文就將使用 prange 實(shí)現(xiàn) for 循環(huán)的并行,感興趣的可以了解一下
    2022-08-08
  • python?selenium實(shí)現(xiàn)登錄豆瓣示例詳解

    python?selenium實(shí)現(xiàn)登錄豆瓣示例詳解

    大家好,本篇文章主要講的是python?selenium登錄豆瓣示例詳解,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • 對(duì)python中的pop函數(shù)和append函數(shù)詳解

    對(duì)python中的pop函數(shù)和append函數(shù)詳解

    今天小編就為大家分享一篇對(duì)python中的pop函數(shù)和append函數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • 打包FlaskAdmin程序時(shí)關(guān)于static路徑問(wèn)題的解決

    打包FlaskAdmin程序時(shí)關(guān)于static路徑問(wèn)題的解決

    近期寫(xiě)了個(gè)基于Flask-admin的數(shù)據(jù)庫(kù)管理程序,通過(guò)pyinstaller打包,給別人用,經(jīng)過(guò)幾次嘗試,打包的數(shù)據(jù)一直找不到static里面的樣式文件,查閱資料后,最總把問(wèn)題搞定了。寫(xiě)下處理流程,供后來(lái)人參考
    2021-09-09
  • Python字典get()函數(shù)使用詳解

    Python字典get()函數(shù)使用詳解

    在Python中,字典對(duì)象有一個(gè)名為get()的方法,它可以用來(lái)獲取字典中鍵對(duì)應(yīng)的值,該方法接受一個(gè)鍵作為參數(shù),并返回該鍵對(duì)應(yīng)的值,如果鍵不存在于字典中,則返回None,本文就給大家介紹一下Python get()函數(shù)使用方法,需要的朋友可以參考下
    2023-07-07
  • Python入門之字典的使用教程

    Python入門之字典的使用教程

    Python字典是一種可變?nèi)萜髂P?,且可存?chǔ)任意類型對(duì)象,如字符串、數(shù)字、元組等其他容器模型。本文將為大家詳細(xì)講講字典的使用教程,需要的可以參考一下
    2022-09-09

最新評(píng)論