【视频】K近邻KNN算法原理与R语言结合新冠疫情对股票价格预测|数据分享(上)

简介: 【视频】K近邻KNN算法原理与R语言结合新冠疫情对股票价格预测|数据分享

原文链接:http://tecdat.cn/?p=24057


本文的目标是使用K-最近邻(K近邻),ARIMA和神经网络模型分析Google股票数据集(查看文末了解数据获取方式)预测Google的未来股价,然后分析各种模型。

视频:K近邻KNN算法原理与R语言结合新冠疫情对股票价格预测


K-最近邻(K近邻)是一种用于回归和分类的监督学习算法。K近邻 试图通过计算测试数据与所有训练点之间的距离来预测测试数据的正确类别。然后选择最接近测试数据的K个点。K近邻算法计算测试数据属于'K'个训练数据的类的概率,并且选择概率最高的类。在回归的情况下,该值是“K”个选定训练点的平均值。


让我们看看下面的例子,以便更好地理解

为什么我们需要 K近邻 算法?

假设有两个类别,A 和B,并且我们有一个新的数据点x1,那么这个数据点将位于这些类别中的哪一个。为了解决这类问题,我们需要一个K近邻算法。借助K近邻,我们可以轻松识别特定数据集的类别。考虑下图:

K近邻 是如何工作的?

K近邻 的工作原理可以根据以下算法进行解释:

  • 步骤1:选择邻居的数量K
  • 步骤2:计算K个邻居的欧几里得距离
  • 步骤3:根据计算出的欧几里得距离取K个最近邻。
  • 步骤4:在这k个邻居中,统计每个类别的数据点个数。
  • 步骤 5:将新数据点分配给邻居数量最大的类别。
  • 步骤6:我们的模型准备好了。

假设我们有一个新的数据点,我们需要把它放在所需的类别中。

首先,我们将选择邻居的数量,因此我们将选择 k=5。

接下来,我们将计算数据点之间的欧几里得距离。欧几里得距离是两点之间的距离,我们已经在几何学中研究过。可以计算为:


通过计算欧几里得距离,我们得到了最近邻,即 A 类中的2个最近邻和 B 类中的3个最近邻。



正如我们所见,3 个最近的邻居来自类别B,因此这个新数据点必须属于类别B。

如何选择 K 值?

Kvalue 表示最近邻的计数。我们必须计算测试点和训练过的标签点之间的距离。每次迭代更新距离度量的计算成本很高,这就是为什么 K近邻 是一种惰性学习算法。

那么如何选择最优的K值呢?

  • 没有预先定义的统计方法来找到最有利的 K 值。
  • 初始化一个随机的 K 值并开始计算。
  • 选择较小的 K 值会导致决策边界不稳定。
  • 较大的 K 值更适合分类,因为它可以平滑决策边界。
  • 得出错误率和 K 之间的图,表示定义范围内的值。然后选择K值作为具有最小错误率。

现在您将了解通过实施模型来选择最佳 K 值。


计算距离:

第一步是计算新点和每个训练点之间的距离。计算该距离有多种方法,其中最常见的方法是欧几里得、曼哈顿(用于连续)和汉明距离(用于分类)。

欧几里得距离:欧几里得距离计算为新点 (x) 和现有点 (y) 之间的平方差之和的平方根。

曼哈顿距离:这是实际向量之间的距离,使用它们的绝对差之和。


结合新冠疫情COVID-19对股票价格预测:ARIMA,KNN和神经网络时间序列分析


1.概要


本文的目标是使用各种预测模型分析Google股票数据集查看文末了解数据获取方式预测Google的未来股价,然后分析各种模型。


2.简介


预测算法是一种试图根据过去和现在的数据预测未来值的过程。提取并准备此历史数据点,来尝试预测数据集所选变量的未来值。在市场历史期间,一直有一种持续的兴趣试图分析其趋势,行为和随机反应。不断关注在实际发生之前先了解发生了什么,这促使我们继续进行这项研究。我们还将尝试并了解 COVID-19对股票价格的影响。


3.所需包


library(quantmod) R的定量金融建模和交易框架

library(forecast) 预测时间序列和时间序列模型

library(tseries) 时间序列分析和计算金融。

library(timeseries) 'S4'类和金融时间序列的各种工具。

library(readxl) readxl包使你能够轻松地将数据从Excel中取出并输入R中。

library(kableExtra) 显示表格

library(data.table) 大数据的快速聚合

library(DT) 以更好的方式显示数据

library(tsfknn) 进行KNN回归预测


4.数据准备


4.1导入数据


我们使用Quantmod软件包获取了Google股票价格2015年1月1日到2020年4月24日的数据,用于我们的分析。为了分析COVID-19对Google股票价格的影响,我们从quantmod数据包中获取了两组数据。

  • 首先将其命名为data\_before\_covid,其中包含截至2020年2月28日的数据。
  • 第二个名为data\_after\_covid,其中包含截至2020年4月24日的数据。

所有分析和模型都将在两个数据集上进行,以分析COVID-19的影响(如果有)。

getSymbols("GOG" fro= "2015-01-01", to = "2019-02-28")
before_covid <-dafae(GOOG)
getSymbols("GOG" , frm = "2015-01-01")
after_covid <- as.tae(GOOG)


4.2数据的图形表示

par(mfrow = c(1,2))
plot.ts(fore_c)


【视频】K近邻KNN算法原理与R语言结合新冠疫情对股票价格预测|数据分享(下):https://developer.aliyun.com/article/1491731

相关文章
|
4月前
|
机器学习/深度学习 存储 算法
用kNN算法诊断乳腺癌--基于R语言
用kNN算法诊断乳腺癌--基于R语言
|
15天前
|
算法
基于SIR模型的疫情发展趋势预测算法matlab仿真
该程序基于SIR模型预测疫情发展趋势,通过MATLAB 2022a版实现病例增长拟合分析,比较疫情防控力度。使用SIR微分方程模型拟合疫情发展过程,优化参数并求解微分方程组以预测易感者(S)、感染者(I)和移除者(R)的数量变化。![]该模型将总人群分为S、I、R三部分,通过解析或数值求解微分方程组预测疫情趋势。
|
16天前
|
机器学习/深度学习 算法 数据挖掘
R语言中的支持向量机(SVM)与K最近邻(KNN)算法实现与应用
【9月更文挑战第2天】无论是支持向量机还是K最近邻算法,都是机器学习中非常重要的分类算法。它们在R语言中的实现相对简单,但各有其优缺点和适用场景。在实际应用中,应根据数据的特性、任务的需求以及计算资源的限制来选择合适的算法。通过不断地实践和探索,我们可以更好地掌握这些算法并应用到实际的数据分析和机器学习任务中。
|
1月前
|
机器学习/深度学习 数据采集
R语言逻辑回归、GAM、LDA、KNN、PCA主成分分类分析预测房价及交叉验证
上述介绍仅为简要概述,每个模型在实施时都需要仔细调整与优化。为了实现高度精确的预测,模型选择与调参是至关重要的步骤,并且交叉验证是提升模型稳健性的有效途径。在真实世界的房价预测问题中,可能还需要结合地域经济、市场趋势等宏观因素进行综合分析。
42 3
|
1月前
|
机器学习/深度学习 数据采集 算法
基于SVm和随机森林算法模型的中国黄金价格预测分析与研究
本文通过运用支持向量机(SVM)、决策树和随机森林算法,结合历史黄金价格数据和特征工程,建立了中国黄金价格的预测模型,并通过模型训练、评估及可视化分析,为黄金市场投资者和分析师提供了基于机器学习算法的预测方法和决策支持。
|
1月前
|
机器学习/深度学习 数据采集 数据可视化
基于机器学习的一线城市租房价格预测分析与实现,实现三种算法预测
本文通过数据采集、处理、特征选择和机器学习建模,对一线城市租房价格进行预测分析,比较了随机森林、一元线性回归和多元线性回归模型,并发现随机森林模型在预测租房价格方面表现最佳,为租房市场参与者提供决策支持。
|
2月前
|
自然语言处理 算法 安全
Python实现贝叶斯算法疫情微博评论情感分析
Python实现贝叶斯算法疫情微博评论情感分析
Python实现贝叶斯算法疫情微博评论情感分析
|
3月前
|
机器学习/深度学习 存储 算法
K 近邻算法(二)
K-近邻(KNN)算法是一种监督学习方法,用于分类和回归。关键步骤包括计算新样本与训练样本的距离,选择合适的邻近样本数K,基于K个邻居的多数类别或平均值做出预测。K值的选择影响模型性能:小K易受噪声影响(过拟合),大K可能导致模型过于简单(欠拟合)。评估模型通常使用测试集的预测准确率,如sklearn.metrics.accuracy_score。最优K值可通过交叉验证,如GridSearchCV,来确定,但它可能计算密集。KNN常用于手写数字识别等任务,如MNIST数据集。
|
3月前
|
机器学习/深度学习 数据采集 算法
K 近邻算法(一)
本文介绍了KNN算法的基本概念、步骤、优缺点,以及在图像识别、文本分类、回归预测、医疗诊断和金融风控等领域的应用。重点讲解了数据预处理、模型训练、评估方法和参数选择策略,包括K值确定、交叉验证和GridSearchCV的使用。
|
3月前
|
机器学习/深度学习 算法 搜索推荐
KNN算法(k近邻算法)原理及总结
KNN算法(k近邻算法)原理及总结

热门文章

最新文章