File: gshock.m

package info (click to toggle)
dynare 5.3-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 77,852 kB
  • sloc: cpp: 94,481; ansic: 28,551; pascal: 14,532; sh: 5,453; objc: 4,671; yacc: 4,442; makefile: 2,923; lex: 1,612; python: 677; ruby: 469; lisp: 156; xml: 22
file content (87 lines) | stat: -rw-r--r-- 2,911 bytes parent folder | download | duplicates (8)
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
function ExactSmyear = gshock(begy,begm,finy,finm,xlab,idfile,tlinput)
% ExactSmyear = gshock(begy,begm,finy,finm,xlab)
%  Plot the structural shocks for the range given by the inputs
%
% begy:  the beginning year for the graph
% begm:  the begiining month for the graph
% finy:  the end year for the graph
% finm:  the end month for the graph
% xlab:  label for each structural equation
%-----------
% ExactSmyear:  time (myears) and all structural shocks
%  if no nargout, plot graphics.
%
% October 1998 by Tao A. Zha
%
% 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/>.
%



eval(['load ' idfile '.mat']);

%
ibegy = find(myears==begy);
ifiny = find(myears==finy);

ibegy1 = find(myears==begy+1);

%
if isempty(ibegy) & isempty(ibegy1)
	warning('Either ibegy or begm is out of the range of myears')
	disp('Print myears to see the range')
	disp('Or change actuap to make the range longer and save new results to Xshock.mat')
	pause
elseif isempty(ibegy) & (begm<myears(1))
	warning('Either ibegy or begm is out of the range of myears')
	disp('Print myears to see the range')
	disp('Or change actuap to make the range longer and save new results to Xshock.mat')
	pause
elseif isempty(ibegy)
   ibegy = -myears(1)+2;  % +2 is needed for the following -1 in
	                        % bar(Estrexa(ibegy+begm-1:ifiny+finm-1,i))
									%so that it 2-1=1 so that +1 is what we want
end

%
if isempty(ifiny)
	warning('Either ifiny or finm is out of the range of myears')
	disp('Print myears to see the range')
	disp('Or change actuap to make the range longer and save new results to Xshock.mat')
	pause
elseif (ifiny+finm-1>size(myears,1))
	warning('Either ifiny or finm is out of the range of myears')
	disp('Print myears to see the range')
	disp('Or change actuap to make the range longer and save new results to Xshock.mat')
	pause
end


if nargout==0
	t=length(Estrexa(ibegy+begm-1:ifiny+finm-1,1));
	for i=1:size(Estrexa,2)
	   figure
	   %plot(1:t, Estrexa(ibegy+begm-1:ifiny+finm-1,i));
		bar(Estrexa(ibegy+begm-1:ifiny+finm-1,i))
		title([ tlinput ' Monthly Structural Shocks' ])
		ylabel(char(xlab(i)))
		xlabel([ 'From ' num2str(begy) ':' num2str(begm) ' to ' ...
							  num2str(finy) ':' num2str(finm) ])
		grid
	end
else
   ExactSmyear = [myears(ibegy+begm-1:ifiny+finm-1) Estrexa(ibegy+begm-1:ifiny+finm-1,:)];
end