国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python實現的邏輯回歸算法示例【附測試csv文件下載】

2020-01-04 13:40:45
字體:
來源:轉載
供稿:網友

本文實例講述了Python實現的邏輯回歸算法。分享給大家供大家參考,具體如下:

使用python實現邏輯回歸
Using Python to Implement Logistic Regression Algorithm

菜鳥寫的邏輯回歸,記錄一下學習過程

代碼:

#encoding:utf-8""" Author:  njulpy Version:  1.0 Data:  2018/04/10 Project: Using Python to Implement LogisticRegression Algorithm"""import numpy as npimport pandas as pdimport matplotlib.pyplot as pltfrom sklearn.model_selection import train_test_split#建立sigmoid函數def sigmoid(x): x = x.astype(float) return 1./(1+np.exp(-x))#訓練模型,采用梯度下降算法def train(x_train,y_train,num,alpha,m,n): beta = np.ones(n) for i in range(num):  h=sigmoid(np.dot(x_train,beta)) #計算預測值  error = h-y_train.T    #計算預測值與訓練集的差值  delt=alpha*(np.dot(error,x_train))/m #計算參數的梯度變化值  beta = beta - delt  #print('error',error) return betadef predict(x_test,beta): y_predict=np.zeros(len(y_test))+0.5 s=sigmoid(np.dot(beta,x_test.T)) y_predict[s < 0.34] = 0 y_predict[s > 0.67] = 1 return y_predictdef accurancy(y_predict,y_test): acc=1-np.sum(np.absolute(y_predict-y_test))/len(y_test) return accif __name__ == "__main__": data = pd.read_csv('iris.csv') x = data.iloc[:,1:5] y = data.iloc[:,5].copy() y.loc[y== 'setosa'] = 0 y.loc[y== 'versicolor'] = 0.5 y.loc[y== 'virginica'] = 1 x_train,x_test,y_train,y_test = train_test_split(x,y,test_size=0.3,random_state=15) m,n=np.shape(x_train) alpha = 0.01 beta=train(x_train,y_train,1000,alpha,m,n) pre=predict(x_test,beta) t = np.arange(len(x_test)) plt.figure() p1 = plt.plot(t,pre) p2 = plt.plot(t,y_test,label='test') label = ['prediction', 'true'] plt.legend(label, loc=1) plt.show() acc=accurancy(pre,y_test) print('The predicted value is ',pre) print('The true value is ',np.array(y_test)) print('The accuracy rate is ',acc)

輸出結果:

The predicted value is  [ 0.   0.5  1.   0.   0.   1.   1.   0.5  1.   1.   1.   0.5  0.5  0.5  1.
  0.   0.5  1.   0.   1.   0.5  0.   0.5  0.5  0.   0.   1.   1.   1.   1.
  0.   1.   1.   1.   0.   0.   1.   0.   0.   0.5  1.   0.   0.   0.5  1. ]
The true value is  [0 0.5 0.5 0 0 0.5 1 0.5 0.5 1 1 0.5 0.5 0.5 1 0 0.5 1 0 1 0.5 0 0.5 0.5 0
 0 1 1 1 0.5 0 1 0.5 1 0 0 1 0 0 0.5 1 0 0 0.5 1]
The accuracy rate is  0.9444444444444444

Python,邏輯回歸,算法

附:上述示例中的iris.csv文件點擊此處本站下載

希望本文所述對大家Python程序設計有所幫助。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 礼泉县| 云霄县| 茂名市| 萨迦县| 封开县| 田东县| 孙吴县| 时尚| 道真| 青神县| 舞阳县| 长汀县| 台山市| 古丈县| 商河县| 新闻| 南宫市| 若羌县| 垦利县| 湛江市| 明水县| 龙陵县| 清原| 定结县| 太湖县| 张北县| 旬邑县| 黎城县| 武隆县| 库尔勒市| 天峻县| 平度市| 三穗县| 南木林县| 汕尾市| 望江县| 塔河县| 乌兰察布市| 二连浩特市| 盱眙县| 四子王旗|