ARMA模型带拟合的程序暂存

2023-10-04 11:59
文章标签 程序 模型 拟合 arma 暂存

本文主要是介绍ARMA模型带拟合的程序暂存,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

function[ddb,bbb,aaa, e,pos,yucezhi]=armaminerrordainihe2(cD)
%没有作平稳性检验 相关函数https://blog.csdn.net/chamyto98/article/details/5181623
%以下为系统自带函数
%  edit arima
%  edit garch
aaa=ones(50,500)*10000;
bbb=ones(50,500)*10000;
gaotie=cD;
N=size(gaotie,1);
for k=1:N/6%k=1 p=3 n=2 m=1 第p+1个有残差 
p=4*k-1;n=2*k;m=2*k-1;
[a0,b0] = arburg(gaotie,p);%%%https://www.ilovematlab.cn/thread-296619-1-1.html  a0为系数
c=N-p;
dd=ones(1,c);
for i=1:c
ddd=gaotie(i:i+p-1);
%ddd=ddd';
dd(i)=a0(2:p+1)*ddd;
end
%残差:
dd=dd';
cancha=gaotie(p+1:N)-dd;cancha=cancha';%从第p+1个才有残差%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%11.11 pp=N-(p)-m;%ARMA(n,m) AR的自回归基数一直是有的 MA拟合第一个则需要第m个残差即总数的p+m
y=gaotie(p+m+1:N);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%构造x矩阵
gaotie=gaotie';
gaotie1=toeplitz(gaotie);%预先分配一个N*N的内存
for kk=2:Ngaotie1(kk,:)=gaotie;for kkk=1:kk-1       
gaotie1(kk,:)=circshift(gaotie1(kk,:),-1);end
end
gaotie1=gaotie1(p+m-n+1:N-n,1:n);
%%%%前p个残差设置为零就和书上一样了
cancha1=toeplitz(cancha);
for kk=2:length(cancha)cancha1(kk,:)=cancha;for kkk=1:kk-1       
cancha1(kk,:)=circshift(cancha1(kk,:),-1);end
end
%cancha1=cancha1(p+m-1:N-2,1:m);
cancha1=cancha1(1:size(gaotie1,1),1:m);
x=[gaotie1 cancha1];
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%x=toeplitz(xx); %MATLAB提供了一个称为toeplitz的函数,可根据第一行和第一列生成toeplitz矩阵。用此函数开发另一个MATLAB函数来执行线性卷积
%例子 a=[1 2 3 4] ;  b=toeplitz(a)%inv(G)返回G的反函数%W=inv(G)*[R(1:5)]' geta=inv(x'*x)*x'*y;%输出拟合误差
error(k)=sum(abs(x*geta-y))/size(y,1);[Q,pValue,stat,cValue] = lbqtest(x*geta-y);if pValue<0.05error(k)=10000;end%https://www.ilovematlab.cn/thread-213882-1-1.html%https://bbs.pinggu.org/thread-3560191-1-1.html
%对误差的序列进行保存
bbbb=x*geta;
ccc=x*geta-y;%列向量for j=1:size(ccc)aaa(k,j)=ccc(j);bbb(k,j)=bbbb(j);end yuce(k)=[gaotie(N-n+1:N) cancha(length(cancha)-m+1:length(cancha))]*geta;   
gaotie=cD;
end
[e,pos]=min(error)
yucezhi=yuce(pos);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
for i=1:500if bbb(pos,i)<10000db(i)=bbb(pos,i);end
end
%figure(20);plot(db);
ddb=[cD(1:6*pos-2)' db];
% if p==2
% ddb=[b4(1:10)' db];
% end
% if p==3
% ddb=[b4(1:6*pos-2)' db];
% end
% if p==4
% ddb=[b4(1:22)' db4];
% endend

这篇关于ARMA模型带拟合的程序暂存的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/2019

相关文章

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

基于Python开发PDF转Doc格式小程序

《基于Python开发PDF转Doc格式小程序》这篇文章主要为大家详细介绍了如何基于Python开发PDF转Doc格式小程序,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用python实现PDF转Doc格式小程序以下是一个使用Python实现PDF转DOC格式的GUI程序,采用T

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

SpringBoot快速接入OpenAI大模型的方法(JDK8)

《SpringBoot快速接入OpenAI大模型的方法(JDK8)》本文介绍了如何使用AI4J快速接入OpenAI大模型,并展示了如何实现流式与非流式的输出,以及对函数调用的使用,AI4J支持JDK8... 目录使用AI4J快速接入OpenAI大模型介绍AI4J-github快速使用创建SpringBoot

将java程序打包成可执行文件的实现方式

《将java程序打包成可执行文件的实现方式》本文介绍了将Java程序打包成可执行文件的三种方法:手动打包(将编译后的代码及JRE运行环境一起打包),使用第三方打包工具(如Launch4j)和JDK自带... 目录1.问题提出2.如何将Java程序打包成可执行文件2.1将编译后的代码及jre运行环境一起打包2

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创