机器学习入门:概念原理及常用算法

简介: 机器学习入门:概念原理及常用算法

一:机器学习概念、原理和应用场景


1.1机器学习的基础概念


人工智能、机器学习、深度学习

人工智能从1950年兴起,1980年机器学习开始繁荣,2010年深度学习黑科技开始兴起,人工智能包含机器学习,机器学习包含深度学习,互相包含的关系。


20709e1c842a4dffbe6d892c0e100528.png


什么是人工智能?

经典的定义希望它能够像人一样思考,做事情,甚至是像人一样去推理,做一些更智能的事情,图灵测试,认知科学,老科学等。


b73767e571bb4c2b8c2f5de20e3a1c27.png


如上图所示,几个常用的领域,有推理,机器人,机器学习,知识,数据挖掘,自然语言处理,视觉领域,这样区分不是指这几个有严格的界限,只是非常粗糙的区别,人工智能的目标使得有这样的计算机像人一样智能的去做一些事情,总体的目标。


80fa44b37ccd40b6acdf0913fd2a8f5f.png


从实用主义的角度来看,跟学习相关,跟搜索,编程,planning,模型,社交,信息分类等,在背后指的都是机器学习。

什么是机器学习?

定义其实就是一类的计算方法,通过使用经验去改进性能,它经验主要是数据驱动的一些经验,通过从数据里面得到这些经验,跟数据相关的无非就是这样几个学科,一个是统计概率,还有优化理论通过这样几个理论结合数据让机器去学习,同时跟经验相关的还有包括计算机科学里面相关的,比如优化理论里面很多一个具体学习的算法,有这些算法就会有复杂度的分析,这个是跟计算机学科息息相关的。比如使用一个文档里面它的词的一个视频的技术去预测它大概是属于什么样的一个 topic ,比如一篇文章它到底是属于科技类的,娱乐类的还是别的一个类型的。


62e97f4d4e1f4339bc74eaafd7b3cdd1.png


机器学习被认为是一种方式,这种方式使得计算机能够按照它们自己的逻辑去做一些事情,比如给它一个三角形,告诉它这是个三角形,这个机器从此之后就认识这个东西就是三角形。通常的方法就是通过从数据里面去学,给它大量的例子,告诉它说不同形状的这些东西都是三角形,然后在某个瞬间它再看到一个三条边的一个形状的时候,它可能就会知道这个东西三角形,通过从这样一个数据里面,通过一定的算法来学到这个东西是三角形,这样的一个经验,或者是这样的一个知识。


当人们看到一张黑熊的照片,能够一眼分辨出来这个肯定是黑熊,因为人们在前面已经看见了大量的黑熊这样的知识,但是如果给的都是一些侧面的照片,人们也能知道它是黑熊,因为人可以从鼻子颜色清楚的知道它就是黑熊,基于学习希望机器也能够跟人的学习方式一样去让这个机器去学习,最终目标甚至都没有办法去区分在面前的到底是一个人还是一个机器。


1.2机器学习的领域


机器学习的领域

1、 Classification: assign a category to each item(e.g, document classification).

分类是分到一个具体的目录里面,把文档分为娱乐、科技、体育等等。

2、Regression: predict a real value for each item(prediction of stock values, economic variables).


违规是预测出一个实数的值比如股票预测股价,经济预测经济的增长速度,具体的值。


3、Ranking: order items according to some criterion(relevant web pages returned by a search engine).


排序是通过某一种标准去排序,比如搜索引擎里面,给它一个搜索目标,返回一系列排好序的结果。


4、Clustering: partition data into 'homogeneous’regions(analysis of very large data sets).


聚类,物以类聚,通过对一个数据的分析,把它分成几个大的区域。


5、Dimensionality reduction:find lower-dimensional manifold preserving some properties of the data.


维度的降维,去找一个比较好的低维的东西去展示原来的数据,但这个低维的东西可能保留一个原始的数据绝大部分有用的一个属性。


机器学习的目标:

1.Theoretical questions:

它是在什么样的条件下,什么东西能进行学习?

这些学习有理论上的保障吗?

给定一个学习算法之后,它会进行一些分析,算法学习的数据怎么样?它能收敛到一个什么样的情况,是不是可以收敛了等,这个是有一系列理论上的问题,也牵扯出一系列的学科、概率、统计、图优化等,这里有非常多的学科在后面做一些理论的支持和支撑。

2.Algorithms:

具体的算法,等解决了一些理论上的问题之后,来看具体的算法,去做的更加高效,更加准确,有没有去处理大数据,大规模的问题,有没有办法去提供一个种类丰富的算法集,或者一个学习问题有多种解等,每个目标里面都牵扯着机器学习里面的子学科。


定义跟术语:

1.example: item, instance of the data used.

2.Features:attibutes associated to an item, often represented as a vector(e.g, word counts).

3.Labels:category (clasification) or real value(regression)aassociated to an item.

4.Data:training data(typically labeled); test data (labeled but labels not seen); validation data (labeled, for tuning parameters).


Standard Scenarios

具体来看一下机器学习算法的分类,比如有 label 可以认为它是一个监督学习,没有 label 认为它是一个无监督学习,基于它们两者之间叫半监督,除此之外还有一种其实跟人下棋的状态很像,叫做强化学习,它是有一定的观察,然后你维护了一个状态的东西,通过这样一个动作获得一种奖罚机制,用这种方式来学习的叫做强化学习。


1、Unsupervised learning:


no labeled data.


监督跟非监督都非常像,只是中间没有 label。


b589a6a4833c4363987f3efb5ea9bbc9.png


2、Supervised learning:


uses labeled data for prediction on unseen points.

比如给一些芒果,里面有熟的有生的,那如果告诉芒果是熟的还是生的,通过图片,通过一个机器学习算法得到一个模型,这种认为是监督学习,如果把熟了或者没熟的这个东西给它去掉,这样就成为无监督学习,通过剧烈的方式,从流程图上看,这样一些东西拿来之后设计特征,送到一个集群的算法里面得到一个模型再进行预测。


9c3abf3a13a941d59f282d139c3da2ec.png


3、Semi-supervised learning:


uses labeled and unlabeled data for prediction on unseen points.

4.Reinforcement learning:


observation+ action+ reward+ state


强化学习这里用了一个老鼠走迷宫的方式,老鼠的头脑里面有状态图,通过 action 里面环境本身会有一个奖惩的机制,比如再某一个地方给它奖励或者惩罚,通过这样的方式更正或学习到一些东西同过来观察它能够去跟踪和学习到一些东西去更正它内部的状态,通过这样的方式进行学习。


4447bbd7dc6148db90fd1ed6a5b2cb9e.png


5、Formalize the Learning Problem


数学上形式化一下,x 为输入,通常它是一个输入的形式或者矩阵的形式,输出 y 是 label,通常它也是一个向量或矩阵方式,从 x 到 y去探索一个未知的模式,数据就是一大堆的训练样本,训练样本就是用数据的方式就是 xy,有些没有 y,希望从大量的 example 里面学到一个去探索这种未知的 f,最后学到一个积,这就是最终要学到的一个结果。


1.3机器为什么能学习


二:机器学习常用算法


2.1 监督学习-线性回归


2.2 非线性回归、过度拟合、模型选择


非线性回归:


4f70d61fc09b4b45a5f4bc5300ebc035.png


将抛物线的数据进行简单的修改变得到了下方的这张图,通过观察可以发现,;图中的图形形状是抛物线的形状,理论上与二次拟合的效果视为最佳,这种就被称之为二次非线性关系图。

过拟合:

x的多次方里面的高阶需求,使得我们可以通过高阶的需求来实现非线性的linear *regression。


*辅助理解视图如下:


0f2e8bf1895b43df8a6c54c114de8a9c.png


在之前的数据上加入二次方之后,图形也就成了下面的形状,由图可知,它非常好的拟合了数据的趋势。


c7fac75cf77e4521a2b3617deb1f2bc4.png


如果继续加大它的特征(从二次方加到十次方或者更大),则会出现过拟合的状况。如图所示:

d192f91a6dae45db99c7a1f743d56cf8.png

模型选择:

905d41fa9da74a42b31d703264d41d0f.png

通过观察图形,可以发现Training的值在不断下降,而Test的值在到达某个临界值后便开始反弹。


Overfitting模型的判定有很多种方式,运用的比较广泛的是通过Training和Test的值来进行判断其模型是否是Overfitting模型。由改图可知,模型的设计并不是越复杂越好,而是适用场景就足够了。


图中的公式为参考公式,平方与i的值都是可变的;不同的值可以视为不同的正则化方式。通过这种方式可以不断的进行过拟合来获得一个好的模型选择。

解决模型选择的问题可以使用七三分算法,将数据七三分,七的那一部分作为Training,三的那一部分作为Test。再者就是将数据分为两级。对于虚拟数据我们也可以使用七三分算法来验证。比如正择化的运用.


2.3 有监督分类学习

2.4 无监督分类学习

三:总结与联习

3.1 总结与练习

相关文章
|
2天前
|
算法 Java 数据库
理解CAS算法原理
CAS(Compare and Swap,比较并交换)是一种无锁算法,用于实现多线程环境下的原子操作。它通过比较内存中的值与预期值是否相同来决定是否进行更新。JDK 5引入了基于CAS的乐观锁机制,替代了传统的synchronized独占锁,提升了并发性能。然而,CAS存在ABA问题、循环时间长开销大和只能保证单个共享变量原子性等缺点。为解决这些问题,可以使用版本号机制、合并多个变量或引入pause指令优化CPU执行效率。CAS广泛应用于JDK的原子类中,如AtomicInteger.incrementAndGet(),利用底层Unsafe库实现高效的无锁自增操作。
理解CAS算法原理
|
1月前
|
算法 容器
令牌桶算法原理及实现,图文详解
本文介绍令牌桶算法,一种常用的限流策略,通过恒定速率放入令牌,控制高并发场景下的流量,确保系统稳定运行。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
令牌桶算法原理及实现,图文详解
|
23天前
|
存储 人工智能 缓存
【AI系统】布局转换原理与算法
数据布局转换技术通过优化内存中数据的排布,提升程序执行效率,特别是对于缓存性能的影响显著。本文介绍了数据在内存中的排布方式,包括内存对齐、大小端存储等概念,并详细探讨了张量数据在内存中的排布,如行优先与列优先排布,以及在深度学习中常见的NCHW与NHWC两种数据布局方式。这些布局方式的选择直接影响到程序的性能,尤其是在GPU和CPU上的表现。此外,还讨论了连续与非连续张量的概念及其对性能的影响。
46 3
|
28天前
|
机器学习/深度学习 人工智能 算法
探索人工智能中的强化学习:原理、算法与应用
探索人工智能中的强化学习:原理、算法与应用
|
1月前
|
负载均衡 算法 应用服务中间件
5大负载均衡算法及原理,图解易懂!
本文详细介绍负载均衡的5大核心算法:轮询、加权轮询、随机、最少连接和源地址散列,帮助你深入理解分布式架构中的关键技术。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
5大负载均衡算法及原理,图解易懂!
|
1月前
|
缓存 算法 网络协议
OSPF的路由计算算法:原理与应用
OSPF的路由计算算法:原理与应用
50 4
|
1月前
|
存储 算法 网络协议
OSPF的SPF算法介绍:原理、实现与应用
OSPF的SPF算法介绍:原理、实现与应用
84 3
|
28天前
|
机器学习/深度学习 人工智能 算法
探索人工智能中的强化学习:原理、算法及应用
探索人工智能中的强化学习:原理、算法及应用
|
2月前
|
算法 数据库 索引
HyperLogLog算法的原理是什么
【10月更文挑战第19天】HyperLogLog算法的原理是什么
112 1
|
1月前
|
机器学习/深度学习 算法 Python
机器学习入门:理解并实现K-近邻算法
机器学习入门:理解并实现K-近邻算法
36 0

热门文章

最新文章