统计学习方法入门:机器学习与统计学习基础
创作时间:
作者:
@小白创作中心
统计学习方法入门:机器学习与统计学习基础
引用
CSDN
1.
https://blog.csdn.net/weixin_42917352/article/details/121754083
统计学习是关于计算机基于数据构建概率统计模型并运用模型对数据进行分析与预测的一门学科。统计学习包括监督学习、非监督学习、半监督学习和强化学习。
统计学习方法三要素——模型、策略、算法,对理解统计学习方法起到提纲挈领的作用。
本书主要讨论监督学习,监督学习可以概括如下:从给定有限的训练数据出发, 假设数据是独立同分布的,而且假设模型属于某个假设空间,应用某一评价准则,从假设空间中选取一个最优的模型,使它对已给训练数据及未知测试数据在给定评价标准意义下有最准确的预测。
统计学习中,进行模型选择或者说提高学习的泛化能力是一个重要问题。如果只考虑减少训练误差,就可能产生过拟合现象。模型选择的方法有正则化与交叉验证。学习方法泛化能力的分析是统计学习理论研究的重要课题。
分类问题、标注问题和回归问题都是监督学习的重要问题。本书中介绍的统计学习方法包括感知机、 𝑘 近邻法、朴素贝叶斯法、决策树、逻辑斯谛回归与最大熵模型、支持向量机、提升方法、EM算法、隐马尔可夫模型和条件随机场。这些方法是主要的分类、标注以及回归方法。它们又可以归类为生成方法与判别方法。
使用最小二乘法拟合曲线
这段代码实现了一个多项式拟合的示例,使用最小二乘法来拟合一个带有噪声的正弦函数。以下是对代码流程的详细解释:
1. 导入必要的库
import numpy as np
import scipy as sp
from scipy.optimize import leastsq
import matplotlib.pyplot as plt
- numpy:用于数值计算和数组操作。
- scipy:提供科学计算的工具,这里主要使用 scipy.optimize 中的 leastsq 函数进行最小二乘法拟合。
- matplotlib.pyplot:用于绘图和可视化。
2. 定义目标函数
def real_func(x):
return np.sin(2 * np.pi * x)
- real_func:定义了一个目标函数,返回 y = sin(2πx),这是我们希望拟合的真实函数。
3. 定义多项式函数
def fit_func(p, x):
f = np.poly1d(p)
return f(x)
- fit_func:接受多项式系数 p 和输入 x,返回多项式在 x 上的值。np.poly1d(p) 创建一个多项式对象。
4. 定义残差函数
def residuals_func(p, x, y):
ret = fit_func(p, x) - y
return ret
- residuals_func:计算拟合值与真实值之间的残差(误差)。它返回拟合值与实际观测值之间的差。
5. 生成数据点
x = np.linspace(0, 1, 10)
x_points = np.linspace(0, 1, 1000)
y_ = real_func(x)
y = [np.random.normal(0, 0.1) + y1 for y1 in y_]
- x:生成 10 个均匀分布在 [0, 1] 区间的点。
- x_points:生成 1000 个均匀分布在 [0, 1] 区间的点,用于绘制拟合曲线。
- y_:计算真实函数在 x 上的值。
- y:在真实值上添加正态分布的噪声,生成带噪声的观测值。
6. 定义拟合函数
def fitting(M=0):
"""
M 为 多项式的次数
"""
# 随机初始化多项式参数
p_init = np.random.rand(M + 1)
# 最小二乘法
p_lsq = leastsq(residuals_func, p_init, args=(x, y))
print('Fitting Parameters:', p_lsq[0])
# 可视化
plt.plot(x_points, real_func(x_points), label='real')
plt.plot(x_points, fit_func(p_lsq[0], x_points), label='fitted curve')
plt.plot(x, y, 'bo', label='noise')
plt.legend()
return p_lsq
- fitting:定义了一个拟合函数,接受一个参数 M,表示多项式的次数。
- 随机初始化多项式参数 p_init,长度为 M + 1。
- 使用 leastsq 函数进行最小二乘法拟合,计算最佳的多项式参数 p_lsq。
- 打印拟合参数。
- 使用 Matplotlib 绘制真实函数、拟合曲线和带噪声的观测值。
7. 调用拟合函数
在代码中并没有直接调用 fitting 函数的部分,但可以通过以下方式调用它:
fitting(M=3) # 例如,拟合一个三次多项式
plt.show() # 显示绘制的图形
这段代码的主要流程是:
- 定义真实函数和多项式拟合函数。
- 生成带有噪声的观测数据。
- 使用最小二乘法拟合多项式,并可视化结果。
通过调整多项式的次数 M,可以观察到不同复杂度的多项式如何拟合带噪声的数据。
M=0
p_lsq_0 = fitting(M=0)
M=1
p_lsq_0 = fitting(M=1)
M=3
p_lsq_0 = fitting(M=3)
M=9
p_lsq_0 = fitting(M=9)
结果显示过拟合, 引入正则化项(regularizer),降低过拟合
regularization = 0.0001
def residuals_func_regularization(p, x, y):
ret = fit_func(p, x) - y
ret = np.append(ret,
np.sqrt(0.5 * regularization * np.square(p))) # L2范数作为正则化项
return ret
# 最小二乘法,加正则化项
p_init = np.random.rand(9 + 1)
p_lsq_regularization = leastsq(
residuals_func_regularization, p_init, args=(x, y))
plt.plot(x_points, real_func(x_points), label='real')
plt.plot(x_points, fit_func(p_lsq_9[0], x_points), label='fitted curve')
plt.plot(
x_points,
fit_func(p_lsq_regularization[0], x_points),
label='regularization')
plt.plot(x, y, 'bo', label='noise')
plt.legend()
热门推荐
卧室床摆放的风水指南
如何预防白血病?医生提示:远离白血病,记住8点,降低发病风险
工伤认定的程序流程及赔偿标准详解
燃气费上涨背后的深层原因:公共服务定价机制的困境
增值税留抵退税会计分录怎么做
高铁提前几分钟停检?出门旅游必须知道的知识点
清晰表达:陈述性语言的实践技巧
潍坊市正式成为“国家公交都市建设示范城市”
春分:昼夜平分,寒暑平衡
久咳不愈有白痰喉咙发痒?可能由这5个原因引起
Nikola破产:市值蒸发超260亿美元 烧钱难以为继,是骗子界天花板
ASTM A53 综合分析:碳钢的牌号分类、规格及应用
覆盆子的功效与作用是什么
楼间距多少才不会影响采光?楼间距不足有什么危害?
人过50进入养寿关键期,养成这4个“懒习惯”,助您拥抱健康!
库存超市是什么?如何有效管理库存超市?库存超市的优势与挑战
2025年中国宠物殡葬服务行业处理方式、完整流程及相关政策分析
揭秘恶魔铁甲虫:体长仅1cm却能承受350万公斤压力的神奇生物
不用做胃镜检查胃病的方法是什么
文具店经营全攻略:选址、选品到营销策略详解
宝宝秋季腹泻补液盐使用全攻略:从原理到选购指南
呋塞米注射液用量多少管用
朱元璋与韩林儿的关系:一段政治联姻的剖析
如何锻炼腰部力量改善腰痛
修复 iPad 卡在耳机模式下的问题简单而专业的方法
如何高效搭建企业知识库?企业知识库搭建实施步骤全解析
正月十四的民俗禁忌:1不结、3要拜、4不说
构建强大的物联网平台系统架构:关键步骤与最佳实践
花园洋房装修风格有哪些?如何选择适合自己的风格?
桃树栽哪个方向风水好?东南、西南还是正南?