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 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
function fn_forerrgraph(yfore,yforel,yforeh,yacte,keyindx,rnum,cnum,q_m,ylab,forelabel,conlab)
%
% Graph annual (or calendar year) forecasts with one error band vs actual
% Import some data from "msstart.m"
%
% yfore: both actual and forecast annual growth data with dates in the first 2 columns
% in the order of year and month (or quarter).
% yforel: lower bound of the forecast.
% yforeh: high bound of the forecast.
% yacte: actual annual growth data with dates.
% keyindx: index for the variables to be graphed
% rnum: number of rows in subplot
% cnum: number of columns in subplot
% q_m: if 4 or 12, quarterly or monthly data.
% ylab: string array for the length(keyindx)-by-1 variables
% forelabel: title label for as of time of forecast
% conlab: x-axis label for what conditions imposed; e.g., conlab = 'All bar MS shocks inspl'
%-------------
% No output argument for this graph file.
% See fn_seriesgraph.m, fn_foregraph.m.
%
% Tao Zha, August 2000
%
% Copyright (C) 1997-2012 Tao Zha
%
% This free software: you can redistribute it and/or modify
% it under the terms of the GNU General Public License as published by
% the Free Software Foundation, either version 3 of the License, or
% (at your option) any later version.
%
% It is distributed in the hope that it will be useful,
% but WITHOUT ANY WARRANTY; without even the implied warranty of
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
% GNU General Public License for more details.
%
% If you did not received a copy of the GNU General Public License
% with this software, see <http://www.gnu.org/licenses/>.
%
vyrs = yfore(:,1); % vectorized
hornum = cell(length(vyrs),1); % horizontal year (number)
count=0;
for k=vyrs'
count=count+1;
jnk=num2str(k);
hornum{count}=jnk(3:4); % e.g., with '1990', we have '90'
end
count=0;
for i = keyindx
count = count+1;
subplot(rnum,cnum,count)
plot(yacte(:,1)+yacte(:,2)/q_m,yacte(:,2+i),yfore(:,1)+yfore(:,2)/q_m,yfore(:,2+i),'--',...
yforel(:,1)+yforel(:,2)/q_m,yforel(:,2+i),'-.',yforeh(:,1)+yforeh(:,2)/q_m,yforeh(:,2+i),'-.')
if (yfore(1,2)==0) % only for annual growth rates (not for, say, monthly annualized rates)
set(gca,'XLim',[vyrs(1) vyrs(end)])
set(gca,'XTick',vyrs)
set(gca,'XTickLabel',char(hornum))
end
if i==keyindx(1)
title(forelabel)
elseif i>=length(keyindx) %i>=length(keyindx)-1
xlabel(conlab)
end
%
grid
ylabel(char(ylab(i)))
end
|