【视频】马尔可夫链原理可视化解释与R语言区制转换MRS实例|数据分享

news2024/10/5 17:16:04

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


马尔可夫链是从一个“状态”(一种情况或一组值)跳到另一个“状态”的数学系统。本文介绍了马尔可夫链和一种简单的状态转移模型,该模型构成了隐马尔可夫模型(HMM)的特例。从应用的角度来看,这些模型在评估经济/市场状态数据时(查看文末了解数据获取方式)非常有用。这里的讨论主要围绕使用这些模型的科学性。

点击文末“阅读原文”获取完整代码数据)。

视频:马尔可夫链原理可视化解释与R语言区制转换Markov regime switching实例

例如,如果您制作了婴儿行为的马尔可夫链模型,您可能会将“玩耍”、“吃饭”、“睡觉”和“哭泣”作为状态,它们与其他行为一起可以形成“状态空间”:所有可能状态的列表。此外,在状态空间之上,马尔可夫链告诉您从一个状态跳跃或“转换”到任何其他状态的概率——例如,正在玩耍的婴儿在下一个状态下入睡的可能性五分钟不先哭。

一个简单的两态马尔可夫链如下所示。

875700795660caa272b5c81665906853.png

在我们的状态空间中有两种状态(A 和 B),有 4 种可能的转换(不是 2 种,因为状态可以转换回自身)。如果我们在“A”,我们可以过渡到“B”或留在“A”。如果我们在“B”,我们可以过渡到“A”或留在“B”。在这两个状态图中,从任何状态转换到任何其他状态的概率为 0.5。

f72ebf6cf474ce2f9030f57e22437a72.png

当然,真正的建模者并不总是画出马尔可夫链图。相反,他们使用“转移矩阵”来计算转移概率。状态空间中的每个状态都包含一次作为行和列,并且矩阵中的每个单元格都告诉您从其行状态转换到其列状态的概率。因此,在矩阵中,单元格的作用与图中箭头的作用相同。

如果状态空间添加一个状态,我们添加一行和一列,每个现有的列和行添加一个单元格。这意味着当我们向马尔可夫链添加状态时,单元格的数量呈二次增长。因此,除非您想绘制丛林健身房马尔可夫链图,否则转换矩阵很快就会派上用场。

41d7cd3096e6d1d9b3388908afd1eb12.png

马尔可夫链的一种用途是在计算机模拟中包含真实世界的现象。例如,我们可能想要检查新大坝的溢出频率,这取决于连续下雨的天数。为了建立这个模型,我们从以下雨天 (R) 和晴天 (S) 开始:

edd83b5f64431d5f824ec8fb4c8ac610.png

模拟这种天气的一种方法是只说“有一半的日子下雨。因此,在我们的模拟中,每天都有 50% 的几率下雨。”

该规则将在模拟中生成以下序列:

88410c8f2f182136e38e3b5c84aa4b8f.png

你有没有注意到上面的序列看起来和原来的不太一样?第二个序列似乎跳来跳去,而第一个(真实数据)似乎具有“粘性”。在实际数据中,如果一天是晴天(S),那么第二天晴天的可能性也更大。

我们可以使用两态马尔可夫链来缩小这种“粘性”。当马尔可夫链处于“R”状态时,它有 0.9 的概率留在原地,有 0.1 的机会离开“S”状态。同样,“S”状态有 0.9 的概率保持原状,并且有 0.1 的机会转换到“R”状态。

5bfe4c01f5efe38e22077bd90b2ab809.png

在气象学家、生态学家、计算机科学家、金融工程师和其他需要对大现象建模的人群中,马尔可夫链可以变得非常庞大和强大。例如,谷歌用来确定搜索结果顺序的算法,称为PageRank,是一种马尔可夫链。

马尔可夫区制转移模型Markov regime switching

本文简要介绍了一种简单的状态转移模型,该模型构成了隐马尔可夫模型(HMM)的特例。这些模型拟合时间序列数据中的非平稳性。

基本案例

HMM的主要挑战是预测隐藏部分。我们如何识别“不可观察”的事物?HMM的想法是从可观察的事物来预测潜在的事物。

模拟数据

为了演示,我们准备一些数据并尝试进行反向推测。每个状态都具有不同的均值和波动率。

theta_v <- data.frame(t(c(2.00,-2.00,1.00,2.00,0.95,0.85)))

kable(theta_v, "html", booktabs = F,escape = F) %>% 
        kable_styling(position = "center")

fb0f3ad19459b6650e689679d1adb1f2.png

如上表所示,状态s = 2变成“坏”状态,其中过程x_t表现出较高的变化性。因此,停留在状态2的可能比停留在状态1的可能性小。

马尔可夫过程

为了模拟过程x\_t ,我们从模拟马尔可夫过程s\_t 开始。为了模拟T 期间的过程,首先,我们需要构建给定p_ {11} 和p_ {22} 的转换矩阵。其次,我们需要从给定状态s\_1 = 1 开始。从s\_1 = 1 开始,我们知道有95%的概率停留在状态1,有5%的概率进入状态2。

P <- matrix(c(p11,1-p22,1-p11,p22),2,2)
P\[1,\]
## \[1\] 0.95 0.05

因为它先前的状态,模拟s_t 是递归的。因此,我们需要构造一个循环:

for(t in 2:T_end) {
  s <- c(s,st(s\[t-1\]))
}
plot(s, pch = 20,cex = 0.5)

71299fe2a2193f5dce9fffb82c638a0e.png

上图说明了过程s_t的持久性。在大多数情况下,状态1的“实现”多于状态2。实际上,这可以由稳定概率确定,该稳定概率由下式表示:

P_stat\[1,\]
## \[1\] 0.75 0.25

因此,有15%的概率处于1状态,而有25%的概率处于状态2。这应该反映在模拟过程中  s,从而

mean(s==1)
## \[1\] 0.69

由于我们使用的是100个周期的小样本,因此我们观察到稳定概率为69%,接近但不完全等于75%。

结果

给定模拟的马尔可夫过程,结果的模拟非常简单。一个简单的技巧是模拟16d9652a04284010f4a75684409ba478.png的T周期和b96b505b50c37601f48388dece3508d6.png的 T  周期。然后,给定 s\_t  的模拟,我们针对每个状态创建结果变量 x\_t  。

plot(x~t_index, pch = 20)
points(x\[s == 2\]~t_index\[s==2\],col = 2)

2f94e10e7c44e57b7506b50f63e42092.png


点击标题查阅往期内容

7df79076f76b34a1544802b96dbc1230.jpeg

R语言如何做马尔可夫转换模型markov switching model

outside_default.png

左右滑动查看更多

outside_default.png

01

0022d9b3640f33a2947ca1b2c1008a00.png

02

8ac39adb32f0887b2ac23829eb0c6234.png

03

1c4841e0e1e54c6b3efe2bf70ba9e368.png

04

09210b82f2c5fe62b0e034ff737de0bf.png

虽然总体而言时间序列看起来是平稳的,但我们观察到一些周期(以红色突出显示)显示出较高的波动。有人可能会建议说,数据存在结构性中断,或者区制发生了变化,过程 x_t 变得越来越大,带有更多的负值。虽然如此,事后解释总是比较容易的。主要的挑战是识别这种情况。

估计参数

在本节中,我将使用R软件手动(从头开始)和非手动进行统计分解。在前者中,我将演示如何构造似然函数,然后使用约束优化问题来估计参数。

似然函数-数值部分

首先,我们需要创建一个以  Theta 向量为主要输入的函数。其次,我们需要设置一个MLE的优化问题。

在优化似然函数之前。让我们看一下工作原理。假设我们知道参数 Theta 的向量,并且我们有兴趣使用 x_t  上的数据评估随时间变化的隐藏状态。

8d86b48f09957c1beb37a806ba78e760.png

显然,这两种状态的每次过滤器的总和应为1。看起来,我们可以处于状态1或状态2。

all(round(apply(Filter\[,-1\],1,sum),9) == 1)
## \[1\] TRUE

由于我们设计了此数据,因此我们知道状态2的时期。

plot(Filter\[,3\]~t_index, type = "l", ylab = expression(xi\[2\]))
points(Filter\[s==2,3\]~t_index\[s==2\],pch = 20, col = 2)

7c86cd11708a1fc10ee4000638e92255.png

过滤器背后的优点是仅使用 x_t  上的信息来识别潜在状态。我们观察到,状态2的过滤器主要在状态2发生时增加。这可以通过发出红点的概率增加来证明,红点表示状态2发生的时间段。尽管如此,上述还是存在一些大问题。首先,它假定我们知道参数 Theta ,而实际上我们需要对此进行估计,然后在此基础上进行推断。其次,所有这些都是在样本中构造的。从实际的角度来看,决策者对预测的概率及其对未来投资的影响感兴趣。

手动估算

为了优化上面定义的  HMM_Lik 函数,我将需要执行两个附加步骤。首先是建立一个初始估计值,作为搜索算法的起点。其次,我们需要设置约束条件以验证估计的参数是否一致,即非负波动性和介于0和1之间的概率值。

第一步,我使用样本创建初始参数向量Theta_0 

在第二步中,我为估算设置了约束

请注意,参数的初始向量应满足约束条件

all(A%*%theta0 >= B)
## \[1\] TRUE

最后,回想一下,通过构建大多数优化算法都可以搜索最小点。因此,我们需要将似然函数的输出更改为负值。

## $par
## \[1\]  1.7119528 -1.9981224  0.8345350  2.2183230  0.9365507  0.8487511
## 
## $value
## \[1\] 174.7445
## 
## $counts
## function gradient 
##     1002       NA 
## 
## $convergence
## \[1\] 0
## 
## $message
## NULL
## 
## $outer.iterations
## \[1\] 3
## 
## $barrier.value
## \[1\] 6.538295e-05

为了检查MLE值是否与真实参数一致,我们绘制估计值与真实值的关系图:

plot(opt$par ~ theta_known,pch = 20,cex=2,ylab="MLE",xlab = "True")
abline(a=0,b=1,lty=2)

5f17828c23d6350980d45f462919423c.png

总体而言,我们观察到估计值非常一致。

估算 

我将在下面演示如何使用r软件复制人工估算的结果  。

如果我们要忽略过程中的任何区制转换,我们可以简单地将参数 mu 和 sigma 估计为

kable(mod_est, "html", booktabs = F,escape = F) %>% 
        kable_styling(position = "center")

07ed4524607be9eca70376dfc7f4c296.png

平均而言,我们应该期望过程平均值约为1,即ce7748191794ee3ea4c9ef8e11fbd97f.png。这是由期望定律得出的,其中我们知道

84c72486fed0bc6208c923995ea310f1.png

EX <- 0.75\*2 + 0.25\*-2
EX
## \[1\] 1

对于波动率,适用相同的逻辑。

## \[1\] 2.179449

我们注意到,回归估计值与波动率的一致性高于均值。

上面的观点是,估计值并未涵盖数据的真实性质。如果我们假设数据是稳定的,那么我们错误地估计过程的平均值为62%。但是,与此同时,我们通过构造知道该过程表现出两个平均结果-一个正面和一个负面。波动性也是如此。

为了揭示这些模式,我们在下面演示如何使用上面的线性模型建立区制转移模型:

主要输入是拟合模型,  mod我们将其归纳为拟合转移状态。第二个  k是区制的数量。由于我们知道我们要处理两个状态,因此将其设置为2。但是,实际上,需要参考一种信息标准来确定最佳状态数。根据定义,我们有两个参数,均值 mu\_s 和波动率 sigma\_s 。因此,我们添加一个true / false向量来指示正在转移的参数。在上面的命令中,我们允许两个参数都转移。最后,我们可以指定估计过程是否正在使用并行计算进行。

要了解模型的输出,让我们看一下

## Markov Switching Model
## 
## 
##        AIC     BIC    logLik
##   352.2843 366.705 -174.1422
## 
## Coefficients:
##         (Intercept)(S)    Std(S)
## Model 1       1.711693 0.8346013
## Model 2      -2.004137 2.2155742
## 
## Transition probabilities:
##            Regime 1  Regime 2
## Regime 1 0.93767719 0.1510052
## Regime 2 0.06232281 0.8489948

上面的输出主要报告我们尝试手动估算的六个估算参数。首先,系数表报告了每个状态的均值和波动。模型1的平均值为1.71,波动率接近1。模型2的平均值为-2,波动率约为2。显然,该模型针对数据确定了两种具有不同均值和波动率的不同状态。其次,在输出的底部,拟合的模型报告了转移概率。

6ba21e3c3847f8ab9e0f5691876d03d0.png

有趣的是,就每种状态的过滤器而言,我们将从包中检索到的状态与手动提取的状态进行比较。根据定义,可以使用图函数  来了解平滑概率以及确定的方案。

par(mar = 2*c(1,1,1,1),mfrow = c(2,1))

afa228fd2451f31572a45349b904f4ec.png

顶部的图表示随时间变化的过程 x_t ,其中灰色阴影区域表示02cf785757ff88889803403ba152bfdb.png的时间段。换句话说,灰色区域表示状态1占优势的时间段。

plot(x~t_index,type ="l",col = 0,xlim=c(1,100))

a425bda38565b5d20c7ea65dacdb7e5f.png

过滤器会在一个周期内检测到第二种状态。发生这种情况是因为在这种情况下,返回的是平滑概率,即在实现整个样本 T  后处于每种状态的概率,即79de5281c421f909b0720220fb5923e9.png。另一方面,来自手动估计的推断概率4878162479b098c1b22942a71a351b5e.png

无论如何,由于我们知道状态的真实值,因此可以确定我们是否处于真实状态。我们在上面的图中使用黑点突出显示状态2。总的来说,我们观察到模型在检测数据状态方面表现非常好。唯一的例外是第60天,其中推断概率大于50%。要查看推断概率多长时间正确一次,我们运行以下命令

mean(Filter$Regime_1 == (s==1)*1)
## \[1\] 0.96

结束语

在实际数据实现方面仍然存在许多挑战。首先,我们不具备有关数据生成过程的知识。其次,状态不一定实现。因此,这两个问题可能会破坏区制转移模型的可靠性。在应用方面,通常部署此类模型来评估经济或市场状况。从决策上来说,这也可以为策略分配提供有趣的建议。

数据获取

在下面公众号后台回复“MRS数”,可获取完整数据。

417adb15aaa84943118fdba3aef17e9d.jpeg

本文中分析的数据分享到会员群,扫描下面二维码即可加群!

8dd9effde62b6b1fd68eb9afd32047c3.png


8295c6c9cedb7d303a05c46cde12ffc3.jpeg

本文摘选R语言马尔可夫区制转移模型Markov regime switching,点击“阅读原文”获取全文完整资料。


点击标题查阅往期内容

时变马尔可夫区制转换MRS自回归模型分析经济时间序列

马尔可夫转换模型研究交通伤亡人数事故时间序列预测

如何实现马尔可夫链蒙特卡罗MCMC模型、Metropolis算法?

Matlab用BUGS马尔可夫区制转换Markov switching随机波动率模型、序列蒙特卡罗SMC、M H采样分析时间序列

matlab用马尔可夫链蒙特卡罗 (MCMC) 的Logistic逻辑回归模型分析汽车实验数据

R语言BUGS序列蒙特卡罗SMC、马尔可夫转换随机波动率SV模型、粒子滤波、Metropolis Hasting采样时间序列分析

stata马尔可夫Markov区制转移模型分析基金利率

PYTHON用时变马尔可夫区制转换(MRS)自回归模型分析经济时间序列

R语言使用马尔可夫链对营销中的渠道归因建模

matlab实现MCMC的马尔可夫转换ARMA - GARCH模型估计

R语言隐马尔可夫模型HMM识别不断变化的股票市场条件

R语言中的隐马尔可夫HMM模型实例

用机器学习识别不断变化的股市状况—隐马尔科夫模型(HMM)

Matlab马尔可夫链蒙特卡罗法(MCMC)估计随机波动率(SV,Stochastic Volatility) 模型

MATLAB中的马尔可夫区制转移(Markov regime switching)模型

Matlab马尔可夫区制转换动态回归模型估计GDP增长率

R语言马尔可夫区制转移模型Markov regime switching

stata马尔可夫Markov区制转移模型分析基金利率

R语言如何做马尔可夫转换模型markov switching model

R语言隐马尔可夫模型HMM识别股市变化分析报告

R语言中实现马尔可夫链蒙特卡罗MCMC模型

967a9679a6d64496ae0c99ee7337b779.png

595ce05c4af559765b903c47085c1de6.jpeg

ca688047a147bfd5f75f25ca9c9aadcc.png

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

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

相关文章

近期方案研究总结(那些你用的到的排列组合)

方案一 这个方案只一个位置一个号码&#xff0c;标的物即一个位置八十期不重即可以切入&#xff0c;以这样的思路去进行扩充。 纬度一 两期重复形态为&#xff1a;11、22、33、44、55、66、77、88、99、1010。 数上升一形态为&#xff1a;12、23、34、45、56、67、78、89、910…

微服务框架 SpringCloud微服务架构 28 数据同步 28.6 测试同步功能

微服务框架 【SpringCloudRabbitMQDockerRedis搜索分布式&#xff0c;系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 SpringCloud微服务架构 文章目录微服务框架SpringCloud微服务架构28 数据同步28.6 测试同步功能28.6.1 直接开干28 数据同步 28.6 测试同步…

云安全系列5:2023 年需要了解的 40个云安全术语

云安全具有广泛而复杂的特点&#xff0c;它有许多特定的术语和首字母缩略词。我们在这里整理了一些云安全术语。将其用作指南&#xff0c;可帮助您了解云安全的细微差别并更便于学习相关内容。 Agent 代理是专门的软件包或应用程序&#xff0c;部署到设备或机器上以完成与安全…

IDEA:Idea 集成 EasyYApi 插件实现接口文档的生成与更新

我是 ABin-阿斌&#xff1a;写一生代码&#xff0c;创一世佳话&#xff0c;筑一览芳华。如果小伙伴们觉得不错就一键三连吧~ 声明&#xff1a;文章原文来源处&#xff1a; https://blog.csdn.net/weixin_40863968/article/details/122432678https://www.jianshu.com/p/cd91590…

10个知识点让你读懂Spring MVC容器

DispatcherServlet 的配置参数 可以通过的属性指定配置参数&#xff1a; namespace参数&#xff1a;DispatcherServlet对应的命名空间&#xff0c;默认是WEB-INF/-servlet.xml。在显式配置该参数后&#xff0c;新的配置文件对应的路径是WEB-INF/.xml&#xff0c;例如如果将name…

Android 移植iperf3.13 测试网络

iperf,测试网络性能的&#xff0c;不同于 webrtc里面的gcc 算法预估网络带宽&#xff0c;iperf是实际占用网络来传输数据测量实际的网络性能。 官网&#xff1a;https://iperf.fr/ 官方就有 android 的下载 https://iperf.fr/iperf-download.php#android&#xff0c; 但是看起…

绕线机算法模型(Simulink仿真验证+PLC代码实现)

绕线机应用的详细内容大家可以参看下面这篇博客,这里不再赘述。本文主要借助Simulink仿真分析和解决工程实际问题。希望对大家学习Simulink有所帮助。限于水平和能力所限,文中难免出现错误和不足之处,诚恳的希望大家批评和指正。 S7-200 SMART PLC和V20变频器绕线机控制应用…

Linux(在 Linux 上搭建 java 部署环境(安装jdk/tomcat/mysql) + 将程序部署到云服务器上的操作)

目录 &#x1f432; 1. 在 Linux 上搭建 java 部署环境 &#x1f984; 1.1 安装 jdk &#x1f984; 1.2 安装 tomcat &#x1f984; 1.3 安装 mysql &#x1f432; 2. 将[博客系统]部署到云服务器上 &#x1f984; 2.1 先在云服务器上,创建和之前 windows 上一样的数据库…

德勤、阿里为数据智能时代造势,是风口还是韭菜?

前不久&#xff0c;德勤和阿里高调发布了业内首个DAAS报告《DAAS数字化新世代的最优解》&#xff0c;强调“企业不应该继续将数据智能建设当作‘选择题’&#xff0c;而是一道‘必答题’&#xff01;” 德勤管理咨询中国首席执行官戴耀华&#xff08;右&#xff09;与阿里巴巴集…

自学编程技术如何选择书籍?

首先自学编程的话&#xff0c;也是要先确定要选择适合自己的编程语言。然后再购买相应的编程教材&#xff0c;不知道怎么选择的话&#xff0c;可以直接选择黑马的原创书籍。 《C语言开发基础》 内容简介 本书是对《C语言开发入门教程》一书的全新改版&#xff0c;本次改版结合…

智能驾驶穿越“寒冬”:Argo AI们倒下,复睿智行们崛起

作者 | 曾响铃 文 | 响铃说&#xff08;xiangling0815&#xff09; 寒气还在智能驾驶领域蔓延。 在过去的一段时间&#xff0c;裁员、倒闭、破产、市值下跌、巨头撤离等等一系列不好的消息在智能驾驶行业频频爆出&#xff0c;一批老牌的智能驾驶企业更是倒在了黎明前。 智能…

OpenCV实战——实现高效图像扫描循环

OpenCV实战——实现高效图像扫描循环0. 前言1. 测量代码运行时间2. 计算不同扫描算法的执行时间4. 完整代码及运行结果相关链接0. 前言 在《像素操作》一节中&#xff0c;我们介绍了扫描图像以处理其像素的不同方法。在本节中&#xff0c;我们将学习比较这些方法的计算效率。编…

Linux篇 一、香橙派Zero2设置开机连接wifi

香橙派Zero2系列文章目录 一、香橙派Zero2设置开机连接wifi 文章目录香橙派Zero2系列文章目录前言一、调试串口的连接说明二、WIFI 连接测试1.首先使用 nmcli dev wifi 命令扫描周围的 WIFI 热点2.找到自己的wifi&#xff0c;准备好wifi名称和密码三、设置开机连接WiFi总结前言…

【MySQL】第10章_创建和管理表

创建和管理表1. 基础知识1.1 一条数据存储的过程1.2 标识符命名规则1.3 MySQL中的数据类型2. 创建和管理数据库2.1 创建数据库2.2 使用数据库查看当前所有的数据库查看当前正在使用的数据库查看指定库下所有的表查看数据库的创建信息使用/切换数据库2.3 修改数据库更改数据库字…

RadZen 最新注册版,2022年末圣诞-happy

RadZen快速简单地生成业务 Web 应用程序&#xff0c;以可视化方式构建和启动 Web 程序&#xff0c;而我们会为您创建新代码。 从信息开始 连接到数据库。Radzen 推断您的信息并生成功能完备的 Web 应用程序。支持 MSSQL REST 服务。 微调添加页面或编辑生成的页面。通过预览您…

vue使用高德地图,marker低于1000,滑动卡顿问题的探究(已解决)

问题描述 vue使用高德地图点标记&#xff0c;刚开始使用的是Marker&#xff0c;但是数目超过300&#xff0c;滑动就卡顿&#xff0c;按文档来说&#xff0c;Marker 类型推荐在数据量为 500 以内时使用&#xff0c;不应该卡顿。后边就开始对这个bug进行两天脑秃的探究了 1.换成…

pytorch-天气识别

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f366; 参考文章地址&#xff1a; 365天深度学习训练营-第P3周&#xff1a;天气识别&#x1f356; 作者&#xff1a;K同学啊一、前期准备 1.设置GPU import torch import torch.nn as nn impor…

MAC苹果系统安装数字证书的方法

MAC苹果系统安装数字证书的方法之工具/原料 Mac OS电脑一台 数字证书 先讲讲安装方法,mac系统默认浏览器是Safari,那小D在这里就以Safari浏览器为例子,讲解一下相关的安装方法 如果已有开通了数字证书的用户,在重装了系统或是在没有安装安装证书的电脑上进行付款时,会提…

【ELM回归预测】基于非洲秃鹫算法优化极限学习机预测附matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;修心和技术同步精进&#xff0c;matlab项目合作可私信。 &#x1f34e;个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知。 更多Matlab仿真内容点击&#x1f447; 智能优化算法 …

FL Studio水果21版本助力原创音乐人(中文完整版All Plugins)

最近&#xff0c;网上算是“风言风语”吧&#xff0c;关于FL Studio是否出21版的说法各异。首先呢&#xff0c;这里先肯定一点&#xff0c;FL Studio即将出FL Studio 21版本&#xff0c;但是正式版已经出来。希望大家不要被网上一些所谓冒充发布的FL Studio21正式版所骗&#x…