機(jī)器學(xué)習(xí)算法應(yīng)用中常用技巧-2

7. 降維-PCA

n_components為降到多少維,用原數(shù)據(jù)fit后,再用transform轉(zhuǎn)換成降維后的數(shù)據(jù)。

from sklearn.decomposition import PCA
pca = PCA(n_components = 6)
pca.fit(good_data)
reduced_data = pca.transform(good_data)
reduced_data = pd.DataFrame(reduced_data, columns = ['Dimension 1', 'Dimension 2'])

8. 聚類-選擇類別數(shù)

用 silhouette coefficient 計(jì)算每個(gè)數(shù)據(jù)到中心點(diǎn)的距離,-1 (dissimilar) to 1 (similar) 根據(jù)這個(gè)系數(shù)來評價(jià)聚類算法的優(yōu)劣。

from sklearn.cluster import KMeans
from sklearn.metrics import silhouette_score
cluster = KMeans(n_clusters=2, random_state=0).fit(reduced_data)
preds = cluster.predict(reduced_data)
score = silhouette_score(reduced_data, preds)

選擇分?jǐn)?shù)最大的個(gè)數(shù)作為聚類的類別數(shù)。


9. 恢復(fù)維度

例如數(shù)據(jù),先經(jīng)過 log,又經(jīng)過 PCA降維, 要恢復(fù)回去,先用 pca.inverse_transform,再用 np.exp

log_centers = pca.inverse_transform(centers)
true_centers = np.exp(log_centers)
true_centers = pd.DataFrame(np.round(true_centers), columns = data.keys())

數(shù)據(jù)變化:


10. 自定義accuracy

分類問題可以自己寫accuracy的函數(shù)

def accuracy_score(truth, pred):
    """ Return accuracy score for input truth and prediction"""
    
    if len(truth)==len(pred):
        return "Accuracy for prediction: {:.2f}%.".format((truth==pred).mean()*100)
    else:
        return "Numbers do not match!"
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容