アットウィキロゴ

JAVA DSGE 42

class dgame{
public static void main(String args[]){
double[][] tk=new double[11][11];
double[][] tl=new double[11][11];
double[][] lx=new double[11][11];
double[][] cx=new double[11][11];
double[][] lxs=new double[11][11];
double[][] cxs=new double[11][11];
double[][] startc=new double[11][11];
double[][] startl=new double[11][11];
double[][] gotob=new double[11][11];
double[][] makib=new double[11][11];
double[][] v=new double[11][11];
double[][] vs=new double[11][11];
double[] b=new double[11];
double[] k=new double[11];
int m,n;
int n2,n3,m2,m3;
double n1,m1;
double a,beta,ls,ks,h,j,g;
double k1,l1,dm,dn,tk1,r1,c1,w1;
double gov,b1;
double ep;
double v1;
int pp;
int t1,t2,t3,t4;
for (m=0;m<11;m++){
for (n=1;n<11;n++){
tk[m][n]=0.2;
tl[m][n]=0.2;
}
}
a=0.33;
g=0.05;
beta=0.95;
ls=(1-a)/(2-a);
ks=ls*Math.pow((1 / beta - 1) / a , 1 / (a - 1));
h=2*ks/10;
for (n=1;n<11;n++){
k[n]=n*h;
}
j=0.01;
for (m=0;m<11;m++){
b[m]=m*j;
}
for (m=0;m<11;m++){
for (n=1;n<11;n++){
lx[m][n]=ls;
cx[m][n]=Math.pow(k[n],a)*Math.pow(lx[m][n],1-a)-g;
}
}
for (m=0;m<11;m++){
for (n=1;n<11;n++){
gotob[m][n]=m;
}
}
t3=0;
while (t3<100){
t1=0;
while (t1<100){
for (m=0;m<11;m++){
for (n=1;n<11;n++){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lx[m][n],1-a)-cx[m][n]-g;
n1=k1/h;
n2=(int)n1;
n3=n2+1;
m1=gotob[m][n];
if (m1>9)m1=9;
if (m1<0)m1=0;
m2=(int)m1;
m3=m2+1;
dm=(m1-m2)*(lx[m3][n2]-lx[m2][n2]);
dn=(n1-n2)*(lx[m2][n3]-lx[m2][n2]);
l1=lx[m2][n2]+dm+dn;
dm=(m1-m2)*(tk[m3][n2]-tk[m2][n2]);
dn=(n1-n2)*(tk[m2][n3]-tk[m2][n2]);
tk1=tk[m2][n2]+dm+dn;
r1=(1-tk1)*a*Math.pow(k[n],a-1)*Math.pow(lx[m][n],1-a);
dm=(m1-m2)*(cx[m3][n2]-cx[m2][n2]);
dn=(n1-n2)*(cx[m2][n3]-cx[m2][n2]);
c1=cx[m2][n2]+dm+dn;
cxs[m][n]=c1/(beta*(1+r1));
w1=(1-tl[m][n])*(1-a)*Math.pow(k[n],a)*Math.pow(lx[m][n],-a);
lxs[m][n]=1-cx[m][n]/w1;
}
}
ep=0;
for (m=0;m<11;m++){
for (n=1;n<11;n++){
ep=ep+Math.pow(lxs[m][n]-lx[m][n],2)+Math.pow(cxs[m][n]-cx[m][n],2);
}
}
for (m=0;m<11;m++){
for (n=1;n<11;n++){
lx[m][n]=lxs[m][n];
cx[m][n]=cxs[m][n];
}
}
if (ep<0.001) t1=1000;
t1=t1+1;
}
t2=0;
while(t2<100){
for (m=0;m<11;m++){
for (n=1;n<11;n++){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lx[m][n],1-a)-cx[m][n]-g;
n1=k1/h;
n2=(int)n1;
n3=n2+1;
m1=gotob[m][n];
if (m1>9)m1=9;
if (m1<0)m1=0;
m2=(int)m1;
m3=m2+1;
dm=(m1-m2)*(lx[m3][n2]-lx[m2][n2]);
dn=(n1-n2)*(lx[m2][n3]-lx[m2][n2]);
l1=lx[m2][n2]+dm+dn;
dm=(m1-m2)*(tk[m3][n2]-tk[m2][n2]);
dn=(n1-n2)*(tk[m2][n3]-tk[m2][n2]);
tk1=tk[m2][n2]+dm+dn;
r1=(1-tk1)*a*Math.pow(k[n],a-1)*Math.pow(lx[m][n],1-a);
gov=(tk[m][n]*a+tl[m][n]*(1-a))*Math.pow(k[n],a)*Math.pow(lx[m][n],1-a);
b1=(1+r1)*b[m]+gov-g;
m1=b1/j;
if (m1<0)m1=0;
if (m1>10)m1=10;
makib[m][n]=m1;
}
}
ep=0;
for (m=0;m<11;m++){
for (n=1;n<11;n++){
ep=ep+Math.pow(makib[m][n]-gotob[m][n],2);
}
}
for (m=0;m<11;m++){
for (n=1;n<11;n++){
gotob[m][n]=makib[m][n];
}
}
if (ep<0.001)t2=1000;
t2=t2+1;
System.out.println(ep);
}
ep=0;
for (m=0;m<11;m++){
for (n=1;n<11;n++){
ep=ep+Math.pow(startl[m][n]-lx[m][n],2)+Math.pow(startc[m][n]-cx[m][n],2);
}
}
for (m=0;m<11;m++){
for (n=1;n<11;n++){
startl[m][n]=lx[m][n];
startc[m][n]=cx[m][n];
}
}
if (ep<0.001) t3=1000;
t3=t3+1;
}
t4=0;
while(t4<100){
for (m=0;m<11;m++){
for (n=1;n<11;n++){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lx[m][n],1-a)-cx[m][n]-g;
n1=k1/h;
n2=(int)n1;
n3=n2+1;
pp=0;
m1=gotob[m][n];
if (m1>9)m1=9;
if (m1<0)pp=100;
if (m1<0)m1=0;
m2=(int)m1;
m3=m2+1;
dm=(m1-m2)*(v[m3][n2]-v[m2][n2]);
dn=(n1-n2)*(v[m2][n3]-v[m2][n2]);
v1=v[m2][n2]+dm+dn;
v1=Math.log(cx[m][n])+Math.log(1-lx[m][n])+beta*v1;
if (pp>50)v1=-999;
vs[m][n]=v1;
}
}
ep=0;
for (m=0;m<11;m++){
for (n=1;n<11;n++){
ep=ep+Math.pow(v[m][n]-vs[m][n],2);
}
}
for (m=0;m<11;m++){
for (n=1;n<11;n++){
v[m][n]=vs[m][n];
}
}
if (ep<0.001) t4=1000;
t4=t4+1;
System.out.println(ep);

}



}
}
最終更新:2010年01月12日 15:55