# -*- coding: utf-8 -*- import pandas as pd from scipy.interpolate import lagrange from matplotlib import pyplot as plt from random import shuffle from keras.models import Sequential #導入神經網絡初始化函數 from keras.layers.core import Dense, Activation #導入神經網絡層函數、激活函數 # inputfile='F:\\python數據挖掘\\chapter6\\chapter6\\demo\\data\\missing_data.xls' # outputfile='F:\\python數據挖掘\\chapter6\\chapter6\\demo\\tmp\\missing_data_sale.xls' # data=pd.read_excel(inputfile,header=None) datafile = 'F:\\python數據挖掘\\chapter6\\chapter6\\demo\\data\\model.xls' data = pd.read_excel(datafile) #print(data) #print(type(data)) data = data.as_matrix()#轉換成矩陣或者是數組型,對數據進行操做。 shuffle(data)#隨機擾亂數據 #print(data) p = 0.8 #設置訓練數據比例 train = data[:int(len(data)*p),:] test = data[int(len(data)*p):,:] # # netfile = 'F:\\python數據挖掘\\chapter6\\chapter6\\demo\\tmp\\net.model1' #構建的神經網絡模型存儲路徑 # net = Sequential() #創建神經網絡 net.add(Dense(input_dim=3,output_dim=10)) #添加輸入層(3節點)到隱藏層(10節點)的鏈接 #net.add(Dense(32, input_dim=16)) net.add(Activation('relu')) #隱藏層使用relu激活函數 net.add(Dense(input_dim=10, output_dim=1)) #添加隱藏層(10節點)到輸出層(1節點)的鏈接 net.add(Activation('sigmoid')) #輸出層使用sigmoid激活函數 net.compile(loss = 'binary_crossentropy', optimizer = 'adam', class_mode = "binary") #編譯模型,使用adam方法求解 net.fit(train[:,:3], train[:,3], nb_epoch=2, batch_size=1) #訓練模型,循環1000次,Keras模塊中的batch_size指的就是小批量梯度降低法。 net.save_weights(netfile) #保存模型 #predict_result = net.predict_classes(train[:,:3]).reshape(len(train)) #預測結果變形 '''這裏要提醒的是,keras用predict給出預測機率,predict_classes纔是給出預測類別,並且二者的預測結果都是n x 1維數組,而不是一般的 1 x n''' # # from cm_plot import * #導入自行編寫的混淆矩陣可視化函數 # cm_plot(train[:,3], predict_result).show() #顯示混淆矩陣可視化結果 # from sklearn.metrics import roc_curve #導入ROC曲線函數 # predict_result = net.predict(test[:,:3]).reshape(len(test)) fpr, tpr, thresholds = roc_curve(test[:,3], predict_result, pos_label=1) print(fpr,tpr) plt.plot(fpr, tpr, linewidth=2, label = 'ROC of LM') #做出ROC曲線 plt.xlabel('False Positive Rate') #座標軸標籤 plt.ylabel('True Positive Rate') #座標軸標籤 plt.ylim(0,1.05) #邊界範圍 plt.xlim(0,1.05) #邊界範圍 plt.legend(loc=4) #圖例 plt.show() #顯示做圖結果
結果畫出的圖如上面所示。python
主要步驟爲:數組
第一:從原始數據中隨機性的抽取數據,而後進行數據探索分析數據,數據探索分析包括:網絡
1.數據清洗dom
2.缺失值處理函數
3.數據變換優化
第二:建模樣本數據spa
1.模型訓練excel
2.模型評價code
第三:預處理後診斷數據blog
第四:自動診斷
第五:根據診斷結果進行模型的優化與重構
最後,再進行模型的訓練和評價。