3 机器学习之假设空间

归纳(induction)与演绎(deduction)是科学推理的两大基本手段。前者是从特殊到一般的"泛化"(generalization)过程,即从具体的事实归结出一般性规律;后者则是从一般到特殊的"特化"(specialization)过程,即从基础原理推演出具体状况。例如,在数学公理系统中,基于一组公理和推理规则推导出与之相洽的定理,这是演绎;而"从样例中学习"显然是一个归纳的过程,因此亦称"归纳学习"(inductivelearning)。

归纳学习有狭义与广义之分,广义的归纳学习大体相当于从样例中学习,而狭义的归纳学习则要求从训练数据中学得概念(concept),因此亦称为"概念学习"或"概念形成"​。概念学习技术目前研究、应用都比较少,因为要学得泛化性能好且语义明确的概念实在太困难了,现实常用的技术大多是产生"黑箱"模型。然而,对概念学习有所了解,有助于理解机器学习的一些基础思想。

概念学习中最基本的是布尔概念学习,即对"是"​"不是"这样的可表示为0/1布尔值的目标概念的学习。举一个简单的例子,假定我们获得了这样一个训练数据集:

表1.1 西瓜数据集

更一般的情况是考虑形如(A∧B)∨(C∧D)的析合范式。

这里要学习的目标是"好瓜"​。暂且假设"好瓜"可由"色泽"​"根蒂"​"敲声"这三个因素完全确定,换言之,只要某个瓜的这三个属性取值明确了,我们就能判断出它是不是好瓜。于是,我们学得的将是"好瓜是某种色泽、某种根蒂、某种敲声的瓜"这样的概念,用布尔表达式写出来则是"好瓜。​(色泽=?​)∧(根蒂=?​)∧(敲声=?​)​"​,这里"​?​"表示尚未确定的取值,而我们的任务就是通过对表1.1的训练集进行学习,把"​?​"确定下来。

"记住"训练样本,就能力。如果仅仅把训练集中的瓜"记住"​,是所谓的"机械学习"​[Cohen and Feigenbaum,1983]​,或称"死记硬背式学习"​,参见(1.5 发展历程)​。

读者可能马上发现,表1.1第一行:​"​(色泽=青绿)∧(根蒂=蜷缩)∧(敲声=浊响)​"不就是好瓜吗?是的,但这是一个已见过的瓜,别忘了我们学习的目的是"泛化"​,即通过对训练集中瓜的学习以获得对没见过的瓜进行判断的能力。如果仅仅把训练集中的瓜"记住"​,今后再见到一模一样的瓜当然可判断,但是,对没见过的瓜,例如"​(色泽=浅白)∧(根蒂=蜷缩)∧(敲声=浊响)​"怎么办呢?

这里我们假定训练样本不含噪声,并且不考虑"非青绿"这样的操作。由于训练集包含正例,因此假设自然不出现。

我们可以把学习过程看作一个在所有假设(hypothesis)组成的空间中进行搜索的过程,搜索目标是找到与训练集"匹配"(fit)的假设,即能够将训练集中的瓜判断正确的假设。假设的表示一旦确定,假设空间及其规模大小就确定了。这里我们的假设空间由形如"​(色泽=?​)∧(根蒂=?​)∧(敲声=?​)​"的可能取值所形成的假设组成。例如色泽有"青绿"​"乌黑"​"浅白"这三种可能取值;还需考虑到,也许"色泽"无论取什么值都合适,我们用通配符""来表示,例如"好瓜。​(色泽= )∧(根蒂=蜷缩)∧(敲声=浊响)​"​,即"好瓜是根蒂蜷缩、敲声浊响的瓜,什么色泽都行"​。此外,还需考虑极端情况:有可能"好瓜"这个概念根本就不成立,世界上没有"好瓜"这种东西;我们用表示这个假设。这样,若"色泽"​"根蒂"​"敲声"分别有3、3、3种可能取值,则我们面临的假设空间规模大小为4×4×4+1=65。图1.1直观地显示出了这个西瓜问题假设空间。

图1.1 西瓜问题的假设空间

有许多可能的选择,如在路径上自顶向下与自底向上同时进行,在操作上只删除与正例不一致的假设等。

可以有许多策略对这个假设空间进行搜索,例如自顶向下、从一般到特殊,或是自底向上、从特殊到一般,搜索过程中可以不断删除与正例不一致的假设、和(或)与反例一致的假设。最终将会获得与训练集一致(即对所有训练样本能够进行正确判断)的假设,这就是我们学得的结果。

需注意的是,现实问题中我们常面临很大的假设空间,但学习过程是基于有限样本训练集进行的,因此,可能有多个假设与训练集一致,即存在着一个与训练集一致的"假设集合"​,我们称之为"版本空间"(version space)。例如,在西瓜问题中,与表1.1训练集所对应的版本空间如图1.2所示。

图1.2 西瓜问题的版本空

相关推荐
zhangfeng11333 分钟前
超算中心海光异构卡dcu bw 64G显卡报错 nccl通讯错误,无法通过设置来解决的办法,需要安装shca IB卡驱动
人工智能
m0_737246984 分钟前
QDKT2-1. Dify 本地部署 & 模型插件配置
人工智能·产品经理
nix.gnehc5 分钟前
手搓 MCP 服务:从零实现 Model Context Protocol 的实践记录
人工智能·mcp·http+sse
动物园猫9 分钟前
火焰与烟雾目标检测数据集分享(适用于YOLO系列深度学习分类检测任务)
深度学习·yolo·目标检测
wuxinyan12311 分钟前
大模型学习之路010:RAG 零基础入门教程(第六篇):重排序技术
人工智能·学习·rag
oscar99915 分钟前
给 AI 编程助手立规矩:OpenCode 的自定义指令体系
人工智能·rule·opencode
SilentSamsara20 分钟前
迭代器协议:`__iter__` / `__next__` 的完整执行流程
开发语言·人工智能·python·算法·机器学习
AI科技星20 分钟前
算法联盟ROOT · 全域数学物理卷第20、21、22分册:量子纠缠、隐形场论与时间膨胀
人工智能·算法·数学建模·数据挖掘·机器人
Android出海24 分钟前
ChatGPT Image2 2.0正式上线:功能解析 + 使用教程(附提示词)
人工智能·ai·chatgpt·ai生图·chatgpt image2·images2
CoderJia程序员甲40 分钟前
GitHub 热榜项目 - 周榜(2026-05-10)
人工智能·ai·大模型·llm·github