日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python 實現樸素貝葉斯算法的示例

瀏覽:20日期:2022-07-09 13:02:40

特點

這是分類算法貝葉斯算法的較為簡單的一種,整個貝葉斯分類算法的核心就是在求解貝葉斯方程P(y|x)=[P(x|y)P(y)]/P(x) 而樸素貝葉斯算法就是在犧牲一定準確率的情況下強制特征x滿足獨立條件,求解P(x|y)就更為方便了 但基本上現實生活中,沒有任何關系的兩個特征幾乎是不存在的,故樸素貝葉斯不適合那些關系密切的特征

from collections import defaultdictimport numpy as npfrom sklearn.datasets import load_irisfrom sklearn.model_selection import train_test_splitfrom loguru import loggerclass NaiveBayesScratch(): '''樸素貝葉斯算法Scratch實現''' def __init__(self): # 存儲先驗概率 P(Y=ck) self._prior_prob = defaultdict(float) # 存儲似然概率 P(X|Y=ck) self._likelihood = defaultdict(defaultdict) # 存儲每個類別的樣本在訓練集中出現次數 self._ck_counter = defaultdict(float) # 存儲每一個特征可能取值的個數 self._Sj = defaultdict(float) def fit(self, X, y): ''' 模型訓練,參數估計使用貝葉斯估計 X: 訓練集,每一行表示一個樣本,每一列表示一個特征或屬性 y: 訓練集標簽 ''' n_sample, n_feature = X.shape # 計算每個類別可能的取值以及每個類別樣本個數 ck, num_ck = np.unique(y, return_counts=True) self._ck_counter = dict(zip(ck, num_ck)) for label, num_label in self._ck_counter.items(): # 計算先驗概率,做了拉普拉斯平滑處理,即計算P(y) self._prior_prob[label] = (num_label + 1) / (n_sample + ck.shape[0]) # 記錄每個類別樣本對應的索引 ck_idx = [] for label in ck: label_idx = np.squeeze(np.argwhere(y == label)) ck_idx.append(label_idx) # 遍歷每個類別 for label, idx in zip(ck, ck_idx): xdata = X[idx] # 記錄該類別所有特征對應的概率 label_likelihood = defaultdict(defaultdict) # 遍歷每個特征 for i in range(n_feature): # 記錄該特征每個取值對應的概率 feature_val_prob = defaultdict(float) # 獲取該列特征可能的取值和每個取值出現的次數 feature_val, feature_cnt = np.unique(xdata[:, i], return_counts=True) self._Sj[i] = feature_val.shape[0] feature_counter = dict(zip(feature_val, feature_cnt)) for fea_val, cnt in feature_counter.items(): # 計算該列特征每個取值的概率,做了拉普拉斯平滑,即為了計算P(x|y) feature_val_prob[fea_val] = (cnt + 1) / (self._ck_counter[label] + self._Sj[i]) label_likelihood[i] = feature_val_prob self._likelihood[label] = label_likelihood def predict(self, x): ''' 輸入樣本,輸出其類別,本質上是計算后驗概率 **注意計算后驗概率的時候對概率取對數**,概率連乘可能導致浮點數下溢,取對數將連乘轉化為求和 ''' # 保存分類到每個類別的后驗概率,即計算P(y|x) post_prob = defaultdict(float) # 遍歷每個類別計算后驗概率 for label, label_likelihood in self._likelihood.items(): prob = np.log(self._prior_prob[label]) # 遍歷樣本每一維特征 for i, fea_val in enumerate(x): feature_val_prob = label_likelihood[i] # 如果該特征值出現在訓練集中則直接獲取概率 if fea_val in feature_val_prob: prob += np.log(feature_val_prob[fea_val]) else: # 如果該特征沒有出現在訓練集中則采用拉普拉斯平滑計算概率 laplace_prob = 1 / (self._ck_counter[label] + self._Sj[i]) prob += np.log(laplace_prob) post_prob[label] = prob prob_list = list(post_prob.items()) prob_list.sort(key=lambda v: v[1], reverse=True) # 返回后驗概率最大的類別作為預測類別 return prob_list[0][0]def main(): X, y = load_iris(return_X_y=True) xtrain, xtest, ytrain, ytest = train_test_split(X, y, train_size=0.8, shuffle=True) model = NaiveBayesScratch() model.fit(xtrain, ytrain) n_test = xtest.shape[0] n_right = 0 for i in range(n_test): y_pred = model.predict(xtest[i]) if y_pred == ytest[i]: n_right += 1 else: logger.info('該樣本真實標簽為:{},但是Scratch模型預測標簽為:{}'.format(ytest[i], y_pred)) logger.info('Scratch模型在測試集上的準確率為:{}%'.format(n_right * 100 / n_test))if __name__ == '__main__': main()

以上就是python 實現樸素貝葉斯算法的示例的詳細內容,更多關于python實現樸素貝葉斯算法的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲人www| 久久精品超碰| 日韩一区自拍| 激情综合婷婷| 日本一区二区高清不卡| 久久免费黄色| 日韩天堂av| 日韩精品国产欧美| 久久久久黄色| 亚洲福利久久| 日韩欧美在线精品| 国产精品一区二区免费福利视频 | 亚洲一区二区网站| 91精品国产一区二区在线观看| 精品国产一区二区三区噜噜噜| 福利一区在线| 日韩视频在线一区二区三区 | 婷婷综合在线| 亚洲一区二区三区中文字幕在线观看| 亚洲精品日本| 免费在线亚洲欧美| 九色精品91| 亚洲精品日本| 国产精品精品| 久久不射网站| 精品国产18久久久久久二百| 亚洲国产专区校园欧美| 欧美一区二区三区久久精品| 久久激情婷婷| 青青草国产成人99久久| 99精品美女| 久久精品99国产国产精| 1024精品一区二区三区| 国产精品一区二区精品视频观看| 久久久精品午夜少妇| 日韩不卡手机在线v区| 亚洲成人va| 伊人久久一区| 国产精品精品国产一区二区| 综合干狼人综合首页| 国产videos久久| 丝袜亚洲另类欧美| 98精品视频| 日韩av中文字幕一区二区三区| 成人羞羞视频播放网站| 国产亚洲一区| 国产精品毛片| 91嫩草亚洲精品| 91成人在线网站| 在线视频日韩| 日韩深夜视频| 国产精品最新| 日韩一区二区久久| 国产一区二区三区不卡视频网站| 亚洲综合三区| 国产在线|日韩| 久久中文欧美| 久久精品72免费观看| 美女精品在线观看| 久久国产影院| 日本一区二区高清不卡| 国产精品亚洲欧美一级在线 | 亚洲激情国产| 日韩精品第一区| 国产精品最新自拍| 亚洲精品进入| 欧美在线亚洲| 久久婷婷亚洲| 亚洲精品88| 激情中国色综合| 久久超级碰碰| 国产麻豆一区二区三区精品视频| 蜜臀av国产精品久久久久| 不卡一区综合视频| 成人精品亚洲| 国产v综合v| 中国字幕a在线看韩国电影| 美女免费视频一区| 欧美一区自拍| 日韩av不卡一区二区| 亚洲欧美日韩专区| 蜜桃视频欧美| 欧美一级精品| 亚洲精品99| 国产精品色网| 蜜臀av一区二区在线免费观看| 在线看片不卡| 99亚洲视频| 亚洲影视一区| 日韩精品国产精品| 久久国产视频网| 免费一区二区三区在线视频| 欧美a级一区二区| 国产伊人久久| 成人片免费看| 婷婷成人在线| 国产韩日影视精品| 香蕉久久国产| 91成人福利| 久久99性xxx老妇胖精品| 久久一区国产| 亚洲综合电影| 999国产精品永久免费视频app| 国产一区亚洲| 中文一区一区三区免费在线观 | 久久激五月天综合精品| 欧美片第1页综合| 国产精品国码视频| 开心激情综合| 成人欧美一区二区三区的电影| 久久久久国产一区二区| 欧美精品自拍| 日本a级不卡| 精品中文在线| 91精品国产91久久久久久黑人| 午夜国产欧美理论在线播放| 亚洲一二av| 美女视频网站久久| 久久精品官网| 六月婷婷一区| 国产精品chinese| 亚洲最新无码中文字幕久久| 欧美亚洲激情| 亚洲精品福利| 麻豆一区二区99久久久久| 欧美日韩精品免费观看视完整| 国产毛片久久| 久久永久免费| 黄色成人精品网站| 国产精品最新| 国内精品福利| 人人爱人人干婷婷丁香亚洲| 日韩欧美国产精品综合嫩v| 欧美福利在线| 国产日产一区| 激情五月色综合国产精品| 日韩区一区二| 久久久久亚洲| 日本少妇精品亚洲第一区| 天堂中文在线播放| 日韩中文字幕在线一区| 国产精品二区不卡| 蜜桃免费网站一区二区三区| 精品国产a一区二区三区v免费| 国产精品日本欧美一区二区三区| 免费一级欧美在线观看视频 | 日韩不卡一区| 亚洲视频电影在线| av资源亚洲| 日本午夜精品一区二区三区电影| 日韩免费久久| 日韩三区四区| 亚洲福利国产| 麻豆免费精品视频| 免费的成人av| 日韩大片在线| 国产精品久久久一区二区| 女主播福利一区| 福利一区视频| 欧美色综合网| 午夜在线视频观看日韩17c| 福利一区二区三区视频在线观看| 老色鬼久久亚洲一区二区| 国产精品成久久久久| 日韩高清国产一区在线| 亚洲一级二级| 欧美成人一二区| 日韩精品中文字幕一区二区| 国产一区清纯| 日韩啪啪电影网| 久久不见久久见中文字幕免费| 丝袜国产日韩另类美女| 色88888久久久久久影院| 欧美激情一区| 亚洲人成亚洲精品| 美女少妇全过程你懂的久久| 福利欧美精品在线| 国产精品丝袜在线播放| 亚洲一区二区三区四区电影| 亚洲二区视频| 欧美精品高清| 国产精品一区二区三区www| 亚洲精品免费观看| 亚洲一区二区三区高清不卡| 日韩精品网站| 国产在线观看www| 国产成人免费av一区二区午夜| 欧美亚洲免费| 日本不卡视频一二三区| 亚洲制服少妇| 欧美成人综合| 午夜日韩av| 欧美一区二区性| 免费高潮视频95在线观看网站| 久久影院资源站| 精品三级av| 精品国产美女a久久9999| 国产精品日韩精品在线播放 | 日韩一二三区在线观看| 亚洲性视频在线|