自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

機(jī)器學(xué)習(xí)之神經(jīng)網(wǎng)絡(luò)及Python實(shí)現(xiàn)

開(kāi)發(fā) 前端 機(jī)器學(xué)習(xí)
神經(jīng)網(wǎng)絡(luò)在機(jī)器學(xué)習(xí)中有很大的應(yīng)用,甚至涉及到方方面面。本文主要是簡(jiǎn)單介紹一下神經(jīng)網(wǎng)絡(luò)的基本理論概念和推算。同時(shí)也會(huì)介紹一下神經(jīng)網(wǎng)絡(luò)在數(shù)據(jù)分類(lèi)方面的應(yīng)用。

神經(jīng)網(wǎng)絡(luò)在機(jī)器學(xué)習(xí)中有很大的應(yīng)用,甚至涉及到方方面面。本文主要是簡(jiǎn)單介紹一下神經(jīng)網(wǎng)絡(luò)的基本理論概念和推算。同時(shí)也會(huì)介紹一下神經(jīng)網(wǎng)絡(luò)在數(shù)據(jù)分類(lèi)方面的應(yīng)用。

[[246577]]

首先,當(dāng)我們建立一個(gè)回歸和分類(lèi)模型的時(shí)候,無(wú)論是用最小二乘法(OLS)還是***似然值(MLE)都用來(lái)使得殘差達(dá)到最小。因此我們?cè)诮⒛P偷臅r(shí)候,都會(huì)有一個(gè)loss function。

而在神經(jīng)網(wǎng)絡(luò)里也不例外,也有個(gè)類(lèi)似的loss function。

對(duì)回歸而言:

對(duì)分類(lèi)而言:

然后同樣方法,對(duì)于W開(kāi)始求導(dǎo),求導(dǎo)為零就可以求出極值來(lái)。

關(guān)于式子中的W。我們?cè)谶@里以三層的神經(jīng)網(wǎng)絡(luò)為例。先介紹一下神經(jīng)網(wǎng)絡(luò)的相關(guān)參數(shù)。

神經(jīng)網(wǎng)絡(luò)的相關(guān)參數(shù)

***層是輸入層,第二層是隱藏層,第三層是輸出層。

在X1,X2經(jīng)過(guò)W1的加權(quán)后,達(dá)到隱藏層,然后經(jīng)過(guò)W2的加權(quán),到達(dá)輸出層

其中,

我們有:

至此,我們建立了一個(gè)初級(jí)的三層神經(jīng)網(wǎng)絡(luò)。

當(dāng)我們要求其的loss function最小時(shí),我們需要逆向來(lái)求,也就是所謂的backpropagation。

我們要分別對(duì)W1和W2進(jìn)行求導(dǎo),然后求出其極值。

從右手邊開(kāi)始逆推,首先對(duì)W2進(jìn)行求導(dǎo)。

代入損失函數(shù)公式:

然后,我們進(jìn)行化簡(jiǎn):

化簡(jiǎn)到這里,我們同理再對(duì)W1進(jìn)行求導(dǎo)。

我們可以發(fā)現(xiàn)當(dāng)我們?cè)谧鯾p網(wǎng)絡(luò)時(shí)候,有一個(gè)逆推回去的誤差項(xiàng),其決定了loss function 的最終大小。

在實(shí)際的運(yùn)算當(dāng)中,我們會(huì)用到梯度求解,來(lái)求出極值點(diǎn)。

總結(jié)一下來(lái)說(shuō),我們使用向前推進(jìn)來(lái)理順神經(jīng)網(wǎng)絡(luò)做到回歸分類(lèi)等模型。而向后推進(jìn)來(lái)計(jì)算他的損失函數(shù),使得參數(shù)W有一個(gè)***解。

當(dāng)然,和線性回歸等模型相類(lèi)似的是,我們也可以加上正則化的項(xiàng)來(lái)對(duì)W參數(shù)進(jìn)行約束,以免使得模型的偏差太小,而導(dǎo)致在測(cè)試集的表現(xiàn)不佳。

Python 的實(shí)現(xiàn):

使用了KERAS的庫(kù)

解決線性回歸:

  1. model.add(Dense(1, input_dim=n_featuresactivation='linear'use_bias=True)) 
  2. # Use mean squared error for the loss metric and use the ADAM backprop algorithm 
  3. model.compile(loss='mean_squared_error'optimizer='adam'
  4. # Train the network (learn the weights) 
  5. # We need to convert from DataFrame to NumpyArray 
  6. history = model.fit(X_train.values, y_train.values, epochs=100,  
  7.  batch_size=1verbose=2validation_split=0

解決多重分類(lèi)問(wèn)題:

  1. # create model 
  2. model = Sequential() 
  3. model.add(Dense(64, activation='relu'input_dim=n_features)) 
  4. model.add(Dropout(0.5)) 
  5. model.add(Dense(64, activation='relu')) 
  6. model.add(Dropout(0.5)) 
  7. # Softmax output layer 
  8. model.add(Dense(7, activation='softmax')) 
  9. model.compile(loss='categorical_crossentropy'optimizer='adam'metrics=['accuracy']) 
  10. model.fit(X_train.values, y_train.values, epochs=20batch_size=16
  11. y_pred = model.predict(X_test.values) 
  12. y_te = np.argmax(y_test.values, axis = 1
  13. y_pr = np.argmax(y_pred, axis = 1
  14. print(np.unique(y_pr)) 
  15. print(classification_report(y_te, y_pr)) 
  16. print(confusion_matrix(y_te, y_pr)) 

當(dāng)我們選取***參數(shù)時(shí)候,有很多種解決的途徑。這里就介紹一種是gridsearchcv的方法,這是一種暴力檢索的方法,遍歷所有的設(shè)定參數(shù)來(lái)求得***參數(shù)。

  1. from sklearn.model_selection import GridSearchCV 
  2. def create_model(optimizer='rmsprop'): 
  3.  model = Sequential() 
  4.  model.add(Dense(64, activation='relu'input_dim=n_features)) 
  5.  model.add(Dropout(0.5)) 
  6.  model.add(Dense(64, activation='relu')) 
  7.  model.add(Dropout(0.5)) 
  8.  model.add(Dense(7, activation='softmax')) 
  9.  model.compile(loss='categorical_crossentropy'optimizeroptimizer=optimizer, metrics=['accuracy']) 
  10.   
  11.  return model 
  12. model = KerasClassifier(build_fn=create_modelverbose=0
  13. optimizers = ['rmsprop'] 
  14. epochs = [5, 10, 15] 
  15. batches = [128] 
  16. param_grid = dict(optimizer=optimizersepochsepochs=epochs, batch_size=batchesverbose=['2']) 
  17. grid = GridSearchCV(estimator=modelparam_gridparam_grid=param_grid) 
  18. grid.fit(X_train.values, y_train.values) 
責(zé)任編輯:趙寧寧 來(lái)源: 今日頭條
相關(guān)推薦

2018-03-22 13:34:59

TensorFlow神經(jīng)網(wǎng)絡(luò)

2022-02-15 23:38:22

Python機(jī)器學(xué)習(xí)算法

2020-12-25 10:08:53

Python機(jī)器學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)算法

2023-04-19 10:17:35

機(jī)器學(xué)習(xí)深度學(xué)習(xí)

2017-07-18 10:20:30

Python神經(jīng)網(wǎng)絡(luò)

2017-03-13 14:45:51

Python神經(jīng)網(wǎng)絡(luò)基礎(chǔ)

2017-07-27 10:46:44

神經(jīng)網(wǎng)絡(luò)機(jī)器學(xué)習(xí)強(qiáng)化學(xué)習(xí)

2025-02-24 08:00:00

機(jī)器學(xué)習(xí)ML架構(gòu)

2017-03-10 12:16:46

機(jī)器學(xué)習(xí)

2024-04-30 14:54:10

2020-08-06 10:11:13

神經(jīng)網(wǎng)絡(luò)機(jī)器學(xué)習(xí)算法

2017-07-06 17:03:45

BP算法Python神經(jīng)網(wǎng)絡(luò)

2017-08-04 14:23:04

機(jī)器學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)TensorFlow

2023-11-15 16:12:41

人工智能機(jī)器學(xué)習(xí)深度學(xué)習(xí)

2025-02-25 14:13:31

2017-03-07 13:55:30

自動(dòng)駕駛神經(jīng)網(wǎng)絡(luò)深度學(xué)習(xí)

2020-06-23 11:49:08

神經(jīng)網(wǎng)絡(luò)數(shù)據(jù)圖形

2020-05-06 10:29:45

機(jī)器學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)TensorFlow

2019-05-07 19:12:28

機(jī)器學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)Python

2018-07-03 16:10:04

神經(jīng)網(wǎng)絡(luò)生物神經(jīng)網(wǎng)絡(luò)人工神經(jīng)網(wǎng)絡(luò)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)