IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 学习曲线 -> 正文阅读

[人工智能]学习曲线

学习曲线

学习曲线是诊断模型算法准确性的一个重要工具。

生成若干个在y=√x附近波动的点作为训练样本。

import numpy as np
import matplotlib.pyplot as plt
n_dots=200
X=np.linspace(0,1,n_dots)
Y=np.sqrt(X)+0.2*np.random.rand(n_dots)-0.1#[0,1]之间创建200个点
X=X.reshape(-1,1)
Y=Y.reshape(-1,1)

用pipline来处理数据

pipeline工作原理:

管道机制在机器学习算法中得以应用的根源在于,参数集在新数据集(比如测试集)上的重复使用。先增加多项式阶数,再用线性回归算法来拟合数据
逻辑原理如下:
在这里插入图片描述

from sklearn.pipeline import Pipeline
from sklearn.preprocessing import PolynomialFeatures
from sklearn.linear_model import  LinearRegression
def polynomial_model(degree=1):#degree表示多项式的阶数
    polynomial_features=PolynomialFeatures(degree=degree,include_bias=False)
    linear_regression=LinearRegression()#流水线,先增加多项式阶数,再用线性回归算法来拟合数据
    pipeline=Pipeline([("polynomial_features",polynomial_features),("linear_regression",linear_regression)])
    #流水线第一道工序:使用PolynomialFeatures来进行特征的构造,这里degree(多项式的度)为1。
    #流水线第二道工序:使用linear_regression线性回归类来拟合曲线。
    #最终返回
    return pipeline

polynmoial_model()用degree表示阶数来生成多项式模型

from sklearn.model_selection import learning_curve
from sklearn.model_selection import ShuffleSplit
def plot_learning_curve(estimator,title,X,y,ylim=None,cv=None,n_jobs=1,train_sizes=np.linspace(.1,1.0,5)):
    #train_sizes=np.linspace(.1,1.0,5)表示把训练样本从0.1-1分成五等分序列,从序列中取出训练样本的数量百分比,逐个计算在当前训练样本数量情况下训练出来的样本准确性
    plt.title(title)
    if ylim is not None:
        plt.ylim(*ylim)
    plt.xlabel("Training examples")
    plt.ylabel("Score")
    train_sizes,train_scores,test_scores=learning_curve(estimator,X,y,cv=cv,n_jobs=n_jobs,train_sizes=train_sizes)

在sklearn里,我们不用自己实现学习曲线算法,直接使用sklearn.model_selection.learning_curve()函数来画学习曲线
X为传入的特征矩阵,y为传入标签
参数cv:
可以传多种格式参数:
(1)整数:指定KFold中的折数,如cv=5,意为将x特征矩阵分为5份,最终分数也会有5份
(2)None:默认为3折交叉验证
(3)分割器:例如ShuffleSplit(n_splits=50,test_size=0.2,random_state=0)
即按照传入分割器进行分割
参数n_jobs:
需要同时运行的CPU数,如果是-1,则调用所有CPU进行计算

    plt.title(title)
    train_scores_mean=np.mean(train_scores,axis=1)
    train_scores_std=np.std(train_scores,axis=1)#训练集的平均分,和中位数
    test_scores_mean = np.mean(test_scores, axis=1)
    test_scores_std = np.std(test_scores, axis=1)#测试集的平均分,和中位数
    plt.grid()
    plt.fill_between(train_sizes,train_scores_mean-train_scores_std,train_scores_mean+train_scores_std,alpha=0.1,color="r")
    plt.fill_between(train_sizes, test_scores_mean - test_scores_std, test_scores_mean + test_scores_std, alpha=0.1,
                     color="g")
    #plt.fill_between()会把模型准确性的平均值的上下方差空间里用颜色填充
    plt.plot(train_sizes,train_scores_mean,'o--',color='r',label="Train scores")
    plt.plot(train_sizes, test_scores_mean, 'o-', color='g', label="Cross scores")
    plt.legend(loc="best")
    return plt

分别是使用polynmoial_model()构建出来的三个模型,分别为1阶,3阶,10阶多项式

cv=ShuffleSplit(n_splits=10,test_size=0.2,random_state=0)
plt.rcParams['font.sans-serif']=['simhei']   # 指定默认字体
titles=['学习曲线(欠拟合)','学习曲线','学习曲线(过拟合)']
degress=[1,3,10]
plt.figure(figsize=(18,4),dpi=200)
for i in range(len(degress)):
    plt.subplot(1,3,i+1)
    plot_learning_curve(polynomial_model(degress[i]),titles[i],X,Y,ylim=(0.75,1.01),cv=cv)
plt.show()

在这里插入图片描述

当模型欠拟合时,随着训练数据集的增加,交叉数据集的准确性(实线)逐渐增大,逐渐和训练集的准确性(虚线)靠近,但其总体水平比较低,收敛在0.88左右。其训练数据集的准确性也比较低,收敛在0.90左右。
当模型过拟合时,随着训练数据集的增加,交叉数据集的准确性(实线)也逐渐增大,逐渐和训练集的准确性(虚线)靠近,但两者之间的间隙较大,训练集的准确性很高,收敛在0.95左右。但其交叉验证数据集的准确性值却很低,收敛在0.91左右。

过拟合与欠拟合的特征:

过拟合:模型对训练数据集的准确性比较高,其成本 J t r a i n ( θ ) J_{train}(θ) Jtrain?(θ)比较低,对交叉验证数据集的准确性较低,其成本 J c v ( θ ) J_{cv}(θ) Jcv?(θ)比较高。
欠拟合:模型对训练数据集的准确性比较低,其成本 J t r a i n ( θ ) J_{train}(θ) Jtrain?(θ)比较高,对交叉验证数据集的准确性较低,其成本 J c v ( θ ) J_{cv}(θ) Jcv?(θ)比较高。

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-08-16 11:44:45  更:2021-08-16 11:45:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/12 0:49:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码