-
Notifications
You must be signed in to change notification settings - Fork 0
/
modelGm7G.mod
86 lines (64 loc) · 1.5 KB
/
modelGm7G.mod
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
// Declare New Keynesian model with constant public employment, with government intervention
// Endogenous variables
var a c pie l n th R g gendo;
// Innovations
varexo epsa hireg gexo;
// Parameters
parameters phi phipi D s delta r omegah eta alpha omega gamma R0 rhoa epsilon sigmaa phir zeta;
[phirx,phix,phipix,Dx,sx,deltax,rx,omegahx,etax,alphax,omegax,gammax,R0x,rhoax,epsilonx,sigmaax,zetax,valgx]=SETUPB();
valg=valgx;
zeta=zetax;
phir=phirx;
phi=phix;
phipi=phipix;
D=Dx;
s=sx;
r=rx;
omegah=omegahx;
eta=etax;
alpha=alphax;
omega=omegax;
gamma=gammax;
R0=R0x;
rhoa=rhoax;
sigmaa=sigmaax;
epsilon=epsilonx;
delta=deltax;
// Model
model;
# q = omegah*th^(-eta);
# f = min(1,omegah*th^(1-eta));
# qn = omegah*th(+1)^(-eta);
# u = 1-(1-s)*n(-1);
# h = n-(1-s)*n(-1);
# w = omega*a^gamma;
# y = a*(l^alpha);
# mpl = a*alpha*l^(alpha-1);
//Monetary policy rule
R = max(1,R0*(1+pie)^(phipi*(1-phir))*(R(-1)/R0)^phir);
//Euler equation
1/R = delta*c/(c(+1)*(1+pie(+1)));
// Resource constraint
y=c*(1+(phi/2)*pie^2)+(r/q)*h*a;
//New Keynesian Phillips Curve
pie*(1+pie)=1/phi*(epsilon*((1/mpl)*(w+a*r/q-D*(c/c(+1))*a(+1)*r/qn))+(1-epsilon))*(y/c)+ delta*pie(+1)*(1+pie(+1));
//Laws of motion
n=l+g;
n=(1-s)*n(-1)+u*f;
gendo=(1-s)*gendo(-1)+hireg;
g=gendo+gexo;
//Technology Shocks
log(a) = rhoa* log(a(-1))+epsa;
end;
initval_file (filename = INNIT);
shocks;
var epsa;
periods 1;
values (-7*sigmaa);
var hireg;
periods 1;
values (valg);
end;
options_.maxit_=35;
options_.dynatol=10^(-13);
simul(periods=15000);