机器学习实战笔记1)K-近邻算法:实战篇

问题
为了提高我的B格,我打算买瓶红酒尝尝。但是我对红酒一窍不通,不知道该如何鉴别红酒质量的好坏。于是突发奇想,能否使用K-近邻算法来帮助我选择呢?

数据准备
我在网上下载了红酒的数据集。该数据集收集了红酒的11种特征及专家对每种酒的评价。这是数据的下载地址,下面列举了部分样本数据:

|序号|非挥发性酸度|挥发性酸度|柠檬酸|残留糖|氯化物|游离二氧化硫|总二氧化硫|浓度|PH值|硫酸盐|酒精度|质量|
|---|
|1|7|0.27|0.36|20.7|0.045|45|170|1.001|3|0.45|8.8|6|
|2|6.3|0.3|0.34|1.6|0.049|14|132|0.994|3.3|0.49|9.5|6|
|3|7.9|0.18|0.37|1.2|0.04|16|75|0.992|3.18|0.63|10.8|5|

数据的处理一共包括两个步骤:读取数据及数据预处理。读取数据部分将数据分成红酒数据部分及标签部分。数据预处理主要是对数据部分进行归一化处理。代码如下:

import numpy as np
import csv

def generateData(filename):
    data = []
    with open(filename, 'r') as csvfile:
    reader = csv.reader(csvfile, delimiter=';')
    data = [row for row in reader]
    data = data[1:]

data = np.array(data)

label = data[:,-1]
data = data[:,:-1]

data = data.astype(np.float)
label = label.astype(np.float)

#normlize to [0,1]
minVals = data.min(0)
maxVals = data.max(0)
data = (data-minVals)/(maxVals-minVals)

return data, label

K-近邻算法
下面来写K-近邻算法的核心算法,算法的流程大概如下:首先计算测试样本与所有训练样本之间的距离,选出距离最近的K个样本,将这K个样本中标签最多的标签作为这个测试样本的标签,代码如下:

 import numpy as np
 import csv
 import operator

def knnclassify(testData, trainData, trainLabel,k):
    diff = trainData - testData
    diffSq = diff**2
    distances = np.sqrt(np.sum(diffSq, axis = 1))
    sortedDistdicies = distances.argsort()
    classCount = {}
  for i in range(k):
      votedLabel = trainLabel[sortedDistdicies[i]]
      classCount[votedLabel] = classCount.get(votedLabel, 0) + 1
  sortedClassCount = sorted(classCount.iteritems(),key=operator.itemgetter(1), reverse=True)
  return sortedClassCount[0][0]

现在我买了一瓶红酒,并记录下它的各种特征,判断它等级的代码如下:

testData = np.array([0.2,0.3,0.11,0.13,0.16,0.2,0.3,0.11,0.13,0.16,0.27])
data, label = generateData('winequality-red.csv')

k=9
level = knnclassify(testData, data, label, k)
print level

从结果可以看出,我们这瓶酒的等级为5,属于中等红酒。对于我这种level来说,应该足够了。

评价分类器 在我品尝这瓶红酒的时候,我心中不禁有点不安:如果这个K-近邻分类方法“骗了”我怎么办? 作为一个严谨的人,我一定得找到一个方法来检验这个分类器的效度。

验证分类器的方法非常简单,首先我们将之前的数据一分为二,一份作为训练集,一份作为测试集。用训练集来预测测试集,因为我们已经知道测试集的真正等级,所以,我们可以通过比较我们的预测结果与真实结果之间的差异来评估分类器的效度。测试的代码为:

data, label = generateData('winequality-red.csv')
ratio = 0.1
k = 9
m = int(ratio*data.shape[0])
testData = data[:m];
trainData = data[m:]
testLabel = label[:m]
trainLabel = label[m:]

errorCount = 0
for i in range(testData.shape[0]):
    predict = knnclassify(testData[i], trainData, trainLabel, k)
    print "the predict is %f, the ground truth is %f" %(predict, testLabel[i])
    if(predict != testLabel[i]):
        errorCount = errorCount + 1;

print "the total error rate is %f" %(errorCount/float(testData.shape[0]))

最后输出的错误率为0.39。还是比较可信,至少是个及格的分数。在后面的文章中,我会尝试使用其他的分类方法,以期达到更好的结果。

关于K的选择
在前面的代码中,K的值我都取做9,但是在实践中,我们需要通过实验得出K的最佳取值。操作也非常简单,就是K取不同的值,然后得出不同的错误率,取错误率最低的那个K值作为我们最终的选择。

本篇文章的完整代码可以在这里下载

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容