【小白自学笔记】【机器学习实战】【Python代码逐行理解】CH02

本文主要是介绍【小白自学笔记】【机器学习实战】【Python代码逐行理解】CH02,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一个给出的是一个非常简单的例子:给出四个训练集数据(0,0)(0,0.1)【A类】(1,1)(1,1.1)【B类】   

然后让你输入一个数字判断从属于A类还是B类

方法也很简单粗暴,离这个点的距离近的3个【k个】点,属于标签A的多,就判给A,B的多就判给B

问题:距离怎么算?

方法很简单:欧氏距离。

好了。所以我们代码的核心就是写出这个欧氏距离,

涉及到几点注意点:1.要根据训练集有多少个数据(比如4个)然后把待判数据也复制成这么多行的矩阵【目的:方便一会儿整个矩阵相减,不用循环了】

2.相减平方直接把矩阵平方即可

3.求和的时候,要按照行求和,毕竟要求每个【分量】或者说特征,的差异,加在一块儿求和是总差异

4.最后,把所有差异的数值从小到大排个序。得到【索引】

def classify0(inX, dataSet, labels, k):
    dataSetSize = dataSet.shape[0] #确定有几行
    diffMat = tile(inX, (dataSetSize,1)) - dataSet#把输入复制n条
    sqDiffMat = diffMat**2   #平方
    sqDistances = sqDiffMat.sum(axis=1)  #平方后矩阵按行相加求和
    distances = sqDistances**0.5  #总距离=距离和开方
    sortedDistIndicies = distances.argsort()#把总距离索引从小到大排序

    classCount={}          

    for i in range(k):
        voteIlabel = labels[sortedDistIndicies[i]]#距离从小到大的标签 比如录入第一个,这里是A
        classCount[voteIlabel] = classCount.get(voteIlabel,0) + 1#应该是统计A和B和各种的数量
    sortedClassCount = sorted(classCount.iteritems(), key=operator.itemgetter(1), reverse=True) #AK:按字典的键值排序?
    return sortedClassCount[0][0]#然后返回的是最大的那个数量的值?



附:各个代码中的函数的注解:

axis=0意味着从列开始往下走,axis=1意味着从行开始【叠加或计数或what】

operator.itemgetter函数
operator模块提供的itemgetter函数用于获取对象的哪些维的数据,参数为一些序号(即需要获取的数据在对象中的序号),下面看例子。

a = [1,2,3] 
>>> b=operator.itemgetter(1)      //定义函数b,获取对象的第1个域的值
>>> b(a) 

>>> b=operator.itemgetter(1,0)  //定义函数b,获取对象的第1个域和第0个的值

>>> b(a) 
(2, 1)

要注意,operator.itemgetter函数获取的不是值,而是定义了一个函数,通过该函数作用到对象上才能获取值


argsort函数
返回的是数组值从小到大的索引值
Examples
-------->>> x = np.array([3, 1, 2])
>>> np.argsort(x)
array([1, 2, 0])

tile的用法


首先要记住Python里面是0列1行 也就是0代表按列来↓↓↓  1代表按行来→

所以说dataset.min(0)代表的是每列的最小值,那么这个应该是一个行向量【1,2,3】

dataset.min(1)代表的是每行的最小值,那么这个应该是一个一维列向量【1】

                 【2】

【1】这种

tile的用法是比如b = [1,2] 那么tile(b,(3,1))代表复制三行,一列b的值          【1,2】

【1,2】

【1,2】这种


这篇关于【小白自学笔记】【机器学习实战】【Python代码逐行理解】CH02的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/871125

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可