アットウィキロゴ

JAVA DSGE 51

class dgame{
public static void main(String args[]){
double[][] tk=new double[11][11];
double[][] tl=new double[11][11];
double[][] maxtk=new double[11][11];
double[][] maxtl=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];
double[][] vv=new double[3][3];
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 tkp,tlp;
int s1,s2;
int pp;
double cp,lp,bp,cps,lps,z;
double mb;
int t1,t2,t3,t4,t5,t6,t7,t8;
double checkc,checkl;
double u1,v1,maxv;
int sx1,sx2;
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.1;
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;
}
}
t8=0;
while (t8<100){
t3=0;
while (t3<100){
t1=0;
while (t1<100){
for (m=0;m<11;m++){
for (n=3;n<8;n++){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lx[m][n],1-a)-cx[m][n]-g;
n1=k1/h;
if (n1>9)n1=9;
if (n1<1)n1=1;
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(k1,a-1)*Math.pow(l1,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=3;n<8;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=3;n<8;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(k1,a-1)*Math.pow(l1,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;
}
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=3;n<8;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;
}
for (m=0;m<11;m++){
for (n=3;n<8;n++){
z=0.01;
cp=cx[m][n];
lp=lx[m][n];
bp=gotob[m][n];
for (s1=-1;s1<2;s1++){
for (s2=-1;s2<2;s2++){
tkp=tk[m][n]+s1*z;
tlp=tl[m][n]*s2*z;
t7=0;
checkc=0;
checkl=0;
while(t7<100){
t5=0;
while(t5<100){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lp,1-a)-cp-g;
n1=k1/h;
if (n1>9)n1=9;
if (n1<1)n1=1;
n2=(int)n1;
n3=n2+1;
m1=bp;
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(k1,a-1)*Math.pow(l1,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;
cps=c1/(beta*(1+r1));
w1=(1-tlp)*(1-a)*Math.pow(k[n],a)*Math.pow(lp,-a);
lps=1-cp/w1;
ep=Math.pow(cps-cp,2)+Math.pow(lps-lp,2);
cp=cps;
lp=lps;
if (ep<0.00001)t5=1000;
t5=t5+1;
}
t6=0;
while(t6<100){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lp,1-a)-cp-g;
n1=k1/h;
n2=(int)n1;
n3=n2+1;
m1=bp;
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(k1,a-1)*Math.pow(l1,1-a);
gov=(tk[m][n]*a+tl[m][n]*(1-a))*Math.pow(k[n],a)*Math.pow(lp,1-a);
b1=(1+r1)*b[m]+gov-g;
m1=b1/j;
if (m1<0)m1=0;
if (m1>10)m1=10;
mb=m1;
ep=Math.pow(mb-bp,2);
bp=mb;
if (ep<0.00001)t6=1000;
t6=t6+1;
}
ep=Math.pow(checkc-cp,2)+Math.pow(checkl-lp,2);
checkc=cp;
checkl=lp;
if (ep<0.0001)t7=1000;
t7=t7+1;
}
u1=Math.log(cp)+Math.log(1-lp);
k1=k[n]+Math.pow(k[n],a)*Math.pow(lp,1-a)-cp-g;
n1=k1/h;
n2=(int)n1;
n3=n2+1;
m1=bp;
pp=0;
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;
vv[s1+1][s2+1]=u1+beta*v1;
if (pp>50)vv[s1+1][s2+1]=-999;
}
}
sx1=0;
sx2=0;
maxv=-999;
for (s1=-1;s1<2;s1++){
for (s2=-1;s2<2;s2++){
if (vv[s1+1][s2+1]>maxv)sx1=s1;
if (vv[s1+1][s2+1]>maxv)sx2=s2;
if (vv[s1+1][s2+1]>maxv)maxv=vv[s1+1][s2+1];
}
}
maxtk[m][n]=tk[m][n]+sx1*z;
maxtl[m][n]=tl[m][n]+sx2*z;
}
}
ep=0;
for (m=0;m<11;m++){
for (n=1;n<11;n++){
ep=ep+Math.pow(maxtk[m][n]-tk[m][n],2)+Math.pow(maxtl[m][n]-tl[m][n],2);
}
}
for (m=0;m<11;m++){
for (n=1;n<11;n++){
tk[m][n]=maxtk[m][n];
tl[m][n]=maxtl[m][n];
}
}
System.out.println(ep);
if (ep<0.001)t8=1000;
t8=t8+1;
}

}
}
最終更新:2010年01月13日 15:03