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 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 2021-11-08 -> 正文阅读

[游戏开发]2021-11-08

TAR模型(门限自回归模型)

TAR模型的实质是分段的AR模型,,它的基本思路是,在观测时序{ x i x_i xi?}的取值范围内引入 l ? 1 l-1 l?1个门限值 r i r_i ri?( i i i=1,2,… l ? 1 l-1 l?1),将该范围分成 l l l个区间,可用 r 0 r_0 r0?, r l r_l rl?分别表示上界和下界,并根据延迟步数 d d d将{ x i x_i xi?}按{ x i ? d x_{i-d} xi?d?}值的大小分配到不同的门限区间内,再对区间内的{ x i x_i xi?}采用不同的自回归模型(AR模型),从而形成时间序列的非线性动态描述,其模型形式如下:
x t x_t xt?= Φ 0 j \Phi^j_0 Φ0j?+ ∑ i = 1 P j \sum_{i=1}^{P_j} i=1Pj?? Φ i j \Phi^j_i Φij? X t ? i X_{t-i} Xt?i?+ ε t j \varepsilon^j_t εtj?, r j r_j rj?, j j j=1,2,… l l l

式中 ε t j \varepsilon^j_t εtj?是第 l l l个相互独立的正态分布白噪声序列, d d d为延迟步数(非负整数), r j r_j rj?为门限值, l l l为门限区间的个数, Φ 0 j \Phi^j_0 Φ0j?为第 j j j个门限区间的自回归系数, P j P_j Pj?为第 j j j个门限区间AR模型的阶数。
由于TAR模型实质是区分区间的AR模型,建模时刻沿用AR模型的参数估计方法模型检验准则,其建模实质是第一个对 d , l , r j , p j d,l,r_j,p_j d,l,rj?,pj?, Φ i j \Phi^j_i Φij?的多维寻优问题,可在给定哥哥参数取值范围的条件下,使用遗传算法、网格搜索等方法搜索最有参数。门限区间个数 l l l的选取,理论上可以选取若干个,但在实际应用中往往选择1对就可以满足,因此通常将门限区间个数 l l l取为2。假设用于训练的数据样本量为 n n n,则可依次取0.3 n n n,0.4 n n n,0.5 n n n,0.6 n n n,0.7 n n n,的对应的值作为门限候选值。对于候选值中的任意门限值 r 1 r_1 r1?,设定最大门限延迟量为 d m a x d_{max} dmax?,对于任意的 1 < = d < = d m a x 1<=d<=d_{max} 1<=d<=dmax?,我们可以将时序数据分成两类,一类时序值其 d d d阶延迟值小于等于 r 1 r_1 r1?,另一类时序值大于 r 1 r_1 r1?。针对这爱玲组数据,分别建立AR模型,并计算出这艾灵格模型对应的AIC值,当他们的和最小时,对应的 d , r 1 , p 1 , p 2 d,r_1,p_1,p_2 d,r1?,p1?,p2?, Φ j 1 \Phi^1_j Φj1?( i = 0 , 2 , . . . p 1 i=0,2,...p_1 i=0,2,...p1?), Φ i 2 \Phi^2_i Φi2?( i = 0 , 2 , . . . , p 2 i=0,2,...,p_2 i=0,2,...,p2?)参数即为所求,其中AIC的公式计算如下:
A I C j AIC_j AICj? = n j l n n_jln nj?ln( σ j 2 \sigma_j^2 σj2?)+2( p j p_j pj?+2), j = 1 , 2 j=1,2 j=1,2
式中 n j n_j nj?为第 j j j个门限区间的样本个数, σ j 2 \sigma_j^2 σj2?为第 j j j个门限区间的阿姨你根本残差的方差, p j p_j pj?为对应的自回归模型阶数。

TAR适用于周期性波动、非线性影响等情况。

R语言
vdata = read.table("f:\\sunspot-1700-2010.txt",header=F)
dim(vdata)
#使用未来50年的数据进行验证,以前的数据用于建模
modelData = vdata$V2[1:261]
n <- length(modelData)
#设置候选门限值
thresholdV = sort(modelData)[round((seq(from=30,to=70,by=3)/100)*n)]
#设置门限延迟量dmax、自回归最大阶数,默认最小AIC值
dmax = 5
pmax = 5
minAIC = le+10
#在指定们线延迟量、结束及门限值的前提下,返回对应自回归AIC值和自回归系数
getModelInfo <- function(tsoobj,d,p,r,isUp=True){
if(isUp){
dstSet = which(tsobj>r)+d
}else{
dstSet = which(tsobj<=r)+d}
tmpdata = NULL
#重建基础数据集
#xt = a0+a1*x(t-1)+...+ap*x(t-p)
for(i in dstSet){
if (i>p &&i<length(tsobj)){
tmpdata = rbind(tmpdata,tspbj[i:(i-p)])
}
}
x = cbind(1,tmpdata[,2:(p+1)])
coef = solve(t(x)%*%x)%*%tmpdata[,1]
epsion = tmpdata[,1]-x%*%coef
aic = drop(nrow(tmpdata)*log(var(epsion))+2*(p+2))
return (list(aic = aic,coef = coef))
}
#选择最优参数
for(tsv in thresholdV){
for (d in 1:dmax){
for (p1 in 1:pmax){#<=r1
model1 = getModelInfo(modelData,d ,p = p1,r = tsv,isUp = F)
for (p2 in 1:pmax)#>r1
{model2 = getModelInfo(modelData,d ,p = p1,r = tsv,isUp = T)
if ((modell$aic+model2$aic)<minAIC)
{
minAIC = (model1$aic+model2$aic)
a_tsv = tsv
a_d = d
a_p1 = p1
a_p2 = p2
coef1 = model1$coef
coef2 = model2$coef
print(minAIC)
}
}
}
}
}

#使用求出的参数,对未来50年的数据逐年预测
predsData = NULL
for(i in 262:311)
{
t0 = vdata$V2[(i-a_d)]
if(t0 <= a_tsv)
{
predsData=c(predsData,sum(c(1,vdata$V2[(i-1):(i-a_p1)])*coef1))
}else{
predsData = c(predsData,sum(c(1,vdata$V2[(i-1):(i-a_p2)])*coef2)}
}


#调包
library(TSA)
vdata = read.table("f:\\sunspot-1700-2010.txt",header=F)
#使用未来50年的数据进行验证,以前的数据用于建模
篇reds DATa= NULL
for(i in 1:50)
{
modelData = vdata$V2[1:(261+i-1)]
tar.obj = tar(y=modelData,p1=5,p2=3,d=3,a=3,b=7)
predsData = c(predsData,predict(tar.obj,n.ahead=1)$fit)
}

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2021-11-09 19:56:40  更:2021-11-09 19:57:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/28 0:42:28-

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