TVP-VAR模型MATLAB代码【增加时间标签、三维脉冲响应图、sa2参数输出】(企研数据修改自Nakajima(2011))

本文主要是介绍TVP-VAR模型MATLAB代码【增加时间标签、三维脉冲响应图、sa2参数输出】(企研数据修改自Nakajima(2011)),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、TVP-VAR模型与常用代码简介

【代码已修改完善,详见评论区】TVP-VAR模型(Time-Varying Parameter Vector AutoRegression,时变参数向量自回归模型)是在VAR模型的基础上拓展而来的模型,其假定系数矩阵和协方差矩阵是时变的,使得模型可以捕捉经济结构随时间变化的过程。

日本学者中岛上智(Jouchi Nakajima)于2011年发表的Time-Varying Parameter VAR Model with Stochastic Volatility: An Overview of Methodology and Empirical Applications是TVP-VAR领域的经典文献,其同时在个人网站上(https://sites.google.com/site/jnakajimaweb/)分享了论文中估计TVP-VAR模型所用的Oxmetrics和MATLAB程序代码,由于OxMetrics软件较为小众,因此很多人会选择使用更为熟悉的MATLAB版本的代码。

中岛上智教授分享的代码上一次更新时间为2020年5月1日,然而MATLAB版本的代码相比OxMetrics存在部分美中不足的地方,即MATLAB版本的代码无法显示现实的时间点,只能显示其在样本数据中的顺序,且MATLAB的作图限制导致其最多允许四条曲线叠加,如果想同时观察四种以上不同情况,难度比较大。

二、我们的工作

针对上述情况,我们谨慎修改了中岛上智教授发布的MATLAB版本的TVP-VAR模型代码,允许用户补充时间标签数据并将其显示出来,同时添加了生成三维脉冲响应图形的功能;针对许多人反应的缺少sa2参数的问题,我们谨慎添加了sa2参数结果的汇报需要声明的是,我们并未修改任何估计方法或参数,以确保结果的准确无误

如需获取代码压缩包请私信

以下为增加了sa2参数的汇报结果对比:

效果对比1:

效果对比2:

以下为原始输出结果和修改后输出结果的对比:

效果对比3:

效果对比4:

效果对比6:

效果对比5:

以下为部分三维脉冲响应图形的展示:

三、使用说明

  1. 中岛上智教授提供了样例数据,请严格按照样例数据的格式将要估计的数据存入EXCEL表中,每一列存储一个变量,左上角不留空白,且表中除数据外不存在多余的空白行,否则会导致估计出错;

  1. 例如,在中岛教授提供的tvpvar_ex.xlsx中,总共有124期、共三个变量的数据,存储在A1-C124的范围内的单元格中,如果存在空白行,则可能导致MATLAB在载入数据时扩大读取范围,如将A1-D200范围内的单元格一并读入,最终导致参数估计失败;

  1. 我们仿照并补充了中岛上智教授的样例数据所对应的时间标签数据,存储在tvpvar_ex_time.xlsx的A1-A124范围内的单元格中,EXCEL表中同样不允许存在多余的空白行;

  1. 时间格式等参数请参阅MATLAB的相关文档;

  1. tvpvar_m文件夹中为中岛教授的原始代码,tvpvar_m_modified文件夹中为修改后的代码,本版本代码仅修改了以下文件:drawimp.m;mcmc.m;tvpvar_ex1.m;tvpvar_ex2.m;

  1. sa2参数的汇报功能由团队成员添加,如存疑可以自行删去。

四、特别声明

本代码仅是对中岛上智教授工作成果的少量修饰,代码本身仍然是中岛上智教授的工作成果,如果使用了本代码,请按如下规范引用:

Nakajima, J. (2011) "Time-varying parameter VAR model with stochastic volatility: An overview of methodology and empirical applications" Monetary and Economic Studies, 29, 107-142.

严禁私自将本代码用于商业目的!违者必究!

如需获取代码压缩包请私信

这篇关于TVP-VAR模型MATLAB代码【增加时间标签、三维脉冲响应图、sa2参数输出】(企研数据修改自Nakajima(2011))的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

Java springBoot初步使用websocket的代码示例

《JavaspringBoot初步使用websocket的代码示例》:本文主要介绍JavaspringBoot初步使用websocket的相关资料,WebSocket是一种实现实时双向通信的协... 目录一、什么是websocket二、依赖坐标地址1.springBoot父级依赖2.springBoot依赖

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

Linux下修改hostname的三种实现方式

《Linux下修改hostname的三种实现方式》:本文主要介绍Linux下修改hostname的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下修改ho编程stname三种方式方法1:修改配置文件方法2:hFvEWEostnamectl命

什么是 Java 的 CyclicBarrier(代码示例)

《什么是Java的CyclicBarrier(代码示例)》CyclicBarrier是多线程协同的利器,适合需要多次同步的场景,本文通过代码示例讲解什么是Java的CyclicBarrier,感... 你的回答(口语化,面试场景)面试官:什么是 Java 的 CyclicBarrier?你:好的,我来举个例

通过ibd文件恢复MySql数据的操作方法

《通过ibd文件恢复MySql数据的操作方法》文章介绍通过.ibd文件恢复MySQL数据的过程,包括知道表结构和不知道表结构两种情况,对于知道表结构的情况,可以直接将.ibd文件复制到新的数据库目录并... 目录第一种情况:知道表结构第二种情况:不知道表结构总结今天干了一件大事,安装1Panel导致原来服务

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete

SpringBoot接收JSON类型的参数方式

《SpringBoot接收JSON类型的参数方式》:本文主要介绍SpringBoot接收JSON类型的参数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、jsON二、代码准备三、Apifox操作总结一、JSON在学习前端技术时,我们有讲到过JSON,而在

Maven pom.xml文件中build,plugin标签的使用小结

《Mavenpom.xml文件中build,plugin标签的使用小结》本文主要介绍了Mavenpom.xml文件中build,plugin标签的使用小结,文中通过示例代码介绍的非常详细,对大家的学... 目录<build> 标签Plugins插件<build> 标签<build> 标签是 pom.XML