机器学习基础(一)理解机器学习的本质

        导读:在本文中,将深入探索机器学习的根本原理,包括基本概念、分类及如何通过构建预测模型来应用这些理论。

目录

机器学习

机器学习概念

相关概念

机器学习根本:模型

数据的语言:特征与标签

训练与测试:模型评估

机器学习的分类

监督学习:有指导的学习过程

非监督学习:自我探索的过程

强化学习:通过试错学习

构建与分析鸢尾花数据模型

鸢尾花数据集简介

加载数据集

创建和训练模型

进行预测与评估模型


机器学习

机器学习概念

        机器学习是人工智能的一个分支,是一门开发算法和统计模型的科学,计算机系统使用这些算法和模型,在没有明确指令的情况下,依靠既有模式和推理来执行任务。在机器学习中,算法使用统计技术来使计算机能够“学习”数据,并基于这些数据做出预测或决策,而不是依靠严格的硬编码指令。机器学习这个领域的起源可以追溯到20世纪50年代,当时科学家们开始探索如何使计算机模拟人类学习过程。

        在机器学习探索和尝试的历史中,有几个关键时刻值得一提。例如,20世纪80年代的神经网络的复兴,以及2006年深度学习概念的提出,这些都极大推动了机器学习的发展。如今,随着计算能力的飞速提升和大数据的普及,机器学习开始快速发展,成为现代技术不可或缺的一部分,从智能手机应用到复杂的股市分析系统,机器学习无处不在,它正在塑造我们的生活方式和工作方式。

        机器学习之所以重要,是因为它为处理大量数据、发现模式、做出预测和决策提供了一种高效的方法。在医疗、金融、教育、零售等众多行业中,机器学习的应用都在带来革命性的变化,比如,医疗领域中的机器学习可以帮助诊断疾病、预测疾病进展,金融领域中则可以用于风险评估和欺诈检测。

        随着我们深入本章的学习,读者不仅将在理论上理解探讨机器学习,也将通过实战案例和代码示例来加深理解,这些实战案例将覆盖从数据准备、模型构建到优化和模型评估的整个流程。我们会提供完整的程序代码,以及对这些代码的详细解释,确保即使是AI领域的新手也能跟上学习的步伐。

相关概念

        要深入理解机器学习,首先需要掌握几个核心概念。这些概念是机器学习理论的基石,对于理解如何构建和应用机器学习模型至关重要。

机器学习根本:模型

        在机器学习中,模型是指从数据中学习的算法。可以将其视为一种根据输入数据(特征)来做出预测或决策的系统。模型的训练过程涉及使用已知的数据集来调整其内部参数,使其能够准确地预测未见过的数据。

模型训练的基本步骤包括:

  • 选择模型:根据问题的性质选择适当的机器学习算法。
  • 训练数据:提供包含特征(解释变量)和标签(目标变量)的数据集。
  • 学习过程:算法通过分析训练数据来学习模式和关系。
  • 评估与调整:使用独立的测试集评估模型的性能,并根据需要进行调整。
数据的语言:特征与标签

        在机器学习中,我们通常将数据分为两类:特征和标签。特征是输入数据,是模型用来进行预测的信息。例如,房价预测模型的数据集结构应该是:

特征

类型

描述

id

整数

房屋唯一标识符

longitude

浮点数

房屋地理位置的经度

latitude

浮点数

房屋地理位置的纬度

housing_median_age

整数

房屋的中位年龄

total_rooms

整数

房屋内的房间总数

total_bedrooms

整数

房屋内的卧室总数

population

整数

房屋所在区域的人口总数

households

整数

房屋所在区域的家庭总数

median_income

浮点数

区域内家庭的收入中位数

ocean_proximity

文本

房屋靠近海洋的位置

median_house_value

浮点数

房屋的中位价值(标签)

        特征可能包括房屋的面积、房间数量、地理位置等信息,标签则是开发者想要预测的结果,在此类中表示房屋的售价。

训练与测试:模型评估

        为了验证模型的有效性,我们需要将数据分为训练集和测试集。训练集用于构建和优化模型,而测试集则用于评估模型的性能。这种划分帮助我们理解模型对新数据的泛化能力,即其在实际应用中的表现。

        在这个过程中,需要特别关注两个常见问题:过拟合和欠拟合。过拟合发生在模型过于复杂,过度学习训练数据的细节和噪声,而不足以泛化到新数据的情况,它对训练数据中的特定特征过度敏感,包括一些不规则和随机的误差,过拟合的模型在训练数据上表现得非常好,但是在新的、未见过的数据上表现不佳。相反,欠拟合则是模型过于简单,不能充分学习数据中的模式,可能是由于模型过于简单(例如,参数太少或模型结构不够复杂)或者训练数据中的特征不足以捕捉到决定输出的关键因素,欠拟合的模型不但在训练数据上表现不佳,而且在新数据上同样表现有所欠缺。

        在欠拟合情况下,即使随着时间的增加训练次数增多,训练集和测试集的成功率提升都非常有限,说明模型未能充分学习数据中的模式。训练集和测试集的成功率曲线都比较平坦,且测试集的成功率通常低于训练集,尽管训练时间延长,训练集和验证集的成功率仍然只是缓慢提高,欠拟合成功率折线图如图:

        对于过拟合情况,通常为训练集成功率随时间显著提高而测试集成功率先提高后下降或停滞不前,反映出模型对训练数据过度拟合而泛化能力差。这种情况下,训练集和测试集之间的准确率会有明显差距,表明模型对未见数据的预测性能不佳,过拟合成功率折线图如图:

        在一个正常拟合的情况下,训练集和验证集的准确率都会随着时间的推移而提高,并且两者之间的差距不会太大,这表明模型既学习了数据中的足够信息,又保持了良好的泛化能力。正常拟合成功率折线图如图:

机器学习的分类

        机器学习的方法多种多样,不同的方法适用于不同类型的问题,主要的机器学习方法可以分为3类:监督学习、非监督学习和强化学习。理解这些分类方法的使用场景有助于读者选择正确的方法来解决特定的问题。

监督学习:有指导的学习过程

        监督学习是最常见的机器学习类型之一。在监督学习方法下,我们提供给模型的训练数据既包括特征也包括相应的标签。模型的任务是学习如何将特征映射到标签,从而能够对新的、未标记的数据做出预测。常见的监督学习任务包括分类(预测离散标签)和回归(预测连续标签)。例如,根据患者的临床数据来预测是否患有特定疾病(分类),或者预测房屋的售价(回归)。

非监督学习:自我探索的过程

        与监督学习不同,非监督学习的训练数据不包含任何标签。非监督学习的目标是让模型自己探索数据并找出其中的结构。常见的非监督学习任务包括聚类和降维。一个典型的例子是市场细分,其中模型会根据客户的购买行为将其分为不同的群体。

  1. 聚类:发现数据中的自然群体
  2. 降维:减少数据的复杂性,同时保留重要信息
强化学习:通过试错学习

        强化学习与监督学习和非监督学习有所不同,在强化学习模式下,智能体通过与环境交互从而进行学习。也就是说强化学习不是从标记好的数据集中学习,而是根据事物行为的结果来学习。这个结果通常以奖励的形式给出。强化学习在游戏(如国际象棋和围棋)、机器人导航以及在线推荐系统中得到了广泛的应用。

构建与分析鸢尾花数据模型

        首次使用scikit-learn库,需要先进行安装。scikit-learn,也称为sklearn,是Python中最流行的机器学习库之一,它提供了广泛的工具和算法来处理常见的机器学习任务。安装sklearn库时,可以在命令行或终端中,输入以下命令:pip install scikit-learn。

鸢尾花数据集简介

        鸢尾花数据集是机器学习中最著名的数据集之一,包含150个样本,每个样本有4个特征(花萼长度、花萼宽度、花瓣长度、花瓣宽度),用于预测鸢尾花的种类(共有三种:Setosa、Versicolour、Virginica)。

加载数据集

 from sklearn.datasets import load_irisiris = load_iris()x, y = iris.data, iris.target

创建和训练模型

        接下来,我们将使用一个简单的分类算法,即决策树来训练模型。决策树是直观运用概率分析的一种图解法,是一个基于分支的树模型,其中,每个内部结点表示在一个属性上的测试,每个分支代表一个属性输出,而每一个树叶结点代表类或类分布,树的最顶层是根结点。在这里,我们首先导入DecisionTreeClassifier,然后创建一个决策树分类器的实例,并使用鸢尾花数据对其进行训练:

 from sklearn.tree import DecisionTreeClassifiermodel = DecisionTreeClassifier()model.fit(X, y)

进行预测与评估模型

        模型一旦训练完成,就可以用来进行数据预测,同时,也可以用来评估模型的性能。在实际应用中,一般会将数据分为独立的训练集和测试集,本例为了简化运算,是在同一数据集上进行的训练和测试,对数据集中的每个样本进行分类预测.

 #进行预测predictions = model.predict(X)#评估模型from sklearn.metrics import accuracy_score#这会输出模型在整个数据集上的准确率print(accuracy_score(y, predictions))

下一节我们将详细讲解监督学习和非监督学习,以及一个实战案例:预测房价

机器学习基础(二)监督与非监督学习-CSDN博客更深入地探讨监督学习和非监督学习的知识,重点关注它们的理论基础、常用算法及实际应用场景。https://blog.csdn.net/qq_52213943/article/details/136163917?spm=1001.2014.3001.5501

-----------------

以上,欢迎点赞收藏、评论区交流

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/690854.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

四分位距IQR_ interquartile range

四分位距IQR_ interquartile range 1 IQR(Interquartile Range)四分位距的含义2 如何计算IQR参考: 1 IQR(Interquartile Range)四分位距的含义 官方定义: 四分位距(interquartile range, IQR&a…

机器学习中梯度下降法的缺点

机器学习中的梯度下降法是一种寻找函数最小值的优化算法,广泛应用于训练各种模型,尤其是在深度学习中。尽管其应用广泛,但梯度下降法也存在一些不可忽视的缺点: 1. 局部最小值和鞍点 局部最小值问题: 对于非凸函数&a…

数据分析 - 机器学习

1:线性回归 线性回归是一种统计技术用于对输出变量与一个或多个输入变量之间的关系进行建模 用外行人的话来说,将其视为通过某些数据点拟合一条线,如下所示 以便在未知数据上进行预测,假设变量之间存在线性关系 点和线之间存在微小…

Git面试题整理(基本点)

1.简述Git Git是一种分布式版本控制系统,它允许多个开发者在任何时间,从任何地点对代码进行编辑和分享,而不会互相干扰。Git通过跟踪和管理代码的历史版本,帮助团队协作开发复杂的项目。 与集中式版本控制系统不同&#…

[ansible] playbook运用

一、复习playbook剧本 --- - name: first play for install nginx #设置play的名称gather_facts: false #设置不收集facts信息hosts: webservers:dbservers #指定执行此play的远程主机组remote_user: root #指定执行此play的用…

【Java万花筒】选择最适合您的数据序列化格式:比较 Avro、Protocol Buffers、JSON、XML、MessagePack和BSON

选择最佳数据序列化格式:找到适合您的解决方案 前言 在当今数据驱动的世界中,高效地处理和传输数据变得至关重要。选择合适的数据序列化格式对于数据存储、通信和处理的性能至关重要。本文将介绍并比较几种常用的数据序列化格式,包括Apache…

python绘制k线图均线图

AAPL.csv 数据文件 Date,Close,Volume,Open,High,Low 06/23/2023,$186.68,53117000,$185.55,$187.56,$185.01 06/22/2023,$187.00,51245330,$183.74,$187.045,$183.67 06/21/2023,$183.96,49515700,$184.90,$185.41,$182.5901 06/20/2023,$185.01,49799090,$184.41,$1…

2.19C语言学习

P8597 [蓝桥杯 2013 省 B] 翻硬币 因为把相邻两个硬币翻转两次相当于不翻,所以最优方案中同一组硬币最多只会翻转一次,故翻转顺序无后效性,考虑贪心:从前往后比较,发现一个不同的硬币就把它和他后面的硬币翻转&#x…

单例模式的几种实现方式

在Java中,实现单例模式主要有几种方式:懒汉式、饿汉式、双重检查锁定、静态内部类和枚举。每种方式都有其特点和适用场景。 1. 饿汉式(线程安全) 饿汉式是最简单的一种实现方式,通过静态初始化实例,保证了…

springboot 事务管理 详细介绍

在Spring Boot中,事务管理是一种关键的特性,它确保了数据的完整性和一致性。Spring Boot提供了对事务管理的内置支持,使得在应用程序中使用事务变得非常简单。 事务管理的基本概念 事务是指一系列操作,这些操作要…

15-55V输入自动升降压 光伏MPPT自动跟踪充电方案 大功率300瓦

1.MPPT原理--简介 MPPT,全称为Maximum Power Point Tracking,即最大功点跟踪,它是一种通过调节电气模块的工作状态,使光伏板能够输出更多电能的电气系统能够将太阳能电池板发出的直流电有效地贮存在蓄电池中,可有效地…

【蓝桥杯】算法模板题(Floyd算法)

一.弗洛伊德算法 用途:用来求解多源点最短路径问题。 思想:Floyd算法又称为插点法,是一种利用动态规划的思想寻找给定的加权图中多源点之间最短路径的算法。 主要步骤: 1)初始化:使用邻接矩阵初始化dis…

第十四届“中关村青联杯”全国研究生数学建模竞赛-A题:无人机在抢险救灾中的优化运用

目录 摘 要: 1 问题重述 1.1 问题背景 1.2 待解决的问题 2 模型假设及符号说明

GitHub仓库文件部署

目录 软件下载和安装 git创建仓库 Github仓库配置 git管理软件配置 Git管理 软件下载和安装 首先需要下载git,以及git管理软件,对其进行安装。 git创建仓库 首先需要创建仓库,在本地仓库文件夹cmd之后输入以下指令创建git仓库文件。 …

解决laravel-admin安装报错1071 Specified key was too long问题

在执行php artisan admin:install命令安装laravel-admin的时候,如果你使用的数据库是MySQL v5.7.7以下版本就会报下面的错: SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 1000 bytes (SQL:…

课时39:表达式_运算符_简单计算

3.1.2 简单计算 学习目标 这一节,我们从 [ ] 、 l e t 、 ( ( ) ) 、 []、let、(())、 []、let、(())、(())、小结 五个方面来学习。 $[] 简介 $[]方法,常用于整数计算场景,适合不太复杂的计算,运算结果是小数的也会自动取整…

递归读取文件夹下的所有文件

水一篇文章 🐶 代码 package file;import org.apache.commons.lang3.StringUtils; import org.junit.Test;import java.io.File; import java.util.Objects;/*** FlattenDirFiles** author allens* date 2024/2/19*/ public class FlattenDirFiles {// 文件数量pri…

小米空气净化器2s使用体验

这个产品最早上市是2017年,我买回来实际上只用了1年就弃用了,性能不行,使用体验也不好。 打算买新的空气净化器,抽空吐槽一下。 这个净化器发售价是899,在当时来说算中下水平的,小米的,有米家…

什么是跨端,常用的跨端技术

跨平台是跨操作系统,跨端是指客户端 常见的客户端有,web、android、ios 等,客户端的特点是有界面、由逻辑,所以包含逻辑跨端和渲染跨端。 常用的跨端技术方案 React Native: 由 Facebook 推出的开源框架,…

Spring Boot与LiteFlow:轻量级流程引擎的集成与应用含完整过程

点击下载《Spring Boot与LiteFlow:轻量级流程引擎的集成与应用含完整过程》添加链接描述 1. 前言 本文旨在介绍Spring Boot与LiteFlow的集成方法,详细阐述LiteFlow的原理、使用流程、步骤以及代码注释。通过本文,读者将能够了解LiteFlow的特…