久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python机器学习笔记:ID3决策树算法实战

發布時間:2024/1/18 python 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python机器学习笔记:ID3决策树算法实战 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.


  ID3算法是一種貪心算法,用來構造決策樹,ID3算法起源于概念學習系統(CLS),以信息熵的下降速度為選取測試屬性的標準,即在每一個節點選取還尚未被用來劃分的具有最高信息增益的屬性作為劃分標準,然后繼續這個過程,直到生成的決策樹能完美的分類訓練樣例。

? ? ? ?在此之前,推薦大家可以多在FlyAI競賽服務平臺多參加訓練和競賽,以此來提升自己的能力。FlyAI是為AI開發者提供數據競賽并支持GPU離線訓練的一站式服務平臺。每周免費提供項目開源算法樣例,支持算法能力變現以及快速的迭代算法模型。

ID3算法的背景知識

  ID3算法最早是由羅斯昆蘭(J. Ross Quinlan)于1975年在悉尼大學提出的一種分類預測算法,算法的核心是“信息熵”。ID3算法通過計算每個屬性的信息增益,認為信息增益高的是好屬性,每次劃分選取信息增益最高的屬性為劃分標準,重復這個過程,直至生成一個能完美分類訓練樣例的決策樹。

  決策樹是對數據進行分類,以此達到預測的目的。該決策樹方法先根據訓練集數據形成決策樹,如果該樹不能對所有對象給出正確的分類,那么選擇一些例外加入到訓練集數據中,重復該過程一直到形成正確的決策集。決策樹代表著決策集的樹形結構。

  決策樹由決策結點、分支和葉子組成。決策樹中最上面的結點為根結點,每個分支是一個新的決策結點,或者是樹的葉子。每個決策結點代表一個問題或決策,通常對應于待分類對象的屬性。每一個葉子結點代表一種可能的分類結果。沿決策樹從上到下遍歷的過程中,在每個結點都會遇到一個測試,對每個結點上問題的不同的測試輸出導致不同的分支,最后會到達一個葉子結點,這個過程就是利用決策樹進行分類的過程,利用若干個變量來判斷所屬的類別。

ID3算法數據描述

所使用的樣本數據有一定的要求,ID3是:

  描述-屬性-值相同的屬性必須描述每個例子和有固定數量的價值觀。

  預定義類-實例的屬性必須已經定義的,也就是說,他們不是學習的ID3。

  離散類-類必須是尖銳的鮮明。連續類分解成模糊范疇(如金屬被“努力,很困難的,靈活的,溫柔的,很軟”都是不可信的。

  足夠的例子——因為歸納概括用于(即不可查明)必須選擇足夠多的測試用例來區分有效模式并消除特殊巧合因素的影響。

  ID3決定哪些屬性如何是最好的。一個統計特性,被稱為信息增益,使用熵得到給定屬性衡量培訓例子帶入目標類分開。信息增益最高的信息(信息是最有益的分類)被選擇。為了明確增益,我們首先從信息論借用一個定義,叫做熵。每個屬性都有一個熵。

ID3決策樹概述

  ID3決策樹是一種非常重要的用來處理分類問題的結構,它形似一個嵌套N層的IF…ELSE結構,但是它的判斷標準不再是一個關系表達式,而是對應的模塊的信息增益。它通過信息增益的大小,從根節點開始,選擇一個分支,如同進入一個IF結構的statement,通過屬性值的取值不同進入新的IF結構的statement,直到到達葉子節點,找到它所屬的“分類”標簽。

  它的流程圖是一顆無法保證平衡的多叉樹,每一個父節點都是一個判斷模塊,通過判斷,當前的向量會進入它的某一個子節點中,這個子節點是判斷模塊或者終止模塊(葉子節點),當且僅當這個向量到達葉子節點,它也就找到了它的“分類”標簽。

  ID3決策樹通過一個固定的訓練集是可以形成一顆永久的“樹”的,這課樹可以進行保存并且運用到不同的測試集中,唯一的要求就是測試集和訓練集需要是結構等價的。這個訓練過程就是根據訓練集創建規則的過程,這也是機器學習的過程。

  ID3決策樹的一個巨大缺陷是:它將產生過度匹配問題。這里在不討論信息增益的前提下,有這樣一個例子:人的屬性中有性別和年齡兩個屬性,由于人的性別只有男和女兩種,年齡有很多種分支,當它有超過兩個分支的時候,在用信息增益選擇新的屬性的時候,會選擇年齡而不是性別,因為ID3決策樹在使用信息增益來劃分數據集的時候會傾向于選擇屬性分支更多的一個;另外一個缺陷是,人的年齡假定為1~100,如果不進行離散化,即區間的劃分,那么在選擇年齡這個屬性的時候,這棵決策樹會產生最多100個分支,這是非??膳露依速M空間和效率的,考慮這 樣一種情況:兩個人的其他所有屬性完全相同,他們的分類都是"A",然而在年齡這一個樹節點中分支了,而這個年齡下有一個跟這兩個人很像,卻不屬于“A”類別的人,由于ID3決策樹無法處理連續性數據,那么這兩個人很有可能被劃分到兩個分類中,這是不合理的,這也是C4.5決策樹考慮的問題。

?ID3決策樹算法推導

  如果以前沒有接觸過決策樹,完全不用擔心,它的概念非常簡單,即使不知道它也可以通過簡單的圖像了解其工作原理,下圖就是一個決策樹,正方形代表判斷模型(decision block),橢圓形代表終止模塊(terminating block),表示已經得出結論,可以終止運行。從判斷模塊引出的左右箭頭稱作分支(branch),它首先檢測發送郵件域名地址。如果地址為myEmployer.com,則將其分類“無聊時需要閱讀的郵件”中。如果郵件不是來自這個域名,則檢查郵件內容里是否包含單詞曲棍球,如果包含則將郵件歸類到“需要及時處理的盆友郵件”,如果不包含則將郵件歸類到“無需閱讀的垃圾郵件”。

  決策樹很多任務都是為了數據中蘊含的知識信息,因此決策樹可以使用不熟悉的數據集合,并從中提取出一系列的規則,機器學習算法最終將使用這些機器從數據及中創造的規則。專家系統中經常使用決策樹,而且決策樹給出結果往往可以匹敵在當前領域具有幾十年工作經驗的人類專家。

  現在我們已經大致了解了決策樹可以完成哪些任務,接下來我們將學習如何從一堆原始數據中構造決策樹,首先我們討論構造決策樹的方法,以及如何編寫決策樹的Python代碼;接著剔除一些度量算法成功率的方法;最后使用遞歸建立分類器,并且使用Matplotlib繪制決策樹圖,構造完成決策樹分類器之后,我們將輸入一些隱形眼鏡的處方數據,并由決策樹分類器預測需要的鏡片類型。

1. 決策樹的構造

  在一步步地構造決策樹算法的時候,首先我們討論數學上如何使用信息論劃分數據集,然后編寫代碼將理論應用到具體的數據集上,最后編寫代碼構建決策樹。

  在構造決策樹時,我們需要解決的第一個問題就是,當前數據集上哪個特征在劃分數據分類時起決定性作用。為了找到決定性的特征,劃分出最好的結果,我們必須評估每個特征。完成測試之后,原始數據集就被劃分為幾個數據子集,這些數據子集會分布在第一個決策點的所有分支上,如果某個分支下的數據屬于同一類型,則當前無需閱讀的垃圾郵件已經正確的劃分數據分類,無需進一步對數據集進行分割,如果數據子集內的數據不屬于同一類型,則需要重復劃分數據子集的過程,如何劃分數據子集的算法和劃分原始數據集的方法相同,知道所有具有相同類型的數據均在一個數據子集內。

  創建分支的偽代碼函數createBranch() 如下所示:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

檢測數據集中的每個子項是否屬于同一分類:

????If? so? retrun?? 類標簽;

????Else

????????????尋找劃分數據集的最好特征

?

????????????劃分數據集

?

????????????創建分支節點

?

????????????????for??每個劃分的子集

?

????????????????????調用函數createBranch并增加返回結果到分支節點中

?????????????????

????????????????return??分支節點

  上面的偽代碼createBranch是一個遞歸函數,在倒數第二行直接調用了它自己,后面我們將把上面的偽代碼轉換為Python代碼,這里我們需要了解一下算法是如何劃分數據集的。

1.1 決策樹的一般流程

  • (1) 收集數據:可以使用任何方法
  • (2) 準備數據:樹構造算法只適用于標稱型數據,因此數值型數據必須離散化
  • (3) 分析數據:可以使用任何方法,構造樹完成之后,我們應該檢查圖像是否符合預期
  • (4) 訓練算法:構造樹的數據結構
  • (5) 測試算法:使用經驗樹計算錯誤率
  • (6)使用算法:此步驟可以適用于任何監督學習算法,而使用決策樹可以更好的理解數據的內在含義

1.2 劃分特征

  一些決策樹算法采用二分法劃分數據,此處不采用這種方法,本次將使用ID3算法劃分數據集,該算法處理如何劃分數據集,何時停止劃分數據集。如果依據某個屬性劃分數據將會產生4個可能的值,我們將數據劃分為四塊,并創建四個不同的分支,每次劃分數據集時我們只選取一個特征屬性,如果訓練集中存在20個特征,第一次我們選擇哪個特征作為劃分的參考屬性呢?

  下表的數據包含5個海洋動物,特征包括:不浮出水面是否可以生存,以及是否有腳趾。我們可以將這些動物劃分為兩類:魚類和非魚類,現在我們想要決定依據第一個特征還是第二個特征劃分數據,那么那個特征可以作為第一個劃分點呢?讓我們繼續學習。

?1.3? 信息增益

  劃分數據集的大原則是:將無序的數據變得更加有序。我們可以使用多種方法劃分數據集,但是每種方法都有各自的優缺點。組織雜亂無章數據的一種方法就是使用信息論度量信息,信息論是量化處理信息的分支科學。我們可以在劃分數據之前使用信息論量化度量信息的內容。

  在劃分數據集之前之后信息發生的變化成為信息增益,知道如何計算信息增益,我們就可以計算每個特征值劃分數據集獲得的信息增益,獲得信息增益最高的特征就是最好的選擇。

  在可以評測哪種數據劃分方式是最好的數據劃分之前,我們必須學習如何計算信息增益。集合信息的度量方式稱為香農熵或者簡稱為熵(這名字來源于信息論之父克勞德*香農)

  熵定義為信息的期望值,在明白這個概念之前,我們必須知道信息的定義,如果待分類的事務可能劃分在多個分類之中,則符號Xi的信息定義為:

  其中P(Xi)是選擇該分類的概率。

  為了計算熵,我們需要計算所有類別所有可能值包含的信息期望值,通過下面的公式得到:

  其中n是分類的數目。

代碼如下:

  此代碼是使用Python計算給定數據集的信息熵。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

from?math import log

?

# 計算數據的熵(entropy)

def calcShannonRnt(dataSet):

????# 數據條數,計算數據集中實例的總數

????numEntries = len(dataSet)

????labelCounts = {}

????for?featVec?in?dataSet:

????????# 每行數據的最后一個類別(也就是標簽)

????????currentLable = featVec[-1]

????????if?currentLable not?in?labelCounts.keys():

????????????labelCounts[currentLable] = 0

????????# 統計有多少個類以及每個類的數量

????????labelCounts[currentLable]? += 1

????shannonEnt = 0.0

????for?key?in?labelCounts:

????????# 計算單個類的熵值

????????prob =?float(labelCounts[key]) / numEntries

????????# 累加每個類的熵值

????????shannonEnt -= prob * log(prob , 2)

????return?shannonEnt

  下面我們創建一個簡單的數據集(此處我們使用機器學習實戰中的簡單魚鑒定數據集):

1

2

3

4

5

6

7

8

9

# 創建數據集

def createDataSet():

????dataSet = [[1,1,'yes'],

???????????????[1,1,'yes'],

???????????????[1,0,'no'],

???????????????[0,1,'no'],

???????????????[0,1,'no']]

????labels = ['no surfacing','flippers']

????return?dataSet,labels

  代碼執行結果:

1

2

3

4

5

6

7

8

9

10

11

12

myData,labels = createDataSet()

print(myData)

print(labels)

?

shannonEnt = calcShannonRnt(myData)

print(shannonEnt)

?

'''

[[1, 1,?'yes'], [1, 1,?'yes'], [1, 0,?'no'], [0, 1,?'no'], [0, 1,?'no']]

['no surfacing',?'flippers']

0.9709505944546686

'''

  從結果來看,熵為0.97,熵越高,則混合的數據也越多,隨機變量的不確定性越大,我們可以在數據集中添加更多的分類,觀察熵是如何變化的。

?2. 劃分數據集

  上面我們學習了如何度量數據集的無序程度,分類算法除了需要測量信息熵,還需要劃分數據集,度量劃分數據集的熵,以便判斷當前是否正確地劃分了數據集,我們將對每個特征劃分數據集的結果計算一次信息熵,然后判斷按照哪個特征劃分數據集是最好的劃分方式。想象一個分布在二維空間的數據散點圖,需要在數據之間畫條線,將他們分成兩部分,我們應該按照x軸還是y軸劃分呢?

  按照給定特征劃分數據集代碼:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

# 按照給定特征劃分數據集

def splitDataSet(dataSet,axis,value):

????'''

?

????:param dataSet: 待劃分的數據集

????:param axis: 劃分數據集的特征

????:param value: 特征的返回值

????:return:

????'''

????retDataSet = []

????for?featVec?in?dataSet:

????????# 如果發現符合要求的特征,將其添加到新創建的列表中

????????if?featVec[axis] == value:

????????????reduceFeatVec = featVec[:axis]

????????????reduceFeatVec.extend(featVec[axis+1:])

????????????retDataSet.append(reduceFeatVec)

?

????return?retDataSet

  我們使用劃分數據集測試一下,可以看到劃分數據集結果如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

myData,labels = createDataSet()

print(myData)

print(labels)

?

splitDataSetVal = splitDataSet(myData,0,1)

print(splitDataSetVal)

splitDataSetVal = splitDataSet(myData,0,0)

print(splitDataSetVal)

?

'''

[[1, 1,?'yes'], [1, 1,?'yes'], [1, 0,?'no'], [0, 1,?'no'], [0, 1,?'no']]

['no surfacing',?'flippers']

[[1,?'yes'], [1,?'yes'], [0,?'no']]

[[1,?'no'], [1,?'no']]

'''

  接下來,我們將遍歷整個數據集,循環計算香農熵和splitDataSet()函數,找到最好的特征劃分方式,熵計算將會告訴我們如何劃分數據集是最好的數據組織方式。

  選擇最好的數據集劃分方式代碼:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

# 選擇最好的數據集劃分方式

def chooseBestFeatureTpSplit(dataSet):

????'''

????????此函數中調用的數據滿足以下要求

????????1,數據必須是一種由列表元素組成的列表,而且所有列表元素都要具有相同的數據長度

????????2,數據的最后一列或者實例的最后一個元素是當前實例的類別標簽

????:param dataSet:

????:return:

????'''

????numFeatures = len(dataSet[0]) - 1

????# 原始的熵

????baseEntropy = calcShannonRnt(dataSet)

????bestInfoGain = 0.0

????bestFeature = -1

????for?i?in?range(numFeatures):

????????# 創建唯一的分類標簽列表

????????featList = [example[i]?for?example?in?dataSet]

????????uniqueVals =?set(featList)

????????newEntropy = 0.0

????????for?value?in?uniqueVals:

????????????# 計算每種劃分方式的信息熵,并對所有唯一特征值得到的熵求和

????????????subDataSet = splitDataSet(dataSet,i,value)

????????????prob = len(subDataSet)/float(len(dataSet))

????????????# 按照特征分類后的熵

????????????newEntropy += prob * calcShannonRnt(subDataSet)

????????infoGain = baseEntropy - newEntropy

????????if?(infoGain > bestInfoGain):

????????????# 計算最好的信息增益,信息增益越大,區分樣本的能力越強,根據代表性

????????????bestInfoGain = infoGain

????????????bestFeature = i

????return?bestFeature

  測試代碼,得到結果:

1

2

3

4

5

6

7

8

9

10

11

myData,labels = createDataSet()

print(myData)

print(labels)

?

bestFeatureRes = chooseBestFeatureTpSplit(myData)

print(bestFeatureRes)

'''

[[1, 1,?'yes'], [1, 1,?'yes'], [1, 0,?'no'], [0, 1,?'no'], [0, 1,?'no']]

['no surfacing',?'flippers']

0

'''

  結果告訴我們第0個特征是最好的用于劃分數據集的特征。如果按此特征分類,第一個海洋動物分組將有兩個屬于魚類,兩個屬于非魚類,另一個分組則只有一個非魚類。

  假設我們按照第一個特征屬性劃分數據,也就是說第一個特征是1的放在一個組,第一個特征是0的放在另一個組,數據一致性如何?按照上述的方法劃分數據集,第一個特征為1的海洋生物分組將有兩個屬于魚類,一個屬于非魚類;另一個分組則全部屬于非魚類。

3 . 遞歸構建決策樹

???  總結一下構建決策樹的工作原理:得到原始數據集,然后基于最好的屬性值劃分數據集,由于特征值可能多于兩個,因此可能存在大于兩個分支的數據集劃分。第一次劃分之后,數據將向下傳遞到樹分支的下一個節點,在這個節點上,我們可以再次劃分數據。因此我們可以采用遞歸的原則處理數據集。

  遞歸結束的條件是:程序遍歷完所有劃分數據集的屬性,或者每個分支下的所有實例都具有相同的分類。如果所有實例具有相同的分類,則得到一個葉子節點護著終止塊。任何到達葉子節點的數據必然屬于葉子節點的分類,參見下圖:

  第一個結束條件使得算法可以終止,我們甚至可以設置算法可以劃分的最大分組數目。當然目前我們只需要在算法開始運行前計算列的數目,查看算法是否使用了所有屬性即可,如果數據集已經處理了所有屬性,但是類標簽依然不是唯一的,此時我們需要決定如何定義該葉子節點,在這種情況下,我們通常會采用多數表決的方法決定該葉子節點的分類。

  按照分類后類別數量排序代碼:

1

2

3

4

5

6

7

8

9

10

# 按照分類后類別數量排序

def majorityCnt(classList):

????classCount = {}

????for?vote?in?classList:

????????if?vote not?in?classCount.keys():

????????????classCount[vote] = 0

????????classCount[vote] += 1

????sortedClassCount = sorted(classCount.items(),

??????????????????????????????key=operator.itemgetter(1),reverse=True)

????return?sortedClassCount[0][0]

  創建樹的函數代碼:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

# 創建樹的函數代碼

def createTree(dataSet,labels):

????'''

?

????????:param dataSet:? 輸入的數據集

????????:param labels:? 標簽列表(包含了數據集中所有特征的標簽)

????????:return:

????????'''

????# classList 包含了數據集中所有類的標簽

????classList = [example[-1]?for?example?in?dataSet]

????# 類別完全相同則停止繼續劃分

????if?classList.count(classList[0]) == len(classList):

????????return?classList[0]

????# 遍歷完所有特征時返回出現次數最多的

????if?len(dataSet[0])? == 1:

????????return?majorityCnt(classList)

????bestFeat = chooseBestFeatureTpSplit(dataSet)

????bestFeatLabel = labels[bestFeat]

????# 字典myTree存儲了樹的所有信息,這對于后面繪制樹形圖很重要

????myTree = {bestFeatLabel:{}}

????del(labels[bestFeat])

????# 得到列表包含的所有屬性值

????featValues = [example[bestFeat]?for?example?in?dataSet]

????uniqueVals =?set(featValues)

????for?value?in?uniqueVals:

????????subLabels =labels[:]

????????myTree[bestFeatLabel][value] = createTree(splitDataSet(dataSet,bestFeat,value),

??????????????????????????????????????????????????subLabels)

  運行代碼結果如下:

1

2

3

4

5

6

7

8

9

10

11

myData,labels = createDataSet()

print(myData)

print(labels)

?

myTree = createTree(myData,labels)

print(myTree)

'''

[[1, 1,?'yes'], [1, 1,?'yes'], [1, 0,?'no'], [0, 1,?'no'], [0, 1,?'no']]

['no surfacing',?'flippers']

{'no surfacing': {0:?'no', 1: {'flippers': {0:?'no', 1:?'yes'}}}}

'''

  從結果來看,變量myTree包含了很多代表樹結構信息的嵌套字典,從左邊開始,第一次關鍵字nosurfacing是第一個劃分數據集的特征名稱,該關鍵字的值也是另一個數據字典,第二個關鍵字是no? ?surfacing特征劃分的數據集,這些關鍵字的值時no? surfacing節點的子節點,這些值可能是類標簽,也可能是另一個數據字典,如果值時類標簽,則該子節點是葉子節點;如果值時另一個數據字典,則子節點是一個判斷節點,這種格式結構不斷重復就構成了整棵樹。

4 . 使用Matplotlib注解繪制樹形圖

  上面我們學習了如何從數據集中創建樹,然而字典的表示形式非常不易于理解,而且直接繪制圖形也比較困難,這里我們學習使用Matplotlib庫創建樹形圖。決策樹的主要優點就是直觀易于理解,如果不能將其直觀的顯示出來,就無法發揮其優勢。

  Matplotlib可以對文字著色并提供多種形狀以供選擇,而且我們還可以反轉箭頭,將它指向文本框而不是數據點。

  使用文本注解繪制樹節點代碼:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

import matplotlib.pyplot?as?plt

?

# 定義文本框和箭頭格式(樹節點格式的常量)

decisionNode = dict(boxstyle='sawtooth',fc='0.8')

leafNode = dict(boxstyle='round4',fc='0.8')

arrows_args = dict(arrowstyle='<-')

?

# 繪制帶箭頭的注解

def plotNode(nodeTxt,centerPt,parentPt,nodeType):

????createPlot.ax1.annotate(nodeTxt,xy=parentPt,

????????????????????????????xycoords='axes fraction',

????????????????????????????xytext=centerPt,textcoords='axes fraction',

????????????????????????????va='center',ha='center',bbox=nodeType,

????????????????????????????arrowprops=arrows_args)

?

def createPlot():

????# 創建一個新圖形并清空繪圖區

????fig = plt.figure(1,facecolor='white')

????fig.clf()

????createPlot.ax1 = plt.subplot(111,frameon=False)

????plotNode('a decision node',(0.5,0.1),(0.1,0.5),decisionNode)

????plotNode('a leaf node',(0.8,0.1),(0.3,0.8),leafNode)

????plt.show()

?

if?__name__ ==?'__main__':

????createPlot()

  結果:

?

?5 . 構造決策樹

  繪制一顆完整的樹需要一些技巧。我們雖然有x,y坐標,但是如何放置所有的樹節點卻是個問題,我們必須知道有多少個葉子節點,以便可以正確確定x軸的長度我們還需要知道樹有多少層,以便可以正確確定y軸的高度,這里我們定義兩個新函數getNumLeafs() 和getTreeDepth(),來獲取葉節點數目和樹的層數,如下:

  獲取葉子節點的數目和樹的層數代碼:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

import matplotlib.pyplot?as?plt

?

def myTree():

????treeData = {'no surfacing': {0:?'no', 1: {'flippers': {0:?'no', 1:?'yes'}}}}

????return?treeData

?

# 獲取葉子節點的數目

def getNumLeafs(myTree):

????# 初始化結點數

????numLeafs = 0

????firstSides = list(myTree.keys())

????# 找到輸入的第一個元素,第一個關鍵詞為劃分數據集類別的標簽

????firstStr = firstSides[0]

????secondDect = myTree[firstStr]

????for?key?in?secondDect.keys():

????????# 測試節點的數據類型是否為字典

????????if?type(secondDect[key]).__name__ ==?'dict':

????????????numLeafs += getNumLeafs(secondDect[key])

????????else:

????????????numLeafs +=1

????return?numLeafs

?

# 獲取樹的層數

def getTreeDepth(myTree):

????maxDepth = 0

????firstSides = list(myTree.keys())

????firstStr = firstSides[0]

????secondDict = myTree[firstStr]

????for?key?in?secondDict.keys():

????????# 測試節點的數據類型是否為字典

????????if?type(secondDict[key]).__name__ ==?'dict':

????????????thisDepth = 1 + getTreeDepth(secondDict[key])

????????else:

????????????thisDepth = 1

????????if?thisDepth > maxDepth:

????????????maxDepth = thisDepth

?

????return?maxDepth

?

if?__name__ ==?'__main__':

????myData? = myTree()

????LeafNum = getNumLeafs(myData)

????TreeDepth = getTreeDepth(myData)

????print(LeafNum)

????print(TreeDepth)

  測試結果如下:

1

2

3

2

  下面我們將前面的方法組合在一起,得到決策樹,此時我們需要更新畫圖的代碼:

完整代碼如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

import matplotlib.pyplot?as?plt

?

# 定義文本框和箭頭格式(樹節點格式的常量)

decisionNode = dict(boxstyle='sawtooth',fc='0.8')

leafNode = dict(boxstyle='round4',fc='0.8')

arrows_args = dict(arrowstyle='<-')

?

# 繪制帶箭頭的注解

def plotNode(nodeTxt,centerPt,parentPt,nodeType):

????createPlot.ax1.annotate(nodeTxt,xy=parentPt,

????????????????????????????xycoords='axes fraction',

????????????????????????????xytext=centerPt,textcoords='axes fraction',

????????????????????????????va='center',ha='center',bbox=nodeType,

????????????????????????????arrowprops=arrows_args)

?

?

# 在父子節點間填充文本信息

def plotMidText(cntrPt,parentPt,txtString):

????xMid = (parentPt[0] - cntrPt[0]) / 2.0 + cntrPt[0]

????yMid = (parentPt[1] - cntrPt[1]) / 2.0 + cntrPt[1]

????createPlot.ax1.text(xMid,yMid,txtString, va="center", ha="center", rotation=30)

?

def plotTree(myTree,parentPt,nodeTxt):

????# 求出寬和高

????numLeafs = getNumLeafs(myData)

????depth = getTreeDepth(myData)

????firstStides = list(myTree.keys())

????firstStr = firstStides[0]

????# 按照葉子結點個數劃分x軸

????cntrPt = (plotTree.xOff + (0.1 +?float(numLeafs)) /2.0/plotTree.totalW,plotTree.yOff)

????plotMidText(cntrPt,parentPt,nodeTxt)

????plotNode(firstStr,cntrPt,parentPt,decisionNode)

????secondDict = myTree[firstStr]

????# y方向上的擺放位置 自上而下繪制,因此遞減y值

????plotTree.yOff = plotTree.yOff - 1.0/plotTree.totalD

????for?key?in?secondDict.keys():

????????if?type(secondDict[key]).__name__? ==?'dict':

????????????plotTree(secondDict[key],cntrPt,str(key))

????????else:

????????????plotTree.xOff = plotTree.xOff + 1.0 / plotTree.totalW? # x方向計算結點坐標

????????????plotNode(secondDict[key], (plotTree.xOff, plotTree.yOff), cntrPt, leafNode)? # 繪制

????????????plotMidText((plotTree.xOff, plotTree.yOff), cntrPt, str(key))? # 添加文本信息

????plotTree.yOff = plotTree.yOff + 1.0 / plotTree.totalD? # 下次重新調用時恢復y

?

def myTree():

????treeData = {'no surfacing': {0:?'no', 1: {'flippers': {0:?'no', 1:?'yes'}}}}

????return?treeData

?

# 獲取葉子節點的數目

def getNumLeafs(myTree):

????# 初始化結點數

????numLeafs = 0

????firstSides = list(myTree.keys())

????# 找到輸入的第一個元素,第一個關鍵詞為劃分數據集類別的標簽

????firstStr = firstSides[0]

????secondDect = myTree[firstStr]

????for?key?in?secondDect.keys():

????????# 測試節點的數據類型是否為字典

????????if?type(secondDect[key]).__name__ ==?'dict':

????????????numLeafs += getNumLeafs(secondDect[key])

????????else:

????????????numLeafs +=1

????return?numLeafs

?

# 獲取樹的層數

def getTreeDepth(myTree):

????maxDepth = 0

????firstSides = list(myTree.keys())

????firstStr = firstSides[0]

????secondDict = myTree[firstStr]

????for?key?in?secondDict.keys():

????????# 測試節點的數據類型是否為字典

????????if?type(secondDict[key]).__name__ ==?'dict':

????????????thisDepth = 1 + getTreeDepth(secondDict[key])

????????else:

????????????thisDepth = 1

????????if?thisDepth > maxDepth:

????????????maxDepth = thisDepth

?

????return?maxDepth

?

# 主函數

def createPlot(inTree):

????# 創建一個新圖形并清空繪圖區

????fig = plt.figure(1,facecolor='white')

????fig.clf()

????axprops = dict(xticks=[], yticks=[])

????createPlot.ax1 = plt.subplot(111, frameon=False, **axprops)? # no ticks

????# createPlot.ax1 = plt.subplot(111, frameon=False) #ticks for demo puropses

????plotTree.totalW =?float(getNumLeafs(inTree))

????plotTree.totalD =?float(getTreeDepth(inTree))

????plotTree.xOff = -0.5 / plotTree.totalW

????plotTree.yOff = 1.0

????plotTree(inTree, (0.5, 1.0),?'')

????plt.show()

?

?

if?__name__ ==?'__main__':

????myData? = myTree()

????myData['no surfacing'][3] =?'maybe'

????print(myData)

????# LeafNum = getNumLeafs(myData)

????# TreeDepth = getTreeDepth(myData)

????# print(LeafNum)

????# print(TreeDepth)

????createPlot(myData)

  

6 . 測試算法:使用決策樹執行分類

  依靠訓練數據構造了決策樹之后,我們可以將它用于實際數據的分類,在執行數據分類時,需要決策樹以及用于構造樹的標簽向量。然后,程序比較測試數據與決策樹上的數值,遞歸執行該過程直到進入葉子節點,最后將測試數據定義為葉子節點所屬的類型。

 使用決策樹的分類函數代碼:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

from?math import log

import?operator

?

# 計算數據的熵(entropy)

def calcShannonRnt(dataSet):

????# 數據條數,計算數據集中實例的總數

????numEntries = len(dataSet)

????labelCounts = {}

????for?featVec?in?dataSet:

????????# 每行數據的最后一個類別(也就是標簽)

????????currentLable = featVec[-1]

????????if?currentLable not?in?labelCounts.keys():

????????????labelCounts[currentLable] = 0

????????# 統計有多少個類以及每個類的數量

????????labelCounts[currentLable]? += 1

????shannonEnt = 0.0

????for?key?in?labelCounts:

????????# 計算單個類的熵值

????????prob =?float(labelCounts[key]) / numEntries

????????# 累加每個類的熵值

????????shannonEnt -= prob * log(prob , 2)

????return?shannonEnt

?

# 創建數據集

def createDataSet():

????dataSet = [[1,1,'yes'],

???????????????[1,1,'yes'],

???????????????[1,0,'no'],

???????????????[0,1,'no'],

???????????????[0,1,'no']]

????labels = ['no surfacing','flippers']

????# dataSet = [['Long', 'Think', 'male'],

????#??????????? ['Short', 'Think', 'male'],

????#??????????? ['Short', 'Think', 'male'],

????#??????????? ['Long', 'Thin', 'female'],

????#??????????? ['Short', 'Thin', 'female'],

????#??????????? ['Short', 'Think', 'female'],

????#??????????? ['Long', 'Think', 'female'],

????#??????????? ['Long', 'Think', 'female']]

????# labels = ['hair', 'voice']

????return?dataSet,labels

?

# 按照給定特征劃分數據集

def splitDataSet(dataSet,axis,value):

????'''

?

????:param dataSet: 待劃分的數據集

????:param axis: 劃分數據集的特征

????:param value: 特征的返回值

????:return:

????'''

????retDataSet = []

????for?featVec?in?dataSet:

????????# 如果發現符合要求的特征,將其添加到新創建的列表中

????????if?featVec[axis] == value:

????????????reduceFeatVec = featVec[:axis]

????????????reduceFeatVec.extend(featVec[axis+1:])

????????????retDataSet.append(reduceFeatVec)

?

????return?retDataSet

?

# 選擇最好的數據集劃分方式

def chooseBestFeatureTpSplit(dataSet):

????'''

????????此函數中調用的數據滿足以下要求

????????1,數據必須是一種由列表元素組成的列表,而且所有列表元素都要具有相同的數據長度

????????2,數據的最后一列或者實例的最后一個元素是當前實例的類別標簽

????:param dataSet:

????:return:

????'''

????numFeatures = len(dataSet[0]) - 1

????# 原始的熵

????baseEntropy = calcShannonRnt(dataSet)

????bestInfoGain = 0.0

????bestFeature = -1

????for?i?in?range(numFeatures):

????????# 創建唯一的分類標簽列表

????????featList = [example[i]?for?example?in?dataSet]

????????uniqueVals =?set(featList)

????????newEntropy = 0.0

????????for?value?in?uniqueVals:

????????????# 計算每種劃分方式的信息熵,并對所有唯一特征值得到的熵求和

????????????subDataSet = splitDataSet(dataSet,i,value)

????????????prob = len(subDataSet)/float(len(dataSet))

????????????# 按照特征分類后的熵

????????????newEntropy += prob * calcShannonRnt(subDataSet)

????????infoGain = baseEntropy - newEntropy

????????if?(infoGain > bestInfoGain):

????????????# 計算最好的信息增益,信息增益越大,區分樣本的能力越強,根據代表性

????????????bestInfoGain = infoGain

????????????bestFeature = i

????return?bestFeature

?

# 按照分類后類別數量排序

def majorityCnt(classList):

????classCount = {}

????for?vote?in?classList:

????????if?vote not?in?classCount.keys():

????????????classCount[vote] = 0

????????classCount[vote] += 1

????sortedClassCount = sorted(classCount.items(),

??????????????????????????????key=operator.itemgetter(1),reverse=True)

????return?sortedClassCount[0][0]

?

# 創建樹的函數代碼

def createTree(dataSet,labels):

????'''

?

????????:param dataSet:? 輸入的數據集

????????:param labels:? 標簽列表(包含了數據集中所有特征的標簽)

????????:return:

????????'''

????# classList 包含了數據集中所有類的標簽

????classList = [example[-1]?for?example?in?dataSet]

????# 類別完全相同則停止繼續劃分

????if?classList.count(classList[0]) == len(classList):

????????return?classList[0]

????# 遍歷完所有特征時返回出現次數最多的

????if?len(dataSet[0])? == 1:

????????return?majorityCnt(classList)

????bestFeat = chooseBestFeatureTpSplit(dataSet)

????bestFeatLabel = labels[bestFeat]

????# 字典myTree存儲了樹的所有信息,這對于后面繪制樹形圖很重要

????myTree = {bestFeatLabel:{}}

????del(labels[bestFeat])

????# 得到列表包含的所有屬性值

????featValues = [example[bestFeat]?for?example?in?dataSet]

????uniqueVals =?set(featValues)

????for?value?in?uniqueVals:

????????subLabels =labels[:]

????????myTree[bestFeatLabel][value] = createTree(splitDataSet(dataSet,bestFeat,value),

??????????????????????????????????????????????????subLabels)

?

????return?myTree

?

# 使用決策樹的分類函數

def classify(inputTree ,featLabels,testVec):

????firstSides = list(inputTree.keys())

????firstStr = firstSides[0]

????secondDict = inputTree[firstStr]

????# print('featLables:',featLabels)

????featIndex = featLabels.index(firstStr)

????for?key?in?secondDict.keys():

????????# 若該特征值等于當前key,yes往下走

????????if?testVec[featIndex]? == key:

????????????if?type(secondDict[key]).__name__ ==?'dict':

????????????????classLabel = classify(secondDict[key],featLabels,testVec)

????????????else:

????????????????classLabel = secondDict[key]

????return?classLabel

#使用決策樹來分類

def classify11(inputTree,featLabels,testVec):

????#python3.X

????firstSides = list(inputTree.keys())

????firstStr = firstSides[0]? # 找到輸入的第一個元素

????# python3.X

????secondDict=inputTree[firstStr]? #baocun在secondDict中

????featIndex=featLabels.index(firstStr)? #建立索引

????for?key?in?secondDict.keys():

????????if?testVec[featIndex]==key: #若該特征值等于當前key,yes往下走

????????????if?type(secondDict[key]).__name__=='dict':# 若為樹結構

????????????????classLabel=classify(secondDict[key],featLabels,testVec) #遞歸調用

????????????else:? classLabel=secondDict[key]#為葉子結點,賦予label值

????return?classLabel #分類結果

?

def retrieveTree(i):

????listOfTrees = [

????????{'no surfacing': {0:?'no', 1: {'flippers': {0:?'no', 1:?'yes'}}}},

????????{'no surfacing': {0:?'no', 1: {'flippers': {0: {'head':{0:'no', 1:?'yes'}},1:'no'}}}}

????]

????return?listOfTrees[i]

  測試結果如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

if?__name__ ==?'__main__':

????myData,labels = createDataSet()

????# print(myData)

????# print(labels)

?

????myTree = createTree(myData,labels)

?

????# print(myTree0)

????myTree1 = {'no surfacing': {0:?'no', 1: {'flippers': {0:?'no', 1:?'yes'}}}}

????# print(type(myTree1))

????# myTree = retrieveTree(0)

????myData, labels = createDataSet()

????print(myData)

????print(labels)

????res1 = classify(myTree,labels,[1,1])

????print(res1)

????res2 = classify(myTree,labels,[1,0])

????print(res2)

?

?

'''

[[1, 1,?'yes'], [1, 1,?'yes'], [1, 0,?'no'], [0, 1,?'no'], [0, 1,?'no']]

['no surfacing',?'flippers']

yes

no

'''

  

?7. 使用算法:決策樹的存儲

  構造決策樹是很耗時的任務,即使處理很小的數據集,如前面的樣本數據,也要花費幾秒的時間,如果數據集很大,將會耗費很多計算時間,然而使用創建好的決策樹解決問題,則可以很快完成。所以為了節省時間,最好能夠在每次執行分類時調用已經構造好的決策樹,為了解決這個問題,需要使用pickle序列化對象。序列化對象可以在磁盤上保存對象,并在需要的時候讀取出來,任何對象都可以執行序列化操作,字典對象也不例外。

  使用pickle模塊存儲決策樹代碼:

1

2

3

4

5

6

7

8

9

10

11

# 使用pickle模塊存儲決策樹

def storeTree(inputTree,filename):

????import pickle

????fw =open(filename,'wb')

????pickle.dump(inputTree,fw)

????fw.close()

?

def grabTree(filename):

????import pickle

????fr = open(filename,'rb')

????return?pickle.load(fr)

  

 通過上面的代碼,我們可以將分類器存儲在硬盤上,而不是每次對數據分類時重新學習一邊,這就是決策樹的優點之一。

  驗證上面代碼,測試結果如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

if?__name__ ==?'__main__':

????myData,labels = createDataSet()

????myTree = createTree(myData,labels)

????print(myTree)

????print(type(myTree))

????myTree1 = {'no surfacing': {0:?'no', 1: {'flippers': {0:?'no', 1:?'yes'}}}}

????storeTree(myTree1,'classifierStorage.txt')

????res = grabTree('classifierStorage.txt')

????print(res)

?

'''

{'no surfacing': {0:?'no', 1: {'flippers': {0:?'no', 1:?'yes'}}}}

<class?'dict'>

{'no surfacing': {0:?'no', 1: {'flippers': {0:?'no', 1:?'yes'}}}}

'''

  

8. 示例:使用決策樹預測隱形眼鏡類型

  此處通過一個例子學習決策樹如何預測患者需要佩戴的隱形眼鏡類型,使用小數據集,我們就可以利用決策樹學到很多知識:眼科醫生是如何判斷患者需要佩戴的鏡片類型;

?(隱形眼鏡數據集時非常著名的數據集,它包含很多患者眼部狀況的觀察條件以及醫生推薦的隱形眼鏡類型,隱形眼鏡類型包括硬材質,軟材質以及不適合佩戴隱形眼鏡。數據來源于UCI數據庫,為了更容易顯示數據,機器學習實戰將數據做了簡單的更改,數據存儲在文本文件中)

  lenses.txt內容可以去我的GitHub上拿(GitHub地址:https://github.com/LeBron-Jian/MachineLearningNote

  程序如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

199

200

201

202

203

# _*_coding:utf-8_*_

import?operator

from?math import log

import? matplotlib.pyplot?as??plt

?

# 計算香農熵? 度量數據集無序程度

def calcShannonEnt(dataSet):

????numEntries = len(dataSet)

????labelCounts = {}

????for?fearVec?in?dataSet:

????????currentLabel = fearVec[-1]

????????if?currentLabel not?in?labelCounts.keys():

????????????labelCounts[currentLabel] = 0

????????labelCounts[currentLabel] +=1

????shannonEnt = 0.0

????for?key?in?labelCounts:

????????prob =?float(labelCounts[key])/numEntries

????????shannonEnt -= prob*log(prob,2)

????return?shannonEnt

?

# 劃分數據集

def? splitDataSet(dataSet,axis,value):

????retDataSet = []

????for?featVec?in?dataSet:

????????if?featVec[axis] == value:

????????????reducesFeatVec = featVec[:axis]

????????????reducesFeatVec.extend(featVec[axis+1:])

????????????retDataSet.append(reducesFeatVec)

????return?retDataSet

?

# 選擇最好的數據集劃分方式

def chooseBestFeatureTpSplit(dataSet):

????'''

????????此函數中調用的數據滿足以下要求

????????1,數據必須是一種由列表元素組成的列表,而且所有列表元素都要具有相同的數據長度

????????2,數據的最后一列或者實例的最后一個元素是當前實例的類別標簽

????:param dataSet:

????:return:

????'''

????numFeatures = len(dataSet[0]) - 1

????# 原始的熵

????baseEntropy = calcShannonEnt(dataSet)

????bestInfoGain = 0.0

????bestFeature = -1

????for?i?in?range(numFeatures):

????????# 創建唯一的分類標簽列表

????????featList = [example[i]?for?example?in?dataSet]

????????uniqueVals =?set(featList)

????????newEntropy = 0.0

????????for?value?in?uniqueVals:

????????????# 計算每種劃分方式的信息熵,并對所有唯一特征值得到的熵求和

????????????subDataSet = splitDataSet(dataSet,i,value)

????????????prob = len(subDataSet)/float(len(dataSet))

????????????# 按照特征分類后的熵

????????????newEntropy += prob * calcShannonEnt(subDataSet)

????????infoGain = baseEntropy - newEntropy

????????if?(infoGain > bestInfoGain):

????????????# 計算最好的信息增益,信息增益越大,區分樣本的能力越強,根據代表性

????????????bestInfoGain = infoGain

????????????bestFeature = i

????return?bestFeature

?

# 按照分類后類別數量排序

def majorityCnt(classList):

????classCount = {}

????for?vote?in?classList:

????????if?vote not?in?classCount.keys():

????????????classCount[vote] = 0

????????classCount[vote] += 1

????sortedClassCount = sorted(classCount.items(),

??????????????????????????????key=operator.itemgetter(1),reverse=True)

????return?sortedClassCount[0][0]

?

# 創建樹的函數代碼

def createTree(dataSet,labels):

????'''

?

????????:param dataSet:? 輸入的數據集

????????:param labels:? 標簽列表(包含了數據集中所有特征的標簽)

????????:return:

????????'''

????# classList 包含了數據集中所有類的標簽

????classList = [example[-1]?for?example?in?dataSet]

????# 類別完全相同則停止繼續劃分

????if?classList.count(classList[0]) == len(classList):

????????return?classList[0]

????# 遍歷完所有特征時返回出現次數最多的

????if?len(dataSet[0])? == 1:

????????return?majorityCnt(classList)

????bestFeat = chooseBestFeatureTpSplit(dataSet)

????bestFeatLabel = labels[bestFeat]

????# 字典myTree存儲了樹的所有信息,這對于后面繪制樹形圖很重要

????myTree = {bestFeatLabel:{}}

????del(labels[bestFeat])

????# 得到列表包含的所有屬性值

????featValues = [example[bestFeat]?for?example?in?dataSet]

????uniqueVals =?set(featValues)

????for?value?in?uniqueVals:

????????subLabels =labels[:]

????????myTree[bestFeatLabel][value] = createTree(splitDataSet(dataSet,bestFeat,value),

??????????????????????????????????????????????????subLabels)

?

????return?myTree

?

# 獲取葉子節點的數目

def getNumLeafs(myTree):

????# 初始化結點數

????numLeafs = 0

????firstSides = list(myTree.keys())

????# 找到輸入的第一個元素,第一個關鍵詞為劃分數據集類別的標簽

????firstStr = firstSides[0]

????secondDect = myTree[firstStr]

????for?key?in?secondDect.keys():

????????# 測試節點的數據類型是否為字典

????????if?type(secondDect[key]).__name__ ==?'dict':

????????????numLeafs += getNumLeafs(secondDect[key])

????????else:

????????????numLeafs +=1

????return?numLeafs

?

# 獲取樹的層數

def getTreeDepth(myTree):

????maxDepth = 0

????firstSides = list(myTree.keys())

????firstStr = firstSides[0]

????secondDict = myTree[firstStr]

????for?key?in?secondDict.keys():

????????# 測試節點的數據類型是否為字典

????????if?type(secondDict[key]).__name__ ==?'dict':

????????????thisDepth = 1 + getTreeDepth(secondDict[key])

????????else:

????????????thisDepth = 1

????????if?thisDepth > maxDepth:

????????????maxDepth = thisDepth

?

????return?maxDepth

?

# 定義文本框和箭頭格式(樹節點格式的常量)

decisionNode = dict(boxstyle='sawtooth',fc='0.8')

leafNode = dict(boxstyle='round4',fc='0.8')

arrows_args = dict(arrowstyle='<-')

?

# 繪制帶箭頭的注解

def plotNode(nodeTxt,centerPt,parentPt,nodeType):

????createPlot.ax1.annotate(nodeTxt,xy=parentPt,

????????????????????????????xycoords='axes fraction',

????????????????????????????xytext=centerPt,textcoords='axes fraction',

????????????????????????????va='center',ha='center',bbox=nodeType,

????????????????????????????arrowprops=arrows_args)

?

?

# 在父子節點間填充文本信息

def plotMidText(cntrPt,parentPt,txtString):

????xMid = (parentPt[0] - cntrPt[0]) / 2.0 + cntrPt[0]

????yMid = (parentPt[1] - cntrPt[1]) / 2.0 + cntrPt[1]

????createPlot.ax1.text(xMid,yMid,txtString, va="center", ha="center", rotation=30)

?

?

def plotTree(myTree,parentPt,nodeTxt):

????# 求出寬和高

????numLeafs = getNumLeafs(myData)

????depth = getTreeDepth(myData)

????firstStides = list(myTree.keys())

????firstStr = firstStides[0]

????# 按照葉子結點個數劃分x軸

????cntrPt = (plotTree.xOff + (0.1 +?float(numLeafs)) /2.0/plotTree.totalW,plotTree.yOff)

????plotMidText(cntrPt,parentPt,nodeTxt)

????plotNode(firstStr,cntrPt,parentPt,decisionNode)

????secondDict = myTree[firstStr]

????# y方向上的擺放位置 自上而下繪制,因此遞減y值

????plotTree.yOff = plotTree.yOff - 1.0/plotTree.totalD

????for?key?in?secondDict.keys():

????????if?type(secondDict[key]).__name__? ==?'dict':

????????????plotTree(secondDict[key],cntrPt,str(key))

????????else:

????????????plotTree.xOff = plotTree.xOff + 1.0 / plotTree.totalW? # x方向計算結點坐標

????????????plotNode(secondDict[key], (plotTree.xOff, plotTree.yOff), cntrPt, leafNode)? # 繪制

????????????plotMidText((plotTree.xOff, plotTree.yOff), cntrPt, str(key))? # 添加文本信息

????plotTree.yOff = plotTree.yOff + 1.0 / plotTree.totalD? # 下次重新調用時恢復y

?

# 主函數

def createPlot(inTree):

????# 創建一個新圖形并清空繪圖區

????fig = plt.figure(1,facecolor='white')

????fig.clf()

????axprops = dict(xticks=[], yticks=[])

????createPlot.ax1 = plt.subplot(111, frameon=False, **axprops)? # no ticks

????# createPlot.ax1 = plt.subplot(111, frameon=False) #ticks for demo puropses

????plotTree.totalW =?float(getNumLeafs(inTree))

????plotTree.totalD =?float(getTreeDepth(inTree))

????plotTree.xOff = -0.5 / plotTree.totalW

????plotTree.yOff = 1.0

????plotTree(inTree, (0.5, 1.0),?'')

????plt.show()

?

if?__name__ ==?'__main__':

????fr = open('lenses.txt')

????lenses = [inst.strip().split('\t')??for?inst?in?fr.readlines()]

????lensesLabels = ['age','prescript','astigmatic','tearRate']

????print(lenses)

????myData = createTree(lenses, lensesLabels)

????print(myData)

????createPlot(myData)

  結果如下:

?

  上圖所示的決策樹非常好的匹配了實驗數據,然而這些選項可能太多了。我們將這種問題稱為過度匹配,為了減少過度匹配問題,我們可以裁剪決策樹,去掉一些不必要的葉子節點,如果葉子節點只能增加少許信息,則可以刪除該節點,將它并入到其他葉子節點中。

  ID3算法無法直接處理數值型數據,盡管我們可以通過量化的方法將數值型數據轉化為標稱型數值,但是如果存在太多的特征劃分,ID3算法仍然會面臨其他問題。

9 總結

  決策樹分類器就像帶有終止塊的流程圖,終止塊表示分類結果。開始處理數據集時,我們首先需要測量集合中數據的不一致性,也就是熵,然后尋找最優方案劃分數據集,直到數據集中的所有數據屬于同一分類。ID3算法可以用于劃分標稱型數據集。構建決策樹時,我們通常采取遞歸的方法將數據集轉化為決策樹。一般我們并不構造新的數據結構,而是使用字典存儲樹節點信息。

參考文獻:機器學習實戰

?

更多精彩內容請訪問FlyAI-AI競賽服務平臺;為AI開發者提供數據競賽并支持GPU離線訓練的一站式服務平臺;每周免費提供項目開源算法樣例,支持算法能力變現以及快速的迭代算法模型。

挑戰者,都在FlyAI!!!

總結

以上是生活随笔為你收集整理的python机器学习笔记:ID3决策树算法实战的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

丰满人妻精品国产99aⅴ | 青青草原综合久久大伊人精品 | av无码久久久久不卡免费网站 | 久久精品中文字幕大胸 | 在线观看欧美一区二区三区 | 成人av无码一区二区三区 | 国产色视频一区二区三区 | 人人妻人人澡人人爽欧美精品 | 国产乱人伦偷精品视频 | 少妇性俱乐部纵欲狂欢电影 | 76少妇精品导航 | 强开小婷嫩苞又嫩又紧视频 | 国产电影无码午夜在线播放 | 日产精品99久久久久久 | 色综合久久久无码网中文 | 在线播放亚洲第一字幕 | 人妻少妇精品久久 | 中文字幕无码日韩专区 | 中文亚洲成a人片在线观看 | 亚洲自偷自拍另类第1页 | 国产精品美女久久久久av爽李琼 | 人妻体内射精一区二区三四 | 中文字幕乱码亚洲无线三区 | 丝袜 中出 制服 人妻 美腿 | 亚洲aⅴ无码成人网站国产app | 亚洲一区二区三区在线观看网站 | 2020久久香蕉国产线看观看 | 日日噜噜噜噜夜夜爽亚洲精品 | 97夜夜澡人人爽人人喊中国片 | 亚洲精品一区二区三区婷婷月 | 玩弄中年熟妇正在播放 | 亚洲成a人片在线观看无码3d | 7777奇米四色成人眼影 | 中文字幕人妻丝袜二区 | 中文字幕乱码人妻无码久久 | 日本精品少妇一区二区三区 | 亚洲人成网站在线播放942 | 亚洲啪av永久无码精品放毛片 | 99久久久无码国产aaa精品 | 人人妻人人澡人人爽欧美一区九九 | 最近免费中文字幕中文高清百度 | aⅴ亚洲 日韩 色 图网站 播放 | 欧美亚洲国产一区二区三区 | 精品久久久久久人妻无码中文字幕 | 久久精品成人欧美大片 | 国产午夜福利100集发布 | 一本色道久久综合狠狠躁 | 成人免费无码大片a毛片 | 久久综合给久久狠狠97色 | 亚洲人成影院在线观看 | 内射欧美老妇wbb | 亚洲天堂2017无码 | 国产后入清纯学生妹 | 国产婷婷色一区二区三区在线 | 亚洲春色在线视频 | 日本精品少妇一区二区三区 | 又大又硬又爽免费视频 | 日日躁夜夜躁狠狠躁 | 黑人巨大精品欧美一区二区 | 精品一区二区三区无码免费视频 | 东京热无码av男人的天堂 | 亚洲欧美色中文字幕在线 | 成人aaa片一区国产精品 | 亚洲成a人片在线观看日本 | 夜夜高潮次次欢爽av女 | 久久午夜无码鲁丝片秋霞 | 国产精品视频免费播放 | 天天躁夜夜躁狠狠是什么心态 | 性欧美牲交在线视频 | 综合激情五月综合激情五月激情1 | 午夜嘿嘿嘿影院 | 亚洲精品一区二区三区在线 | 国产午夜亚洲精品不卡下载 | 国内精品九九久久久精品 | 天下第一社区视频www日本 | 婷婷丁香五月天综合东京热 | 国产在线一区二区三区四区五区 | 国产精品久久久久无码av色戒 | 婷婷五月综合激情中文字幕 | 亚洲理论电影在线观看 | 中文无码成人免费视频在线观看 | 男人扒开女人内裤强吻桶进去 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 亚洲毛片av日韩av无码 | 性啪啪chinese东北女人 | 丁香花在线影院观看在线播放 | 人人爽人人爽人人片av亚洲 | 99精品久久毛片a片 | 亚洲综合无码久久精品综合 | 少妇性l交大片欧洲热妇乱xxx | 欧美老人巨大xxxx做受 | 大乳丰满人妻中文字幕日本 | 丰满少妇人妻久久久久久 | 成人精品一区二区三区中文字幕 | 人人妻人人澡人人爽人人精品 | 亚洲精品一区二区三区四区五区 | 中文无码成人免费视频在线观看 | 人人妻人人澡人人爽欧美一区九九 | 丰满少妇高潮惨叫视频 | 无码人中文字幕 | 亚洲精品综合一区二区三区在线 | 欧美黑人巨大xxxxx | 久久精品女人天堂av免费观看 | 乱人伦人妻中文字幕无码久久网 | 一区二区传媒有限公司 | 亚洲啪av永久无码精品放毛片 | 国产无遮挡又黄又爽又色 | 国色天香社区在线视频 | 国语自产偷拍精品视频偷 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产农村乱对白刺激视频 | 国产超级va在线观看视频 | 牲欲强的熟妇农村老妇女 | 狂野欧美性猛xxxx乱大交 | 狠狠色欧美亚洲狠狠色www | 天堂亚洲2017在线观看 | 免费人成网站视频在线观看 | 少妇愉情理伦片bd | 国产九九九九九九九a片 | 久久久精品人妻久久影视 | 在线亚洲高清揄拍自拍一品区 | 国产成人无码区免费内射一片色欲 | 国产电影无码午夜在线播放 | 国产国产精品人在线视 | 2019nv天堂香蕉在线观看 | 中文字幕无码日韩专区 | 久久午夜夜伦鲁鲁片无码免费 | 最近免费中文字幕中文高清百度 | 中文字幕日韩精品一区二区三区 | 色情久久久av熟女人妻网站 | 粗大的内捧猛烈进出视频 | 国产乱人无码伦av在线a | 国产精品成人av在线观看 | 东京一本一道一二三区 | 国内揄拍国内精品少妇国语 | 亚洲一区二区三区国产精华液 | 丰满少妇女裸体bbw | 搡女人真爽免费视频大全 | 日本精品久久久久中文字幕 | 日本丰满熟妇videos | 内射老妇bbwx0c0ck | 成人三级无码视频在线观看 | 成 人影片 免费观看 | 青青草原综合久久大伊人精品 | 国产亲子乱弄免费视频 | 国产猛烈高潮尖叫视频免费 | www成人国产高清内射 | 欧美xxxx黑人又粗又长 | 国产亚洲视频中文字幕97精品 | 99riav国产精品视频 | 大屁股大乳丰满人妻 | 亚洲中文字幕久久无码 | 国内少妇偷人精品视频免费 | 国产免费观看黄av片 | 成人一在线视频日韩国产 | 国产色在线 | 国产 | 欧美 亚洲 国产 另类 | 欧美喷潮久久久xxxxx | 国产精品久久久久7777 | 老熟妇仑乱视频一区二区 | 精品国产一区二区三区av 性色 | 国产精品爱久久久久久久 | 色一情一乱一伦一视频免费看 | 无码国产色欲xxxxx视频 | 午夜福利不卡在线视频 | 性欧美大战久久久久久久 | 亚洲日本在线电影 | 久久久久人妻一区精品色欧美 | 欧美 丝袜 自拍 制服 另类 | 欧美人与物videos另类 | 正在播放老肥熟妇露脸 | 99久久无码一区人妻 | 国产午夜精品一区二区三区嫩草 | 无码av中文字幕免费放 | 大色综合色综合网站 | 欧美猛少妇色xxxxx | 少妇无套内谢久久久久 | 亚洲狠狠色丁香婷婷综合 | 国内精品人妻无码久久久影院 | 精品国偷自产在线 | 人妻插b视频一区二区三区 | 黑森林福利视频导航 | 亚洲男人av天堂午夜在 | 男女超爽视频免费播放 | 全球成人中文在线 | 午夜精品久久久久久久 | 欧洲熟妇色 欧美 | 伊人久久婷婷五月综合97色 | 亚洲国产成人av在线观看 | 荫蒂添的好舒服视频囗交 | 波多野结衣aⅴ在线 | 亚洲а∨天堂久久精品2021 | 人妻aⅴ无码一区二区三区 | 老太婆性杂交欧美肥老太 | 久久人人爽人人爽人人片av高清 | 日本一区二区更新不卡 | 女高中生第一次破苞av | 国产精品国产自线拍免费软件 | 国产成人av免费观看 | 一本无码人妻在中文字幕免费 | 2020久久香蕉国产线看观看 | 东北女人啪啪对白 | 欧美三级不卡在线观看 | 少妇被粗大的猛进出69影院 | 激情人妻另类人妻伦 | 亚洲日韩av一区二区三区四区 | 全黄性性激高免费视频 | 性欧美疯狂xxxxbbbb | 中文字幕久久久久人妻 | 色偷偷人人澡人人爽人人模 | 亚洲精品国偷拍自产在线观看蜜桃 | 亚洲精品一区二区三区四区五区 | 国产成人精品视频ⅴa片软件竹菊 | 日本大香伊一区二区三区 | 色妞www精品免费视频 | 欧美日韩一区二区综合 | 嫩b人妻精品一区二区三区 | 日韩成人一区二区三区在线观看 | 亚洲欧美国产精品久久 | 女人被男人躁得好爽免费视频 | 亚洲综合无码一区二区三区 | 亚洲第一无码av无码专区 | 国产熟妇另类久久久久 | 午夜福利试看120秒体验区 | 亚洲熟熟妇xxxx | 狂野欧美性猛xxxx乱大交 | 亚洲精品一区二区三区在线观看 | 性生交大片免费看l | 99精品无人区乱码1区2区3区 | 国产精品久久精品三级 | 亚洲色欲色欲天天天www | 成人综合网亚洲伊人 | 麻豆国产人妻欲求不满谁演的 | 国产真实伦对白全集 | 国产精品va在线观看无码 | 无码一区二区三区在线 | 亚洲国产高清在线观看视频 | 亚洲熟妇自偷自拍另类 | 精品国产一区av天美传媒 | 亚洲色无码一区二区三区 | 欧美 亚洲 国产 另类 | 欧美自拍另类欧美综合图片区 | 老熟妇仑乱视频一区二区 | 欧美放荡的少妇 | 四虎4hu永久免费 | 久久精品丝袜高跟鞋 | 又紧又大又爽精品一区二区 | 色噜噜亚洲男人的天堂 | 在线播放免费人成毛片乱码 | 国内少妇偷人精品视频免费 | 蜜臀aⅴ国产精品久久久国产老师 | 国产精品亚洲五月天高清 | 国产农村乱对白刺激视频 | 99久久精品午夜一区二区 | 久久国产精品二国产精品 | 在线成人www免费观看视频 | 又大又黄又粗又爽的免费视频 | 超碰97人人做人人爱少妇 | 鲁一鲁av2019在线 | 国产精品人人爽人人做我的可爱 | 色五月五月丁香亚洲综合网 | 亚洲精品成人福利网站 | 国内精品一区二区三区不卡 | 亚洲性无码av中文字幕 | 国产成人综合在线女婷五月99播放 | 乌克兰少妇xxxx做受 | 日日摸天天摸爽爽狠狠97 | 国产乱人伦av在线无码 | 国产av剧情md精品麻豆 | 东京热一精品无码av | 久久国产36精品色熟妇 | 免费人成网站视频在线观看 | 日产精品高潮呻吟av久久 | 无码人妻精品一区二区三区下载 | 扒开双腿吃奶呻吟做受视频 | 久久精品人妻少妇一区二区三区 | 妺妺窝人体色www在线小说 | 成在人线av无码免观看麻豆 | 国产成人无码a区在线观看视频app | 丰满少妇女裸体bbw | a在线亚洲男人的天堂 | 一个人免费观看的www视频 | 亚洲日本一区二区三区在线 | 成在人线av无码免观看麻豆 | 久久久国产精品无码免费专区 | 小泽玛莉亚一区二区视频在线 | 国产精品18久久久久久麻辣 | 领导边摸边吃奶边做爽在线观看 | 精品夜夜澡人妻无码av蜜桃 | 最新国产麻豆aⅴ精品无码 | 国产绳艺sm调教室论坛 | 亚洲午夜福利在线观看 | 欧美成人高清在线播放 | 亚洲成a人片在线观看无码3d | 粗大的内捧猛烈进出视频 | 夜夜高潮次次欢爽av女 | 国产精华av午夜在线观看 | 久久综合给久久狠狠97色 | 国产农村妇女高潮大叫 | 性生交大片免费看l | 欧美日韩久久久精品a片 | 国产亚洲精品精品国产亚洲综合 | 亚洲精品无码人妻无码 | 成人免费无码大片a毛片 | 一本一道久久综合久久 | 久久综合给久久狠狠97色 | 日韩亚洲欧美中文高清在线 | 国产亚洲精品久久久闺蜜 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲日韩av片在线观看 | 中文字幕无码热在线视频 | 性欧美牲交在线视频 | 国产精品成人av在线观看 | 无码午夜成人1000部免费视频 | 亚洲精品久久久久avwww潮水 | 国产肉丝袜在线观看 | 人妻少妇被猛烈进入中文字幕 | 超碰97人人做人人爱少妇 | 国产精品-区区久久久狼 | 亚洲男人av香蕉爽爽爽爽 | 国产免费观看黄av片 | 国产精品人妻一区二区三区四 | 中文字幕无码免费久久99 | 久久婷婷五月综合色国产香蕉 | 国产精品高潮呻吟av久久 | 综合激情五月综合激情五月激情1 | 国产麻豆精品一区二区三区v视界 | 国产福利视频一区二区 | 亚洲精品国产第一综合99久久 | 国产无套内射久久久国产 | 亚洲人亚洲人成电影网站色 | 国产成人综合色在线观看网站 | 精品国产一区二区三区av 性色 | 牲欲强的熟妇农村老妇女 | 国产成人无码av片在线观看不卡 | 一本久道久久综合狠狠爱 | 熟女少妇人妻中文字幕 | 亚洲一区二区观看播放 | 老熟妇乱子伦牲交视频 | 国产精品.xx视频.xxtv | 成人亚洲精品久久久久 | 国产精品亚洲lv粉色 | aⅴ在线视频男人的天堂 | 国产99久久精品一区二区 | 久久国产精品萌白酱免费 | 中文字幕乱码人妻二区三区 | 狠狠亚洲超碰狼人久久 | 精品久久久中文字幕人妻 | 一区二区传媒有限公司 | 亚洲综合另类小说色区 | 日本在线高清不卡免费播放 | 欧美成人家庭影院 | av人摸人人人澡人人超碰下载 | 国产欧美亚洲精品a | 永久免费观看国产裸体美女 | 亚洲人成网站免费播放 | 欧美日韩亚洲国产精品 | 国产黄在线观看免费观看不卡 | 久久午夜无码鲁丝片 | 综合激情五月综合激情五月激情1 | 国产无套内射久久久国产 | 人妻尝试又大又粗久久 | 午夜时刻免费入口 | 久久久无码中文字幕久... | 日本高清一区免费中文视频 | 成熟人妻av无码专区 | 亚洲七七久久桃花影院 | 亚洲精品久久久久久一区二区 | 亚洲狠狠色丁香婷婷综合 | 水蜜桃亚洲一二三四在线 | 中文字幕av日韩精品一区二区 | 四虎4hu永久免费 | 日日摸日日碰夜夜爽av | 领导边摸边吃奶边做爽在线观看 | 给我免费的视频在线观看 | 2019nv天堂香蕉在线观看 | 日本丰满护士爆乳xxxx | 蜜桃臀无码内射一区二区三区 | 日韩视频 中文字幕 视频一区 | 中文字幕亚洲情99在线 | 88国产精品欧美一区二区三区 | 人妻少妇精品无码专区二区 | 黄网在线观看免费网站 | 亚洲狠狠婷婷综合久久 | 亚洲精品一区国产 | 免费无码一区二区三区蜜桃大 | 久久国产劲爆∧v内射 | 人妻人人添人妻人人爱 | 99久久无码一区人妻 | 亚洲国产精品一区二区美利坚 | 亚洲国产午夜精品理论片 | 日韩人妻无码中文字幕视频 | 成人片黄网站色大片免费观看 | 在线天堂新版最新版在线8 | 我要看www免费看插插视频 | 野外少妇愉情中文字幕 | 精品人人妻人人澡人人爽人人 | 国产精品美女久久久 | 欧美高清在线精品一区 | 久久精品一区二区三区四区 | 人妻少妇精品无码专区动漫 | 久久久久久亚洲精品a片成人 | a片在线免费观看 | 午夜精品久久久久久久久 | 中文亚洲成a人片在线观看 | 国产精品毛多多水多 | 中文字幕无码热在线视频 | 国产精品对白交换视频 | 99精品无人区乱码1区2区3区 | 中文字幕人妻无码一区二区三区 | 中文字幕乱妇无码av在线 | 秋霞特色aa大片 | 久久久久亚洲精品中文字幕 | 99久久精品午夜一区二区 | 乌克兰少妇xxxx做受 | 日产国产精品亚洲系列 | 四虎永久在线精品免费网址 | 亚洲国产午夜精品理论片 | 内射白嫩少妇超碰 | 国产成人精品三级麻豆 | 蜜臀av无码人妻精品 | 午夜精品久久久久久久久 | 国产国语老龄妇女a片 | 女人高潮内射99精品 | 四虎4hu永久免费 | 一区二区三区高清视频一 | 奇米影视7777久久精品人人爽 | 欧美日韩色另类综合 | 欧美性猛交xxxx富婆 | 国产精品久久精品三级 | 欧美精品国产综合久久 | 香港三级日本三级妇三级 | 麻豆国产人妻欲求不满 | 久久综合激激的五月天 | 欧美日韩综合一区二区三区 | 亚洲精品中文字幕久久久久 | 99久久精品国产一区二区蜜芽 | 精品久久久中文字幕人妻 | 久久综合香蕉国产蜜臀av | 成人免费视频一区二区 | 亚洲精品午夜无码电影网 | 综合激情五月综合激情五月激情1 | 亚洲日韩中文字幕在线播放 | 性欧美videos高清精品 | 97精品人妻一区二区三区香蕉 | 日韩av无码一区二区三区不卡 | 国产精品成人av在线观看 | 999久久久国产精品消防器材 | 亚欧洲精品在线视频免费观看 | 午夜性刺激在线视频免费 | 西西人体www44rt大胆高清 | 丰满人妻一区二区三区免费视频 | 香港三级日本三级妇三级 | 九九热爱视频精品 | 国产人成高清在线视频99最全资源 | 亚洲第一网站男人都懂 | 亚洲aⅴ无码成人网站国产app | 欧洲欧美人成视频在线 | 亚洲精品无码国产 | 两性色午夜免费视频 | 亚洲精品无码人妻无码 | 国产精品二区一区二区aⅴ污介绍 | 97无码免费人妻超级碰碰夜夜 | 欧美日韩视频无码一区二区三 | 三上悠亚人妻中文字幕在线 | 国产97色在线 | 免 | 精品无码一区二区三区爱欲 | a在线观看免费网站大全 | 欧美一区二区三区视频在线观看 | 天海翼激烈高潮到腰振不止 | 大屁股大乳丰满人妻 | 国产免费无码一区二区视频 | 麻豆精产国品 | 无码一区二区三区在线 | 国产成人av免费观看 | 亚洲国产精品久久人人爱 | 中文毛片无遮挡高清免费 | 久久人人爽人人爽人人片ⅴ | 丰满人妻翻云覆雨呻吟视频 | 成 人影片 免费观看 | 一本久道久久综合狠狠爱 | 巨爆乳无码视频在线观看 | 精品无码一区二区三区的天堂 | 久久久中文字幕日本无吗 | 精品人妻av区 | 影音先锋中文字幕无码 | 人人妻人人澡人人爽欧美一区 | 亚洲精品一区二区三区在线观看 | 中国女人内谢69xxxxxa片 | 亚洲狠狠婷婷综合久久 | 97精品人妻一区二区三区香蕉 | 国产av久久久久精东av | 丰满人妻一区二区三区免费视频 | 日本乱偷人妻中文字幕 | 久久亚洲中文字幕精品一区 | 欧美自拍另类欧美综合图片区 | 久久亚洲中文字幕精品一区 | 亚洲精品www久久久 | 国产成人精品视频ⅴa片软件竹菊 | 亚洲欧美色中文字幕在线 | 久久久精品成人免费观看 | 日日橹狠狠爱欧美视频 | 丰满少妇女裸体bbw | 亚洲国产欧美日韩精品一区二区三区 | 少妇无码一区二区二三区 | 国产欧美精品一区二区三区 | 欧美日韩在线亚洲综合国产人 | 日韩亚洲欧美精品综合 | 亚洲精品国产第一综合99久久 | 2020久久香蕉国产线看观看 | 亚洲国产欧美在线成人 | 久久国产精品二国产精品 | 国产午夜无码视频在线观看 | 中文字幕久久久久人妻 | 日韩亚洲欧美中文高清在线 | 中文字幕人妻丝袜二区 | 麻豆国产97在线 | 欧洲 | 领导边摸边吃奶边做爽在线观看 | www国产亚洲精品久久网站 | 老头边吃奶边弄进去呻吟 | 少妇愉情理伦片bd | 国产特级毛片aaaaaa高潮流水 | 国产精品亚洲一区二区三区喷水 | 亚洲一区二区三区香蕉 | 欧美性黑人极品hd | 中文亚洲成a人片在线观看 | 亚洲中文字幕成人无码 | 国语自产偷拍精品视频偷 | 福利一区二区三区视频在线观看 | 日本免费一区二区三区最新 | 国产成人精品一区二区在线小狼 | 成人亚洲精品久久久久软件 | 熟妇女人妻丰满少妇中文字幕 | 亚洲日本va中文字幕 | 亚洲国精产品一二二线 | 国产乱子伦视频在线播放 | 妺妺窝人体色www婷婷 | 国产精品无码一区二区三区不卡 | 动漫av网站免费观看 | 久9re热视频这里只有精品 | 日本一本二本三区免费 | 99久久精品国产一区二区蜜芽 | 色综合久久久无码中文字幕 | 搡女人真爽免费视频大全 | 水蜜桃亚洲一二三四在线 | 国产精品人人爽人人做我的可爱 | 日本一区二区三区免费高清 | 精品久久久无码人妻字幂 | 亚洲国产精品一区二区第一页 | 欧美午夜特黄aaaaaa片 | 九一九色国产 | 国产乡下妇女做爰 | 成在人线av无码免观看麻豆 | 日欧一片内射va在线影院 | 成人无码影片精品久久久 | 日韩精品a片一区二区三区妖精 | 亚洲熟妇色xxxxx亚洲 | 国产亚洲精品久久久久久国模美 | 国产艳妇av在线观看果冻传媒 | 麻豆人妻少妇精品无码专区 | 麻豆md0077饥渴少妇 | 精品水蜜桃久久久久久久 | 久久精品女人天堂av免费观看 | av香港经典三级级 在线 | 女人被爽到呻吟gif动态图视看 | 日韩人妻无码一区二区三区久久99 | 亚洲国产午夜精品理论片 | 欧美第一黄网免费网站 | 兔费看少妇性l交大片免费 | 国产9 9在线 | 中文 | 婷婷色婷婷开心五月四房播播 | 人妻熟女一区 | 天堂在线观看www | 澳门永久av免费网站 | 伊人色综合久久天天小片 | 国产黄在线观看免费观看不卡 | 麻豆av传媒蜜桃天美传媒 | 国产尤物精品视频 | 欧美丰满熟妇xxxx性ppx人交 | 日本熟妇人妻xxxxx人hd | 亚洲欧美综合区丁香五月小说 | 国产精品高潮呻吟av久久 | 亚洲综合在线一区二区三区 | 国产精品二区一区二区aⅴ污介绍 | 日韩人妻无码中文字幕视频 | 在线天堂新版最新版在线8 | 一个人看的视频www在线 | 亚洲国产欧美国产综合一区 | 国产午夜精品一区二区三区嫩草 | 亚洲熟悉妇女xxx妇女av | 人妻少妇被猛烈进入中文字幕 | 亚洲男女内射在线播放 | 377p欧洲日本亚洲大胆 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲爆乳精品无码一区二区三区 | 丝袜美腿亚洲一区二区 | 欧美精品无码一区二区三区 | 伊人久久婷婷五月综合97色 | 久久亚洲中文字幕无码 | 兔费看少妇性l交大片免费 | 曰本女人与公拘交酡免费视频 | 亚洲国产日韩a在线播放 | 久久久中文字幕日本无吗 | 大屁股大乳丰满人妻 | 亚洲综合色区中文字幕 | 牛和人交xxxx欧美 | 欧洲vodafone精品性 | 国产无遮挡又黄又爽又色 | 久久综合给合久久狠狠狠97色 | 东京无码熟妇人妻av在线网址 | 免费男性肉肉影院 | 伊人久久婷婷五月综合97色 | 无套内谢的新婚少妇国语播放 | 99久久精品国产一区二区蜜芽 | 婷婷色婷婷开心五月四房播播 | 日韩人妻无码中文字幕视频 | 中文字幕av无码一区二区三区电影 | 国产做国产爱免费视频 | 中文字幕日产无线码一区 | 中文字幕乱码人妻无码久久 | 无码人妻丰满熟妇区五十路百度 | 亚洲国产av精品一区二区蜜芽 | 性色av无码免费一区二区三区 | 狠狠噜狠狠狠狠丁香五月 | 婷婷色婷婷开心五月四房播播 | 自拍偷自拍亚洲精品被多人伦好爽 | 亚洲精品久久久久avwww潮水 | 51国偷自产一区二区三区 | 精品国产乱码久久久久乱码 | 亚洲大尺度无码无码专区 | 国产精品久久久av久久久 | 国产综合在线观看 | 国产高潮视频在线观看 | 亚洲性无码av中文字幕 | 国产后入清纯学生妹 | 亚洲中文字幕无码中文字在线 | 成人三级无码视频在线观看 | 国产成人无码av在线影院 | 牲欲强的熟妇农村老妇女 | 国产人妖乱国产精品人妖 | 精品欧洲av无码一区二区三区 | 四虎影视成人永久免费观看视频 | 欧美freesex黑人又粗又大 | 99精品国产综合久久久久五月天 | 少妇厨房愉情理9仑片视频 | 丰满人妻一区二区三区免费视频 | 日本精品久久久久中文字幕 | 少妇久久久久久人妻无码 | 欧美freesex黑人又粗又大 | 日本一卡2卡3卡四卡精品网站 | 人妻少妇精品无码专区动漫 | 欧美freesex黑人又粗又大 | 无码人妻精品一区二区三区下载 | 中文字幕无码热在线视频 | 少妇邻居内射在线 | 色婷婷久久一区二区三区麻豆 | 欧美老人巨大xxxx做受 | 亚洲国产一区二区三区在线观看 | 亚洲精品一区二区三区在线观看 | 日韩亚洲欧美中文高清在线 | 日日天日日夜日日摸 | 99久久99久久免费精品蜜桃 | 婷婷色婷婷开心五月四房播播 | 日本熟妇人妻xxxxx人hd | 中文字幕+乱码+中文字幕一区 | 亚洲综合另类小说色区 | 精品日本一区二区三区在线观看 | 国产精品久久久久9999小说 | 少妇高潮喷潮久久久影院 | 国产 精品 自在自线 | 色一情一乱一伦一区二区三欧美 | 无码国产乱人伦偷精品视频 | 一本久久伊人热热精品中文字幕 | 水蜜桃色314在线观看 | 成人免费视频一区二区 | 亚洲精品久久久久avwww潮水 | 麻花豆传媒剧国产免费mv在线 | 色一情一乱一伦一区二区三欧美 | 国产日产欧产精品精品app | 男人的天堂av网站 | 久久99久久99精品中文字幕 | 欧美国产日韩久久mv | 中国女人内谢69xxxxxa片 | 日本xxxx色视频在线观看免费 | 激情五月综合色婷婷一区二区 | 色一情一乱一伦一视频免费看 | 精品国产国产综合精品 | 丝袜足控一区二区三区 | 人妻无码αv中文字幕久久琪琪布 | 少女韩国电视剧在线观看完整 | 东京一本一道一二三区 | 青草青草久热国产精品 | 少妇被粗大的猛进出69影院 | 中文字幕 人妻熟女 | 欧美成人高清在线播放 | 亚洲国产精品毛片av不卡在线 | 午夜丰满少妇性开放视频 | 内射欧美老妇wbb | 啦啦啦www在线观看免费视频 | 欧美人与禽猛交狂配 | 一区二区传媒有限公司 | 亚洲成a人片在线观看无码 | 国产两女互慰高潮视频在线观看 | 久久精品国产一区二区三区 | 日韩视频 中文字幕 视频一区 | 亚洲自偷精品视频自拍 | 久久视频在线观看精品 | 日韩成人一区二区三区在线观看 | 最新国产麻豆aⅴ精品无码 | 免费人成网站视频在线观看 | 欧美 日韩 亚洲 在线 | 日欧一片内射va在线影院 | 大乳丰满人妻中文字幕日本 | 亚洲色大成网站www国产 | 国产成人久久精品流白浆 | 日韩av无码一区二区三区 | 好爽又高潮了毛片免费下载 | 国内精品九九久久久精品 | 人妻少妇精品无码专区动漫 | 理论片87福利理论电影 | 在线成人www免费观看视频 | 亚洲国产成人a精品不卡在线 | 成人欧美一区二区三区黑人 | 国产两女互慰高潮视频在线观看 | 成年美女黄网站色大免费视频 | 内射白嫩少妇超碰 | 丝袜 中出 制服 人妻 美腿 | 欧美精品在线观看 | 久久久精品成人免费观看 | 97久久超碰中文字幕 | 国产人妻精品一区二区三区 | 久久97精品久久久久久久不卡 | 国产成人av免费观看 | 国产无套粉嫩白浆在线 | 97精品国产97久久久久久免费 | 伦伦影院午夜理论片 | 丰满少妇女裸体bbw | 亚洲s色大片在线观看 | 中文字幕乱码亚洲无线三区 | 亚洲天堂2017无码中文 | 四虎国产精品一区二区 | 色婷婷久久一区二区三区麻豆 | 一区二区三区高清视频一 | 人人妻人人藻人人爽欧美一区 | 无码午夜成人1000部免费视频 | 国内老熟妇对白xxxxhd | 国产精品亚洲五月天高清 | 国产精品久久久一区二区三区 | 美女毛片一区二区三区四区 | 日韩人妻无码一区二区三区久久99 | 夜精品a片一区二区三区无码白浆 | 漂亮人妻洗澡被公强 日日躁 | 中文字幕人妻无码一夲道 | 女人被男人躁得好爽免费视频 | 男人的天堂av网站 | 久久国产劲爆∧v内射 | 国内精品人妻无码久久久影院 | 天堂久久天堂av色综合 | 中文字幕人妻无码一区二区三区 | 亚洲色欲色欲天天天www | 久久久久亚洲精品男人的天堂 | 国产黑色丝袜在线播放 | 97se亚洲精品一区 | 曰韩少妇内射免费播放 | 国产亚洲日韩欧美另类第八页 | 日本一本二本三区免费 | 丰满妇女强制高潮18xxxx | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲成av人在线观看网址 | 国产国产精品人在线视 | 在线成人www免费观看视频 | 久久97精品久久久久久久不卡 | 国产成人久久精品流白浆 | 三级4级全黄60分钟 | 大肉大捧一进一出视频出来呀 | 内射爽无广熟女亚洲 | 在线欧美精品一区二区三区 | 日韩精品成人一区二区三区 | 永久免费观看国产裸体美女 | 粗大的内捧猛烈进出视频 | 无码av中文字幕免费放 | 国产热a欧美热a在线视频 | 国产亚洲精品久久久闺蜜 | 人人超人人超碰超国产 | 国产精品毛片一区二区 | 国产成人午夜福利在线播放 | 99riav国产精品视频 | 国产特级毛片aaaaaa高潮流水 | 在线欧美精品一区二区三区 | 夜夜躁日日躁狠狠久久av | 无码免费一区二区三区 | 综合网日日天干夜夜久久 | 午夜精品一区二区三区在线观看 | 精品国产一区二区三区四区在线看 | 欧美第一黄网免费网站 | 六月丁香婷婷色狠狠久久 | 亚洲精品午夜无码电影网 | 精品无码一区二区三区的天堂 | 真人与拘做受免费视频 | 少妇人妻大乳在线视频 | 国产麻豆精品一区二区三区v视界 | 综合人妻久久一区二区精品 | 在线 国产 欧美 亚洲 天堂 | 伊人久久大香线蕉亚洲 | 精品无码一区二区三区的天堂 | 少妇无套内谢久久久久 | 呦交小u女精品视频 | 99精品国产综合久久久久五月天 | 国产人妻人伦精品 | 麻豆成人精品国产免费 | 无套内射视频囯产 | 国产精品人妻一区二区三区四 | 国产成人精品视频ⅴa片软件竹菊 | 伊人久久大香线蕉午夜 | 玩弄少妇高潮ⅹxxxyw | 国产精品沙发午睡系列 | 欧美色就是色 | 天天拍夜夜添久久精品大 | 亚洲日本va午夜在线电影 | 久久综合色之久久综合 | 精品人妻人人做人人爽 | 国产无遮挡又黄又爽又色 | 成人片黄网站色大片免费观看 | 97无码免费人妻超级碰碰夜夜 | 久激情内射婷内射蜜桃人妖 | 十八禁真人啪啪免费网站 | 东北女人啪啪对白 | 亚洲 a v无 码免 费 成 人 a v | 日韩少妇白浆无码系列 | 狠狠亚洲超碰狼人久久 | 97夜夜澡人人爽人人喊中国片 | 男女猛烈xx00免费视频试看 | 日本成熟视频免费视频 | 久久99精品久久久久久动态图 | 中文字幕av日韩精品一区二区 | 久久久久久久久888 | 正在播放老肥熟妇露脸 | a在线亚洲男人的天堂 | 大色综合色综合网站 | 成人欧美一区二区三区黑人免费 | 亚洲gv猛男gv无码男同 | 亚洲日韩av一区二区三区中文 | 国产尤物精品视频 | 亚洲精品一区二区三区四区五区 | 曰韩无码二三区中文字幕 | 久久久久99精品成人片 | 久久99精品国产麻豆 | 中国大陆精品视频xxxx | 婷婷五月综合激情中文字幕 | 亚洲国产精品毛片av不卡在线 | 亚洲最大成人网站 | 男人扒开女人内裤强吻桶进去 | 中文字幕乱妇无码av在线 | 久久婷婷五月综合色国产香蕉 | 免费视频欧美无人区码 | 欧美真人作爱免费视频 | v一区无码内射国产 | 色 综合 欧美 亚洲 国产 | 欧美日韩久久久精品a片 | 欧美日本免费一区二区三区 | 人人妻人人澡人人爽欧美一区 | 六十路熟妇乱子伦 | 国产在线aaa片一区二区99 | 国产精品久久久久无码av色戒 | 国产国产精品人在线视 | 娇妻被黑人粗大高潮白浆 | 午夜福利不卡在线视频 | 欧美高清在线精品一区 | 国产99久久精品一区二区 | 人妻少妇精品无码专区动漫 | 欧洲极品少妇 | 日日摸天天摸爽爽狠狠97 | 日本爽爽爽爽爽爽在线观看免 | 亚洲aⅴ无码成人网站国产app | 77777熟女视频在线观看 а天堂中文在线官网 | 99久久99久久免费精品蜜桃 | 秋霞特色aa大片 | 国产精品久久久午夜夜伦鲁鲁 | 欧美xxxxx精品 | 亚洲а∨天堂久久精品2021 | 精品久久久久久人妻无码中文字幕 | 东京无码熟妇人妻av在线网址 | 亚洲天堂2017无码中文 | 色欲久久久天天天综合网精品 | 99riav国产精品视频 | 日韩精品成人一区二区三区 | 沈阳熟女露脸对白视频 | 牛和人交xxxx欧美 | 亚洲日韩av一区二区三区四区 | 久久久久久久人妻无码中文字幕爆 | 免费看少妇作爱视频 | 亚洲综合无码久久精品综合 | 国精品人妻无码一区二区三区蜜柚 | 亚洲呦女专区 | 久久国产自偷自偷免费一区调 | 亚洲精品久久久久久久久久久 | 久久伊人色av天堂九九小黄鸭 | 国产精品久久国产精品99 | 国产婷婷色一区二区三区在线 | 高清国产亚洲精品自在久久 | 久久99精品久久久久久动态图 | 熟女少妇人妻中文字幕 | 精品久久久久久人妻无码中文字幕 | 日本丰满护士爆乳xxxx | 国产福利视频一区二区 | 国内精品久久毛片一区二区 | 少妇无套内谢久久久久 | 亚洲欧洲日本无在线码 | 九九久久精品国产免费看小说 | 欧美黑人性暴力猛交喷水 | 97色伦图片97综合影院 | 久久久久成人精品免费播放动漫 | 亚洲va中文字幕无码久久不卡 | 天堂在线观看www | 夜夜夜高潮夜夜爽夜夜爰爰 | 亚洲中文字幕乱码av波多ji | 欧美日韩人成综合在线播放 | 无码一区二区三区在线观看 | 人人妻人人澡人人爽人人精品 | 久久久国产精品无码免费专区 | 国产口爆吞精在线视频 | 中文无码伦av中文字幕 | 国产三级精品三级男人的天堂 | 国产三级精品三级男人的天堂 | 精品欧洲av无码一区二区三区 | 久久亚洲精品成人无码 | 国内丰满熟女出轨videos | 亚洲国产高清在线观看视频 | 精品国产aⅴ无码一区二区 | 一本大道久久东京热无码av | 国产无遮挡又黄又爽免费视频 | 色老头在线一区二区三区 | 日本www一道久久久免费榴莲 | 老熟女乱子伦 | 丰满妇女强制高潮18xxxx | 牲欲强的熟妇农村老妇女视频 | 国产午夜亚洲精品不卡 | 国产精品久久久久影院嫩草 | 成人无码影片精品久久久 | av无码不卡在线观看免费 | 中国女人内谢69xxxxxa片 | 国产又爽又黄又刺激的视频 | 永久免费观看国产裸体美女 | 日韩亚洲欧美精品综合 | 狠狠色噜噜狠狠狠7777奇米 | 亚洲人成影院在线观看 | 久久熟妇人妻午夜寂寞影院 | 国产精品18久久久久久麻辣 | 国产香蕉97碰碰久久人人 | 波多野42部无码喷潮在线 | 日日摸天天摸爽爽狠狠97 | 国产色xx群视频射精 | 久久综合色之久久综合 | 色欲人妻aaaaaaa无码 | 蜜臀aⅴ国产精品久久久国产老师 | 熟妇人妻无乱码中文字幕 | 少妇被粗大的猛进出69影院 | 又色又爽又黄的美女裸体网站 | 永久免费观看美女裸体的网站 | 久久99精品国产麻豆蜜芽 | 欧美日韩一区二区三区自拍 | 无码毛片视频一区二区本码 | 成人欧美一区二区三区黑人免费 | 亚洲综合色区中文字幕 | 国产内射老熟女aaaa | 大地资源网第二页免费观看 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 成 人影片 免费观看 | 好男人www社区 | 少妇被黑人到高潮喷出白浆 | 日本精品人妻无码77777 天堂一区人妻无码 | 免费无码肉片在线观看 | 亚洲日韩中文字幕在线播放 | 国产无遮挡吃胸膜奶免费看 | 无遮挡国产高潮视频免费观看 | 天天av天天av天天透 | 正在播放老肥熟妇露脸 | 高清无码午夜福利视频 | 领导边摸边吃奶边做爽在线观看 | 亚洲精品国产品国语在线观看 | 啦啦啦www在线观看免费视频 | 漂亮人妻洗澡被公强 日日躁 | 最近中文2019字幕第二页 | 久久久久久a亚洲欧洲av冫 | aa片在线观看视频在线播放 | 国产尤物精品视频 | 无码成人精品区在线观看 | 国产亚洲精品久久久久久国模美 | 日韩亚洲欧美中文高清在线 | 国产精品亚洲专区无码不卡 | 麻豆精产国品 | 国产亚洲tv在线观看 | 1000部夫妻午夜免费 | 高清不卡一区二区三区 | 日产精品99久久久久久 | 99久久精品午夜一区二区 | 捆绑白丝粉色jk震动捧喷白浆 | 国产成人精品视频ⅴa片软件竹菊 | 丰满护士巨好爽好大乳 | 亚洲狠狠色丁香婷婷综合 | 天天综合网天天综合色 | 欧美35页视频在线观看 | 亚洲毛片av日韩av无码 | 亚洲国产精华液网站w | 丰满诱人的人妻3 | 99久久久国产精品无码免费 | 熟女俱乐部五十路六十路av | 性欧美videos高清精品 | 久久久亚洲欧洲日产国码αv | 中文字幕av日韩精品一区二区 | 国产亚洲tv在线观看 | 欧美高清在线精品一区 | 高清无码午夜福利视频 | 鲁大师影院在线观看 | 精品aⅴ一区二区三区 | 亚洲无人区一区二区三区 | 曰韩无码二三区中文字幕 | 2019nv天堂香蕉在线观看 | 日韩在线不卡免费视频一区 | 国产午夜亚洲精品不卡下载 | 日韩av无码一区二区三区不卡 | 国产特级毛片aaaaaa高潮流水 | 无码国产色欲xxxxx视频 | 久久人人97超碰a片精品 | 亚洲精品中文字幕久久久久 | 国产精品久久国产三级国 | 成年美女黄网站色大免费视频 | 美女黄网站人色视频免费国产 | 成人aaa片一区国产精品 | 国产超级va在线观看视频 | 精品偷拍一区二区三区在线看 | 国产热a欧美热a在线视频 | 久久久中文字幕日本无吗 | 日本护士xxxxhd少妇 | 婷婷六月久久综合丁香 | 亚洲国产精品久久人人爱 | 一本加勒比波多野结衣 | 无码午夜成人1000部免费视频 | 中文亚洲成a人片在线观看 | 一本精品99久久精品77 | 久久久中文字幕日本无吗 | 国产午夜视频在线观看 | 国产人妻精品午夜福利免费 | 久久精品一区二区三区四区 | 亚洲一区二区三区播放 | 麻花豆传媒剧国产免费mv在线 | 国产电影无码午夜在线播放 | 无码人妻黑人中文字幕 | 日韩欧美中文字幕在线三区 | 丰满人妻被黑人猛烈进入 | 亚洲一区二区观看播放 | 久久人妻内射无码一区三区 | 最新国产麻豆aⅴ精品无码 | а天堂中文在线官网 | 人人爽人人澡人人高潮 | 在线精品亚洲一区二区 | 国产明星裸体无码xxxx视频 | 欧美35页视频在线观看 | 无码毛片视频一区二区本码 | 免费观看激色视频网站 | 伊人色综合久久天天小片 | 亚拍精品一区二区三区探花 | 国产精品手机免费 | 国产欧美亚洲精品a | 久久久久久久久蜜桃 | 天堂а√在线地址中文在线 | 最新国产乱人伦偷精品免费网站 | 性色欲情网站iwww九文堂 | 国产suv精品一区二区五 | 亚洲国产午夜精品理论片 | 欧美国产日产一区二区 | 亚洲码国产精品高潮在线 | 亚洲成熟女人毛毛耸耸多 | 免费网站看v片在线18禁无码 | 夫妻免费无码v看片 | 国精产品一品二品国精品69xx | 伊人久久大香线蕉午夜 | 欧洲欧美人成视频在线 | 国产凸凹视频一区二区 | 国内精品九九久久久精品 | 成人一在线视频日韩国产 | 久久久精品456亚洲影院 | 亚洲国产精品一区二区第一页 | 性色欲网站人妻丰满中文久久不卡 | 国产内射爽爽大片视频社区在线 | 免费乱码人妻系列无码专区 | 午夜福利不卡在线视频 | 中文字幕人妻无码一区二区三区 | 国产欧美熟妇另类久久久 | 欧美日韩在线亚洲综合国产人 | aⅴ在线视频男人的天堂 | 5858s亚洲色大成网站www | 日日噜噜噜噜夜夜爽亚洲精品 | 扒开双腿疯狂进出爽爽爽视频 | 波多野结衣一区二区三区av免费 | 国内少妇偷人精品视频免费 | 日日摸夜夜摸狠狠摸婷婷 | 中文字幕无码日韩欧毛 | 蜜桃无码一区二区三区 | 女人被爽到呻吟gif动态图视看 | 午夜无码人妻av大片色欲 | 中国大陆精品视频xxxx | 人妻中文无码久热丝袜 | 精品偷自拍另类在线观看 | 免费无码一区二区三区蜜桃大 | 少妇无码一区二区二三区 | 国产精品-区区久久久狼 | 高潮毛片无遮挡高清免费视频 | 欧美xxxxx精品 | 国产精品无套呻吟在线 | 爆乳一区二区三区无码 | 激情内射日本一区二区三区 | 免费网站看v片在线18禁无码 | 男女超爽视频免费播放 | 欧美成人免费全部网站 | 国内精品久久久久久中文字幕 | 亚洲成av人片天堂网无码】 | 伊人久久婷婷五月综合97色 | 精品成人av一区二区三区 | 国产又爽又猛又粗的视频a片 | 骚片av蜜桃精品一区 | 特黄特色大片免费播放器图片 | 国产精品美女久久久久av爽李琼 | www国产亚洲精品久久久日本 | 久久久久久av无码免费看大片 | 国内精品人妻无码久久久影院 | 99久久久无码国产aaa精品 | 丝袜人妻一区二区三区 | 成年美女黄网站色大免费全看 | 久久久久av无码免费网 | 久久国语露脸国产精品电影 | 永久免费观看美女裸体的网站 | 亚洲乱码中文字幕在线 | 欧美 日韩 亚洲 在线 | 人人妻人人澡人人爽人人精品浪潮 | 无码av岛国片在线播放 | 国产欧美亚洲精品a | 亚洲欧洲无卡二区视頻 | 18禁黄网站男男禁片免费观看 | 欧美精品免费观看二区 | 亚洲人成网站在线播放942 | 人人爽人人澡人人人妻 | 国产精品久久久 | 国产sm调教视频在线观看 | 国産精品久久久久久久 | 精品熟女少妇av免费观看 | 国产无套内射久久久国产 | 亚洲精品欧美二区三区中文字幕 | 亚洲色偷偷偷综合网 | 亚洲精品国产精品乱码视色 | 欧美精品一区二区精品久久 | 国产成人午夜福利在线播放 | 人人爽人人爽人人片av亚洲 | 欧美乱妇无乱码大黄a片 | 在线成人www免费观看视频 | 97色伦图片97综合影院 | 小鲜肉自慰网站xnxx | 欧美日韩色另类综合 | 精品无码成人片一区二区98 | 国产精品多人p群无码 | 俺去俺来也www色官网 | 十八禁视频网站在线观看 | 人妻与老人中文字幕 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲小说春色综合另类 | 玩弄少妇高潮ⅹxxxyw | 香港三级日本三级妇三级 | 天堂а√在线地址中文在线 | 国产亚洲精品久久久闺蜜 | 狠狠躁日日躁夜夜躁2020 | 18黄暴禁片在线观看 | 中文字幕无码乱人伦 | 日产国产精品亚洲系列 | 亚洲国产精品无码久久久久高潮 | 精品偷拍一区二区三区在线看 | 日日摸天天摸爽爽狠狠97 | 国产精品久久久久久无码 | 午夜免费福利小电影 | av香港经典三级级 在线 | 夜夜夜高潮夜夜爽夜夜爰爰 | 色诱久久久久综合网ywww | 国产后入清纯学生妹 | 免费无码一区二区三区蜜桃大 | 欧美zoozzooz性欧美 | 国产明星裸体无码xxxx视频 | 亚洲中文字幕无码中字 | 亚洲日韩精品欧美一区二区 | 77777熟女视频在线观看 а天堂中文在线官网 | 久久99国产综合精品 | 中文字幕无码av波多野吉衣 | 日韩精品无码一本二本三本色 | 丰满岳乱妇在线观看中字无码 | 精品 日韩 国产 欧美 视频 | 一本久久a久久精品亚洲 | 男人的天堂av网站 | 黑人巨大精品欧美一区二区 | 成 人 网 站国产免费观看 | 亚洲人成无码网www | 人妻中文无码久热丝袜 | 国产亚洲精品久久久ai换 | 十八禁真人啪啪免费网站 | 日韩精品无码免费一区二区三区 | 国产亚洲人成a在线v网站 | 天天摸天天透天天添 | 国产suv精品一区二区五 | 亚洲欧美综合区丁香五月小说 | 精品一区二区三区波多野结衣 | 国产熟妇高潮叫床视频播放 | 强辱丰满人妻hd中文字幕 | 国产成人精品视频ⅴa片软件竹菊 | 97久久国产亚洲精品超碰热 | 国产熟妇高潮叫床视频播放 | 成人欧美一区二区三区黑人免费 | 欧美国产日韩亚洲中文 | 日产精品99久久久久久 | 亚洲中文无码av永久不收费 | 动漫av网站免费观看 | 疯狂三人交性欧美 | 国产超级va在线观看视频 | 激情内射亚州一区二区三区爱妻 | 中文字幕av日韩精品一区二区 | 无码午夜成人1000部免费视频 | 成熟女人特级毛片www免费 | 最近的中文字幕在线看视频 | 亚洲色在线无码国产精品不卡 | 99在线 | 亚洲 | 午夜熟女插插xx免费视频 | 强奷人妻日本中文字幕 | 欧美人与动性行为视频 | 亚洲人亚洲人成电影网站色 | 波多野结衣av一区二区全免费观看 | 亚洲熟悉妇女xxx妇女av | 色综合久久中文娱乐网 | 亚洲人亚洲人成电影网站色 | 国产精品亚洲一区二区三区喷水 | 麻豆果冻传媒2021精品传媒一区下载 | 99久久精品日本一区二区免费 | 国内老熟妇对白xxxxhd | 中文字幕av伊人av无码av | 日本大乳高潮视频在线观看 | 日韩av无码一区二区三区 | 中文字幕日韩精品一区二区三区 | 在线精品国产一区二区三区 | 久久久精品成人免费观看 | 18禁止看的免费污网站 | 国产人成高清在线视频99最全资源 | 波多野42部无码喷潮在线 | 性欧美大战久久久久久久 | 久久久精品456亚洲影院 | 亚洲精品一区二区三区四区五区 | 日本乱人伦片中文三区 | 国产亚洲精品久久久久久国模美 | 国产人妻久久精品二区三区老狼 | 免费无码午夜福利片69 | 天天爽夜夜爽夜夜爽 | 免费观看黄网站 | 鲁大师影院在线观看 | 久久人人爽人人人人片 | 国产成人av免费观看 | 国产亲子乱弄免费视频 | 国产精品久久久久久久9999 | 任你躁国产自任一区二区三区 | 国产高清av在线播放 | 99久久精品日本一区二区免费 | 无码帝国www无码专区色综合 | 偷窥日本少妇撒尿chinese | 久久人人爽人人爽人人片ⅴ | 强辱丰满人妻hd中文字幕 | 欧美黑人乱大交 | 日本免费一区二区三区最新 | 久久久精品人妻久久影视 | 国模大胆一区二区三区 | 夜夜高潮次次欢爽av女 | 国产无遮挡又黄又爽免费视频 | 久久亚洲精品成人无码 | 少妇太爽了在线观看 | 永久免费观看国产裸体美女 | 国产特级毛片aaaaaa高潮流水 | 国产精品高潮呻吟av久久4虎 | 丰满护士巨好爽好大乳 | 免费人成在线观看网站 | 蜜桃av抽搐高潮一区二区 | 亚洲国产精品美女久久久久 | 国产极品美女高潮无套在线观看 | 精品无码av一区二区三区 | 久久久av男人的天堂 | 天天拍夜夜添久久精品大 | 99久久精品国产一区二区蜜芽 | www国产亚洲精品久久久日本 | 欧美老妇与禽交 | 亚洲中文字幕久久无码 | 国产人妻精品一区二区三区 | 帮老师解开蕾丝奶罩吸乳网站 | 领导边摸边吃奶边做爽在线观看 | 免费人成在线视频无码 | 日产国产精品亚洲系列 | 久久99国产综合精品 | 午夜精品久久久久久久久 | 蜜桃无码一区二区三区 | 国产无套内射久久久国产 | 亚洲精品一区二区三区在线 | 日日麻批免费40分钟无码 | 国产精品久久久久7777 | 国产真实乱对白精彩久久 | 国产精品亚洲专区无码不卡 | 国内揄拍国内精品少妇国语 | 97久久国产亚洲精品超碰热 | ass日本丰满熟妇pics | 牛和人交xxxx欧美 | 亚洲一区二区三区香蕉 | 一本大道久久东京热无码av | 国产免费观看黄av片 | 日日碰狠狠丁香久燥 | 日日摸天天摸爽爽狠狠97 | 色婷婷综合激情综在线播放 | 日韩欧美中文字幕在线三区 | 国内少妇偷人精品视频免费 | 久久天天躁狠狠躁夜夜免费观看 | 国产欧美亚洲精品a | 超碰97人人射妻 | 亚洲欧美国产精品专区久久 | 久久zyz资源站无码中文动漫 | 亚洲一区二区三区国产精华液 | 午夜精品一区二区三区的区别 | 亚无码乱人伦一区二区 | 欧洲熟妇精品视频 | 国产办公室秘书无码精品99 | 精品久久久久久人妻无码中文字幕 | 国内精品一区二区三区不卡 | 欧美老熟妇乱xxxxx | 鲁一鲁av2019在线 | 久久久国产精品无码免费专区 | 两性色午夜免费视频 | 曰韩少妇内射免费播放 | 成人一区二区免费视频 | 激情人妻另类人妻伦 | 亚洲欧美日韩国产精品一区二区 | 强伦人妻一区二区三区视频18 | 在线观看欧美一区二区三区 | 国产午夜精品一区二区三区嫩草 | 亚洲天堂2017无码 | 人人妻人人澡人人爽欧美一区九九 | 日韩精品a片一区二区三区妖精 | 中文字幕久久久久人妻 | 亚洲午夜福利在线观看 | 亚洲精品久久久久中文第一幕 | 18精品久久久无码午夜福利 | 国产精品丝袜黑色高跟鞋 | 日韩无码专区 | 日日天干夜夜狠狠爱 | 亚洲国产成人av在线观看 | 粗大的内捧猛烈进出视频 | 无码人妻精品一区二区三区不卡 | 熟女少妇在线视频播放 | 国产av一区二区三区最新精品 | 免费无码的av片在线观看 | 美女毛片一区二区三区四区 | 亚洲色欲色欲天天天www | 久久久久久久人妻无码中文字幕爆 | 日本精品人妻无码免费大全 | 久久久久免费精品国产 | 亚洲中文字幕在线无码一区二区 | 欧洲熟妇精品视频 | 在线播放亚洲第一字幕 | 亚洲毛片av日韩av无码 | 水蜜桃av无码 | 无码国模国产在线观看 | 天堂а√在线中文在线 | 久久亚洲中文字幕精品一区 | 5858s亚洲色大成网站www | 中文字幕无码av波多野吉衣 | √8天堂资源地址中文在线 | 久久aⅴ免费观看 | 国产成人一区二区三区在线观看 | 欧美性猛交内射兽交老熟妇 | 国产情侣作爱视频免费观看 | 国产精品久久久久久久9999 | 成人免费视频视频在线观看 免费 | 成人av无码一区二区三区 | 国产av一区二区精品久久凹凸 | 欧美国产亚洲日韩在线二区 | 国产精品久久久久9999小说 | 国产成人综合在线女婷五月99播放 | 亚洲爆乳精品无码一区二区三区 | 午夜福利试看120秒体验区 | 无码av岛国片在线播放 | 性啪啪chinese东北女人 | 免费男性肉肉影院 | 对白脏话肉麻粗话av | 精品乱子伦一区二区三区 | 国产高清av在线播放 | 国产凸凹视频一区二区 | 67194成是人免费无码 | 亚洲中文字幕成人无码 | 蜜桃视频韩日免费播放 | 午夜无码区在线观看 | 999久久久国产精品消防器材 | 亚洲欧洲日本综合aⅴ在线 | 2020久久香蕉国产线看观看 | 青青久在线视频免费观看 | 国产suv精品一区二区五 | 日本免费一区二区三区最新 | 乱人伦中文视频在线观看 | 久久精品国产大片免费观看 | 巨爆乳无码视频在线观看 | 白嫩日本少妇做爰 | 少妇的肉体aa片免费 | 亚洲の无码国产の无码步美 | 亚洲精品综合一区二区三区在线 | 久久久中文久久久无码 | 在线精品亚洲一区二区 | 日本丰满护士爆乳xxxx | 日本一卡2卡3卡四卡精品网站 | 精品熟女少妇av免费观看 | 欧美黑人巨大xxxxx | 久青草影院在线观看国产 | 国产后入清纯学生妹 | 欧美国产日韩久久mv | 人妻有码中文字幕在线 | 青草视频在线播放 | 丰满诱人的人妻3 | 蜜桃视频插满18在线观看 | 国语精品一区二区三区 | 精品国产乱码久久久久乱码 | 久久午夜夜伦鲁鲁片无码免费 | 日欧一片内射va在线影院 | 欧美人妻一区二区三区 | 欧美一区二区三区视频在线观看 | 图片区 小说区 区 亚洲五月 | 牛和人交xxxx欧美 | 精品久久久久香蕉网 | 99久久婷婷国产综合精品青草免费 | 老司机亚洲精品影院 | 色综合久久久无码中文字幕 | 国产无套粉嫩白浆在线 | 亚欧洲精品在线视频免费观看 | 精品国产av色一区二区深夜久久 | 日韩成人一区二区三区在线观看 | 久久99精品久久久久婷婷 | 国产午夜福利亚洲第一 | 福利一区二区三区视频在线观看 | 亚洲人成人无码网www国产 | 国产精品无码一区二区三区不卡 | 成人免费无码大片a毛片 | 国产在线一区二区三区四区五区 | 人妻无码αv中文字幕久久琪琪布 | 国产精品对白交换视频 | 精品欧洲av无码一区二区三区 | 亚洲色偷偷偷综合网 | 大地资源网第二页免费观看 | 国产区女主播在线观看 | 国产午夜亚洲精品不卡下载 | 天海翼激烈高潮到腰振不止 | 亚洲 另类 在线 欧美 制服 | 中国大陆精品视频xxxx | 国产人妻精品一区二区三区 | 国产乱人偷精品人妻a片 | 亚洲第一无码av无码专区 | 鲁大师影院在线观看 | 国产成人精品必看 | 国产成人久久精品流白浆 | 国产熟妇高潮叫床视频播放 | 亚洲中文字幕在线无码一区二区 | 在线亚洲高清揄拍自拍一品区 | 特大黑人娇小亚洲女 | 亚洲精品一区二区三区婷婷月 | 国产精品多人p群无码 | 国产乡下妇女做爰 | 欧美日韩色另类综合 | 精品久久久久久人妻无码中文字幕 | 荫蒂添的好舒服视频囗交 | 精品国产麻豆免费人成网站 | 久久zyz资源站无码中文动漫 | 天天拍夜夜添久久精品 | 国产高潮视频在线观看 | 荡女精品导航 | 18无码粉嫩小泬无套在线观看 | 亚洲 欧美 激情 小说 另类 | 秋霞成人午夜鲁丝一区二区三区 | 久久精品国产精品国产精品污 | 欧美喷潮久久久xxxxx | 久久人人97超碰a片精品 | 久久aⅴ免费观看 | 免费人成在线视频无码 | 日本护士xxxxhd少妇 | 99久久久无码国产aaa精品 | 狠狠色噜噜狠狠狠狠7777米奇 | 乱人伦人妻中文字幕无码 | 国产成人无码av片在线观看不卡 | 中文字幕人妻无码一区二区三区 | 国产av一区二区精品久久凹凸 | 日日麻批免费40分钟无码 | 国产av一区二区三区最新精品 | 国产亚洲人成a在线v网站 | 国产凸凹视频一区二区 | 日韩精品乱码av一区二区 | 131美女爱做视频 | 熟妇人妻激情偷爽文 | 人妻体内射精一区二区三四 | 久久久久亚洲精品男人的天堂 | 97精品国产97久久久久久免费 | 一二三四在线观看免费视频 | 网友自拍区视频精品 | 亚洲精品午夜无码电影网 | 老司机亚洲精品影院无码 | 扒开双腿疯狂进出爽爽爽视频 | 精品成人av一区二区三区 | 亚洲精品中文字幕乱码 | 蜜桃臀无码内射一区二区三区 | 小sao货水好多真紧h无码视频 | 男女爱爱好爽视频免费看 | 麻豆蜜桃av蜜臀av色欲av | 在线精品国产一区二区三区 | 人妻尝试又大又粗久久 | 5858s亚洲色大成网站www | 亚洲国产精品一区二区第一页 | 日韩 欧美 动漫 国产 制服 | 国产成人综合在线女婷五月99播放 | 国产色xx群视频射精 | 久久精品丝袜高跟鞋 | 特黄特色大片免费播放器图片 | 精品国产国产综合精品 | 日本乱人伦片中文三区 | 国产黑色丝袜在线播放 | 红桃av一区二区三区在线无码av | 无遮挡国产高潮视频免费观看 | 亚洲小说图区综合在线 | 大色综合色综合网站 | 亚洲精品成a人在线观看 | 国产三级久久久精品麻豆三级 | 国产成人无码区免费内射一片色欲 | 日韩av无码中文无码电影 | 黑人粗大猛烈进出高潮视频 | 大地资源网第二页免费观看 | 影音先锋中文字幕无码 | 国内揄拍国内精品少妇国语 | 蜜臀av无码人妻精品 | 日本熟妇人妻xxxxx人hd | 嫩b人妻精品一区二区三区 | 久久无码中文字幕免费影院蜜桃 | 精品成在人线av无码免费看 | 熟妇人妻无码xxx视频 | 国产色在线 | 国产 | 国产亚洲精品久久久久久国模美 | 久久久亚洲欧洲日产国码αv | 给我免费的视频在线观看 | 人妻插b视频一区二区三区 | 无码福利日韩神码福利片 | 99久久婷婷国产综合精品青草免费 | 少妇高潮一区二区三区99 | 精品久久久无码中文字幕 | 国精品人妻无码一区二区三区蜜柚 | 久精品国产欧美亚洲色aⅴ大片 | 成人欧美一区二区三区黑人免费 | 综合激情五月综合激情五月激情1 | 免费无码av一区二区 | 成人免费视频视频在线观看 免费 | 久精品国产欧美亚洲色aⅴ大片 | 国产成人人人97超碰超爽8 | 午夜嘿嘿嘿影院 | 国产绳艺sm调教室论坛 | 亚洲欧美精品aaaaaa片 | 国产特级毛片aaaaaa高潮流水 | 九九在线中文字幕无码 | 激情综合激情五月俺也去 | 国产精品久久久久久久影院 | 亚洲一区二区三区四区 | 在线视频网站www色 | 亚洲日韩av片在线观看 | 丰腴饱满的极品熟妇 | 欧美精品国产综合久久 | 中文字幕av日韩精品一区二区 | 婷婷五月综合激情中文字幕 | 无码人妻丰满熟妇区五十路百度 | 精品人妻人人做人人爽 | 欧美 日韩 人妻 高清 中文 | 成人精品一区二区三区中文字幕 | 男女超爽视频免费播放 | 99久久人妻精品免费一区 | 亚洲色偷偷男人的天堂 | 欧美真人作爱免费视频 | 免费观看的无遮挡av | 亚洲 a v无 码免 费 成 人 a v | 天天躁夜夜躁狠狠是什么心态 | 国产真人无遮挡作爱免费视频 | 强奷人妻日本中文字幕 | 一二三四社区在线中文视频 | 国产精品久久国产三级国 | 欧美老熟妇乱xxxxx | 国产成人无码午夜视频在线观看 | 国产激情艳情在线看视频 | 久久人妻内射无码一区三区 | 精品国产av色一区二区深夜久久 | 国产av剧情md精品麻豆 | 熟妇人妻无乱码中文字幕 | 欧美肥老太牲交大战 | 国产精品爱久久久久久久 | 又大又紧又粉嫩18p少妇 | 亚洲精品国产精品乱码不卡 | 夜精品a片一区二区三区无码白浆 | 久久精品国产99久久6动漫 | 亚洲日本一区二区三区在线 | 亚洲国产欧美日韩精品一区二区三区 | 女人被男人爽到呻吟的视频 | 夜夜高潮次次欢爽av女 | 国产农村乱对白刺激视频 | 国内精品人妻无码久久久影院蜜桃 | 日韩人妻无码一区二区三区久久99 | 少妇厨房愉情理9仑片视频 | 久久国产精品偷任你爽任你 | 乱人伦人妻中文字幕无码 | 国产成人无码a区在线观看视频app | 性欧美牲交在线视频 | 搡女人真爽免费视频大全 | 桃花色综合影院 | 国产无遮挡吃胸膜奶免费看 | 国产成人无码av在线影院 | 国产精品a成v人在线播放 | 亚洲狠狠婷婷综合久久 | 国产亚洲精品久久久久久国模美 | 精品成人av一区二区三区 | 日本va欧美va欧美va精品 | 国产精品无套呻吟在线 | 国产精品二区一区二区aⅴ污介绍 | 欧洲精品码一区二区三区免费看 | 亚洲精品美女久久久久久久 | 国产卡一卡二卡三 | 国产在热线精品视频 | 日日噜噜噜噜夜夜爽亚洲精品 | 天海翼激烈高潮到腰振不止 | 精品偷自拍另类在线观看 | 欧美丰满少妇xxxx性 | 99久久久国产精品无码免费 | 久久精品女人天堂av免费观看 | 天天摸天天碰天天添 | 国产免费无码一区二区视频 | 中文字幕日韩精品一区二区三区 | 亚洲va中文字幕无码久久不卡 | 夜先锋av资源网站 | 亚洲精品综合一区二区三区在线 | 老司机亚洲精品影院 | 中文精品久久久久人妻不卡 | 伦伦影院午夜理论片 | 大地资源中文第3页 | 黑人大群体交免费视频 | 99久久亚洲精品无码毛片 | 久久人人爽人人爽人人片ⅴ | 无遮挡啪啪摇乳动态图 | 人人妻人人澡人人爽欧美一区九九 | 男人的天堂2018无码 | 亚洲 欧美 激情 小说 另类 | 蜜桃av抽搐高潮一区二区 | 67194成是人免费无码 | 日韩av无码中文无码电影 | 麻豆人妻少妇精品无码专区 | 亚洲自偷精品视频自拍 | 亚洲国产午夜精品理论片 | 国产女主播喷水视频在线观看 | 色诱久久久久综合网ywww | 日本在线高清不卡免费播放 | 人妻有码中文字幕在线 | 国产亚洲美女精品久久久2020 | 亚洲伊人久久精品影院 | 国产手机在线αⅴ片无码观看 | 亚洲区欧美区综合区自拍区 | 国产在线aaa片一区二区99 | 大肉大捧一进一出视频出来呀 | 亚洲一区av无码专区在线观看 | 午夜理论片yy44880影院 | 大地资源网第二页免费观看 | 国产激情无码一区二区app | 国产真人无遮挡作爱免费视频 | 亚洲日本一区二区三区在线 | 精品无码国产一区二区三区av | 强辱丰满人妻hd中文字幕 |