机器学习基本概念(附代码)

ops/2025/2/11 7:00:49/

这里的“机器”指的是计算机软硬件组织,而非传统的机械装置;而“学习”,则是指软件通过训练过程,其性能得以提升的过程。

一、算法与模型的关系

机器学习领域,算法和模型是两个核心概念。算法是一种偏抽象的概念,它定义了计算机解决问题的步骤和流程。而模型则是更加具体的概念,通过代码实现特定算法来完成任务。数学上,一个简单的模型可以表示为 y=f(x),其中 x 是样本特征,y 是样本标签,模型的目标就是将输入特征 x 映射到输出标签 y。

二、机器学习算法分类

机器学习可以根据样本是否包含标签分为两大类:有监督学习无监督学习

2.1 有监督学习(Supervised Learning)

有监督学习中,样本不仅包含特征 X,还包含对应的标签 y。基于预测目标的不同,可以进一步细分为分类和回归问题。

  • 分类算法:用于预测离散量。

    • 逻辑回归:虽然名字中有“回归”,但它实际上是一种分类方法,常用于二分类问题。
    • KNN回归:K近邻算法不仅可以用于分类,还可以用于回归任务。
    • 朴素贝叶斯:基于贝叶斯定理并假设特征之间相互独立的一种简单快速的分类方法。
    • 决策树:通过构建树状模型来进行决策的算法,易于理解和实现。
    • 支持向量机(SVM):寻找能够最大化类别间间隔的超平面来分类数据点。
    • 集成学习:如随机森林、梯度提升等方法,通过组合多个弱学习器来提高预测性能。
  • 回归算法:用于预测连续量。

    • 线性回归:试图找到自变量与因变量之间的线性关系。
    • KNN回归:与KNN分类类似,但输出是连续值。
    • 决策树回归:使用决策树结构进行回归分析。
    • 支持向量机回归(SVR):SVM的一个变种,适用于回归任务。
    • 集成学习:同样适用于回归任务,如随机森林回归等。

2.2 无监督学习(Unsupervised Learning)

无监督学习中,我们只有特征 X,没有标签 y。这类学习主要用于探索数据内部结构或模式。

  • 聚类算法

    • KMeans:一种常用的聚类技术,它试图将数据划分成K个簇,使得每个簇内的点尽可能相似。

三、机器学习项目流程

在这里插入图片描述

  • Step1: 项目分析

    首先明确项目的外部特性,包括输入和输出是什么,并确定这是一个分类还是回归问题。例如,在鸢尾花识别项目中,输入是一朵花的特征(如花萼长度、宽度等),输出是该花所属的子品种。

  • Step2: 数据采集
    数据采集是构建数据集的过程,基于输入和输出的需求进行。本质上是数理统计问题,采集总体的一个样本集,通过样本集的统计量来估计总体的统计量,

    人工智能项目的本质,通过对样本的分析,来评估/估计 总体的情况

    数据采集之后的结果是结构化数据:成行成列,确保每行代表一个样本,各行之间保持独立同分布,每列代表一个特征,各个特征之间是独立的,每一个列也代表一个变量,变量分为离散型变量连续型变量

    离散型变量:有限个状态,不同的状态值,状态之间无大小、程度等概念,状态之间是严格对立的!!!,比如男或者女,高或者矮,天晴或者下雨,

    连续型变量:无限个数值,数值之间是大小、程度的差异,内涵是一致的,长度,深度等程度问题,比如长度10.5米。

    怎么理解独立同分布?
    这包含2个意思,独立性同分布
    独立性指的是样本之间没有直接的关系或影响。具体来说,如果两个样本X1和X2是独立的,那么知道X1的信息不会给你关于X2的任何额外信息。换句话说,每个样本点的生成过程不受其他样本点的影响。
    同分布意味着所有样本都来自于同一个概率分布。这意味着每一个样本都有相同的分布函数,包括均值、方差等统计特性都是相同的。如果一个样本集是同分布的,那么无论你选择哪一个样本,它都应该具有相似的概率分布特征。

  • Step3: 数据预处理
    包括数据清洗(去除重复值、缺失值、异常值、无效特征)、数据切分(训练集、验证集、测试集)以及数据预处理(中心化、归一化、标准化)等步骤。

    训练集:训练过程中,用来训练模型(模型的学习数据)

    验证集:在训练过程中,用来验证模型的效果(不参与学习过程)

    测试集:训练完成后,用来评估模型的效果(不参与学习过程)

    在实际工作中,经常把验证集和测试集合并,一起使用

  • Step4: 模型选择
    根据问题是分类还是回归来选择合适的模型,主要是根据标签来判断是分类还是回归。例如,对于分类问题可以选择逻辑回归KNN朴素贝叶斯支持向量机决策树集成学习等;对于回归问题,则可能选择线性回归KNN支持向量机决策树集成学习等。

  • Step5: 训练模型
    使用训练集的数据对模型进行训练,即让模型学习如何将输入特征映射到输出标签。把训练集的特征 X_train 和标签 y_train 给模型 fit 方法,进行训练,

    本质:模型学习的过程!学习如何把 X 映射为 y

  • Step6: 评估模型
    评估模型的效果,分类问题可以通过准确率accuracy召回率recall精准率precisionF1-score等指标;回归问题则常使用MAE:平均绝对误差MSE:平均平方误差等指标。

  • Step7: 保存和部署模型
    最后,保存训练好的模型以便后续加载和部署应用。

四、示例:鸢尾花识别项目

  1. 项目分析
    项目需求:鸢尾花有3个子品种,想通过机器学习算法来做分类预测!进一步思考:
- 任务:给定一朵花,让模型识别到底是哪个子品种!
- 输入:一朵花- 一朵花是不能直接输入计算机中- 特征工程:- 数字化转型- 抽取/构建跟这朵花的类别有关系的特征来代表这朵花!!!- 跟业务专家详细咨询:- 花萼长度 x1- 花萼宽度 x2- 花瓣长度 x3- 花瓣宽度 x4
- 输出:子品种:- 分类问题:- 对状态进行编码:- N个状态:- 0, ..., N-1- 3个类别:- 0- 1- 2

目标是对鸢尾花的3个子品种进行分类预测。输入为花朵的四个特征(花萼长度、宽度,花瓣长度、宽度),输出为目标子品种编码。

  1. 加载数据
    使用sklearn.datasets.load_iris()加载鸢尾花数据集,并检查其基本信息。
from sklearn.datasets import load_iris
result = load_iris()
dir(result)
print(result.DESCR)
X, y = load_iris(return_X_y=True)
# X.shape
# (150, 4)
# y.shape
# (150,)
['DESCR','data','data_module','feature_names','filename','frame','target','target_names']

在这里插入图片描述

  1. 切分数据
    利用train_test_split函数按比例分割数据集。
from sklearn.model_selection import train_test_split
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=0)
  1. 套用模型
    采用K近邻算法作为模型,并对其进行训练。
from sklearn.neighbors import KNeighborsClassifier
# 实例化对象
knn = KNeighborsClassifier()
# 训练模型
knn.fit(X=X_train, y=y_train)
# 模型预测
y_pred = knn.predict(X=X_test)
# 预测结果
y_pred
# 真实结果
y_test
  1. 模型评估
    计算预测结果的准确性。
acc = (y_pred == y_test).mean()
# 0.9666666666666667
  1. 模型的保存和加载
    使用joblib库保存和加载模型。
import joblib
# 模型的保存
joblib.dump(value=knn, filename="knn.model")
# 模型的加载
model = joblib.load(filename="knn.model")

http://www.ppmy.cn/ops/157167.html

相关文章

java练习(12)

ps:题目来自力扣 给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。 考虑 nums 的唯一…

国产编辑器EverEdit - 查找功能详解

1 查找功能详解 1.1 应用场景 查找关键词应该是整个文本编辑/阅读活动中,操作频度非常高的一项,用好查找功能,不仅可以可以搜索到关键字,还可以帮助用户高效完成一些特定操作。 1.2 基础功能 1.2.1 基础查找功能 选择主菜单查…

网络安全 风险评估指南 网络安全风险测评

本文介绍常用的安全测评工具,分别以Web安全测评和移动支付及互联网金融安全测评为案例,详细阐述针对实际业务系统开展安全测评工作的步骤、内容和判定方法。 一、安全测评工具 介绍在测评工作中常用的几类安全测评工具,包括网络数据分析工具…

Jmeter常用的几种断言方法

🍅 点击文末小卡片 ,免费获取软件测试全套资料,资料在手,涨薪更快 在使用Jmeter进行性能测试或者接口自动化测试工作中,经常会用到的一个功能,就是断言,断言相当于检查点,它是用来判…

ARM Linux Qt使用JSON-RPC实现前后台分离

文章目录 1、前言2、解决方案2.1、JSON-RPC2.2、Qt中应用JSON-RPC的框架图2.3、优点2.4、JSON-RPC 1.0 协议规范 3、程序示例3.1、Linux C(只例举RPC Server相关程序)3.2、Qt程序(只例举RPC Client相关程序) 4、编译程序4.1、交叉…

Linux内核数据结构之链表

对于链表的优缺点,我们对比数组可以说出一些,但在随机存储的情况下,我们会选择链表来处理,而我们使用双向链表时,经常会定义成如下形式: struct list_node {TYPE data;struct list_node *prev,*next; }; 相对应的链表结构如下: 对于该数据结构定义,存在一个局限,整个…

【sqlite】python操作sqlite3(含测试)

个人小项目或者小团队,sqllite很适用,数据库封装操作如下 #!/usr/bin/env python # -*- coding: utf-8 -*- # Time : 2025-02-08 13:57 # Author : duxiaowei # File : connect_sqllite.py # Software: PyCharm """ sqllite操作, …

在 Spring Boot 项目中,bootstrap.yml 和 application.yml文件区别

在 Spring Boot 项目中,bootstrap.yml 和 application.yml 是两个常用的配置文件,它们的作用和加载顺序有所不同。以下是它们的详细说明: 1. bootstrap.yml 作用: bootstrap.yml 是 Spring Cloud 项目中的配置文件,用于…