美文网首页
期末作业实验报告:KNN实验对比

期末作业实验报告:KNN实验对比

作者: 红茶绅士 | 来源:发表于2017-06-14 15:13 被阅读184次

工程构建

  • 导入sklearn相关包
import numpy as np
from sklearn import neighbors
  • 定义readDataSet(fileName, isTest)函数,用于加载训练数据,返回特征数据(dataSet)和标签(label)
# fileName: 文件名字
# isTest: =True为测试数据时,只有54列,label直接设0
def readDataSet(fileName, isTest):
    fr = open(fileName,encoding='utf-8')
    lines = fr.readlines()

    numLabels = len(lines) 
    labels = np.zeros(numLabels) #用于存放标签数据
    dateSet = np.zeros([numLabels,54],int) #用于存放特征数据

    # 逐行读取数据到dataSet,labels
    # 总共55列,前54列是样本特征,最后一列是样本类别(label)
    for i in range(numLabels):
        line = lines[i]
        label = 0
        if isTest:  #True:测试集只有54列,最后标签直接设为0
            label = 0
        else:  # False:取最后一列为标签数据
            label = line.split(' ')[54]
        labels[i] = label

        dates = np.zeros(54)
        for j in range(53): # 前54列添加为特征数据
            dates[j] = line.split(' ')[j]
        dateSet[i] = dates

    fr.close()
    return dateSet,labels

添加isTest参数是为了区别训练集(55列)与测试集数据(54列)列数不同,便于交叉验证时,统计错误数量,核算正确率.

  • 加载训练数据
train_dataSet,train_labels = readDataSet('data_train.txt', False)
  • 构建KNN分类器,并调用fit()函数
knn = neighbors.KNeighborsClassifier(algorithm='kd_tree', n_neighbors=3)
knn.fit(train_dataSet,train_labels)
  • 加载测试集,使用构建好的KNN分类器对测试集进行预测
test_dataSet,test_labels = readDataSet('test.txt', False)
res = knn.predict(test_dataSet)
error = 0
for i in range(len(res)):
    if res[i] != test_labels[i]:
        error += 1
print('error:',error,'正确率:',(len(res) - error) / len(res))

邻居数量K影响对比

n_neighbors 1 3 5 7
错误数量 1524 1446 1495 1621
正确率 0.96136 0.96333 0.96209 0.95889

k = 3时正确率最高,当K > 3 后正确率开始下降

相关文章

  • 期末作业实验报告:KNN实验对比

    工程构建 导入sklearn相关包 定义readDataSet(fileName, isTest)函数,用于加载训...

  • 期末作业实验报告:MLP实验对比

    工程构建 导入sklearn相关包 定义readDataSet(fileName, isTest)函数,用于加载训...

  • 随笔

    哇,下学期竟然没有课了,不过还有好多期末作业,和实验报告。

  • NJUPT《 嵌入式应用终端开发 》

    课程要求 1、上课考勤 6 次,课堂作业 3 次。2、上机实验 4 次:实验报告格式规范,内容充实。3、期末课程设...

  • 如何才能调节好团队协作?

    最近快到期末了,老师也分配了期末的考核作业,就是一个小组做一个实验报告,因为专业是计算机,所以实验就是一个 系统。...

  • FPGA 自动售货机大作业

    FPGA大作业实验报告 本实验报告分为实验目标,设计概述,细节详述,常见问题分析,总结,完整代码等部分。 实验目标...

  • 期末周的实验报告

    又是一个在期末周补实验报告的晚上 加油!

  • 第三节 用户及文件权限管理

    “Linux 基础入门(新版)”实验报告 用户及文件权限管理 Linux基础入门(新版)实验报告 作业操作 sud...

  • 2019-11-07三省吾身

    除了最后的期末考试(试卷那种),现在能够想到的作业/考试如下: 信息资源管理:实验报告(第六次实验)、期中小论文、...

  • 2019-11-12

    昨天写了实验报告,今天写了算法作业。

网友评论

      本文标题:期末作业实验报告:KNN实验对比

      本文链接:https://www.haomeiwen.com/subject/cxysqxtx.html