class dgame{
public static void main(String args[]){
double a,gov,beta,ls,ks,h,j;
int m,n;
double[] b =new double[11];
double[] k =new double[11];
double[][] tk =new double[11][11];
double[][] tl =new double[11][11];
double[][] tks =new double[11][11];
double[][] tls =new double[11][11];
double[][] cx =new double[11][11];
double[][] lx =new double[11][11];
double[][] cxs =new double[11][11];
double[][] v =new double[11][11];
double[][] vs =new double[11][11];
double[][] lxs =new double[11][11];
double[][] gotob=new double[11][11];
double[][] nextb=new double[11][11];
int t,t1,t2,t3,t4,t5,t6,t7,t8;
double m1,n1;
int n2,n3,m2,m3;
double dm,dn;
double k1,c1,l1,r1,tk1,w1;
double ep,bar;
double tax,bx;
double u1,v1;
int pp;
int s1,s2;
double maxv,tkps,tlps,tkp,tlp,z,cp,lp,bp,cps,lps,bps,vp,vps;
double mx;
bar=0.0001;
a=0.33;
gov=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;
j=0.01;
for (m=1;m<11;m++){
b[m]=m*j;
}
for (n=1;n<11;n++){
k[n]=n*h;
}
for (m=0;m<11;m++){
for (n=1;n<11;n++){
tk[m][n]=0.2;
tl[m][n]=0.2;
}
}
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)-gov;
}
}
for (m=0;m<10;m++){
for (n=1;n<11;n++){
gotob[m][n]=m;
}
}
z=0.02;
t8=0;
while(t8<5){
z=z/2;
t7=0;
while(t7<100){
t1=0;
while(t1<100){
for (m=0;m<10;m++){
for (n=1;n<10;n++){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lx[m][n],1-a)-cx[m][n]-gov;
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);
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<10;m++){
for (n=1;n<10;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<10;m++){
for (n=1;n<10;n++){
lx[m][n]=lxs[m][n];
cx[m][n]=cxs[m][n];
}
}
if (ep<bar) t1=1000;
t1=t1+1;
}
t2=0;
while(t2<100){
for (m=0;m<10;m++){
for (n=1;n<10;n++){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lx[m][n],1-a)-cx[m][n]-gov;
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);
tax=(tk[m][n]*a+tl[m][n]*(1-a))*Math.pow(k[n],a)*Math.pow(lx[m][n],1-a);
bx=(1+r1)*b[m]+tax-gov;
m1=bx/j;
nextb[m][n]=m1;
}
}
ep=0;
for (m=0;m<10;m++){
for (n=1;n<10;n++){
ep=ep+Math.pow(gotob[m][n]-nextb[m][n],2);
}
}
for (m=0;m<10;m++){
for (n=1;n<10;n++){
gotob[m][n]=nextb[m][n];
}
}
if (ep<bar)t2=1000;
t2=t2+1;
}
t3=0;
while(t3<1000){
for (m=0;m<10;m++){
for (n=1;n<10;n++){
u1=Math.log(cx[m][n])+Math.log(1-lx[m][n]);
k1=k[n]+Math.pow(k[n],a)*Math.pow(lx[m][n],1-a)-cx[m][n]-gov;
n1=k1/h;
n2=(int)n1;
n3=n2+1;
m1=gotob[m][n];
pp=0;
if (m1<0)pp=100;
if (m1>9)m1=9;
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=u1+beta*(v[m2][n2]+dm+dn);
if(pp>50)v1=-999;
vs[m][n]=v1;
}
}
ep=0;
for (m=0;m<10;m++){
for (n=1;n<10;n++){
ep=ep+Math.pow(v[m][n]-vs[m][n],2);
}
}
for (m=0;m<10;m++){
for (n=1;n<10;n++){
v[m][n]=vs[m][n];
}
}
if (ep<bar) t3=10000;
t3=t3+1;
}
for (m=0;m<10;m++){
for (n=1;n<10;n++){
maxv=-999;
tkps=tk[m][n];
tlps=tl[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;
if (tkp<0)tkp=tk[m][n];
if (tlp<0)tlp=tl[m][n];
if (tkp>0.9)tkp=tk[m][n];
if (tlp>0.9)tlp=tl[m][n];
cp=cx[m][n];
lp=lx[m][n];
bp=gotob[m][n];
t4=0;
while(t4<100){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lp,1-a)-cp-gov;
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);
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(cp-cps,2)+Math.pow(lp-lps,2);
cp=cps;
lp=lps;
if(ep<bar)t4=1000;
t4=t4+1;
}
t5=0;
while(t5<100){
k1=k[n]+Math.pow(k[n],a)*Math.pow(lp,1-a)-cp-gov;
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);
tax=(tkp*a+tlp*(1-a))*Math.pow(k[n],a)*Math.pow(lp,1-a);
bx=(1+r1)*b[m]+tax-gov;
m1=bx/j;
bps=m1;
ep=Math.pow(bp-bps,2);
bp=bps;
if(ep<bar)t5=1000;
t5=t5+1;
}
t6=0;
vp=v[m][n];
while(t6<100){
u1=Math.log(cp)+Math.log(1-lp);
k1=k[n]+Math.pow(k[n],a)*Math.pow(lp,1-a)-cp-gov;
n1=k1/h;
n2=(int)n1;
n3=n2+1;
m1=bp;
pp=0;
if (m1<0)pp=100;
if (m1>9)m1=9;
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=u1+beta*(v[m2][n2]+dm+dn);
if(pp>50)v1=-999;
vps=v1;
ep=Math.pow(vp-vps,2);
if(ep<bar)t6=1000;
vp=vps;
t6=t6+1;
}
if (vp>maxv)tkps=tkp;
if (vp>maxv)tlps=tlp;
if (vp>maxv)maxv=vp;
}
}
tks[m][n]=tkps;
tls[m][n]=tlps;
}
}
ep=0;
for (m=0;m<10;m++){
for (n=1;n<10;n++){
ep=ep+Math.pow(tk[m][n]-tks[m][n],2)+Math.pow(tl[m][n]-tls[m][n],2);
}
}
for (m=0;m<10;m++){
for (n=1;n<10;n++){
tk[m][n]=tks[m][n];
tl[m][n]=tls[m][n];
}
}
if(ep<bar)t7=1000;
t7=t7+1;
}
t8=t8+1;
}
mx=0;
k1=k[4];
for (t=0;t<100;t++){
n1=k1/h;
n2=(int)n1;
n3=n2+1;
m1=mx;
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)*(cx[m3][n2]-cx[m2][n2]);
dn=(n1-n2)*(cx[m2][n3]-cx[m2][n2]);
c1=cx[m2][n2]+dm+dn;
dm=(m1-m2)*(gotob[m3][n2]-gotob[m2][n2]);
dn=(n1-n2)*(gotob[m2][n3]-gotob[m2][n2]);
mx=gotob[m2][n2]+dm+dn;;
k1=k1+Math.pow(k1,a)*Math.pow(l1,1-a)-c1-gov;
dm=(m1-m2)*(tl[m3][n2]-tl[m2][n2]);
dn=(n1-n2)*(tl[m2][n3]-tl[m2][n2]);
tk1=tl[m2][n2]+dm+dn;
System.out.println(tk1);
}
}
}
最終更新:2010年01月20日 14:57