,所以我不能直接取每次迭代的損耗值找到很好的文檔,但我希望這會幫助別人的未來:
old_stdout = sys.stdout
sys.stdout = mystdout = StringIO()
clf = SGDClassifier(**kwargs, verbose=1)
clf.fit(X_tr, y_tr)
sys.stdout = old_stdout
loss_history = mystdout.getvalue()
loss_list = []
for line in loss_history.split('\n'):
if(len(line.split("loss: ")) == 1):
continue
loss_list.append(float(line.split("loss: ")[-1]))
plt.figure()
plt.plot(np.arange(len(loss_list)), loss_list)
plt.savefig("warmstart_plots/pure_SGD:"+str(kwargs)+".png")
plt.xlabel("Time in epochs")
plt.ylabel("Loss")
plt.close()
該代碼將正常SGDClassifier(只是任何線性分類器),並攔截verbose=1
標誌,然後將分割以從詳細打印中獲得損失。顯然這比較慢,但會給我們帶來損失並打印出來。
你能解釋一下你想要的東西嗎? –
這與你所要求的接近嗎? http://scikit-learn.org/stable/modules/generated/sklearn.metrics.log_loss.html – MichaelMMeskhi