-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathVAR_avg_est.m
37 lines (25 loc) · 1.42 KB
/
VAR_avg_est.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
function [IRF,n_lags_est,weightOut,submodelIRFOut] = VAR_avg_est(data_sim,settings)
% Function for estimating IRFs using VAR model averaging
% preparations
average_max_lags = settings.est.average_max_lags;
h_store = settings.est.average_store_weight;
store_submodel_irf = settings.est.average_store_submodel_irf;
run('Estimation_Setup'); % common setup for all estimation methods
weightOut = NaN(2 * n_lags_max, length(h_store)); % placeholder for weights on different VAR submodels
submodelIRFOut = NaN(2 * n_lags_max, IRF_hor); % placeholder for irf estimates on different VAR submodels
% check if averaging from one lag to max number of lags
if average_max_lags == 1
n_lags_average_over = n_lags_max; % to max number of lags
else
n_lags_average_over = nlags; % to fixed/estimated number of lags
end
% estimate different VAR submodels
[combination_irf,weights,G,submodel_irf] = VAR_ModelAverage(Y,recursiveShock,responseV,n_lags_average_over,nlags,IRF_hor - 1,settings.est.average_options);
IRF = combination_irf / G(normalizeV, recursiveShock); % IRF normalize by response of normalization variable. Warning: correspond to matrix C in our paper
% store submodel IRF
if store_submodel_irf == 1
submodelIRFOut(1:(n_lags_average_over * 2), :) = (submodel_irf / G(normalizeV, recursiveShock))';
end
% store weights
weightOut(1:(n_lags_average_over * 2), :) = weights(:, h_store - 1); % record weights of submodels at horizon h
end