#include <stdio.h>
#include <math.h>
int main(void){
double a,beta,ks,h,k1,r1,c1,e,n1,uc;
double k[101],cx[11][101],cp[11][101];
double th[11];
int s,n,n2,n3,t,s1;
FILE *fp;
for (s=1;s<=10;s++){
th[s]=0.95+0.01*s;
}
a=0.33;
beta=0.95;
ks=pow((1/beta-1)/a,1/(a-1));
h=2*ks/100;
for (n=1;n<=100;n++){
k[n] = n*h;
}
for (s=1;s<=10;s++){
for (n=1;n<=100;n++){
cx[s][n]=th[s]*pow(k[n],a);
}
}
t=0;
while (t<100){
for (s=1;s<=10;s++){
for (n=10;n<=90;n++){
k1=k[n]+th[s]*pow(k[n],a)-cx[s][n];
n1=k1/h;
n2=floor(n1);
n3=n2+1;
uc=0;
for (s1=1;s1<=10;s1++){
c1=cx[s1][n2]+(n1-n2)*(cx[s1][n3]-cx[s1][n2]);
r1=th[s1]*a*pow(k1,a-1);
uc=uc+(beta*(1+r1))/c1;
}
uc=0.1*uc;
cp[s][n]=1/uc;
}
}
e=0;
for (s=1;s<=10;s++){
for (n=10;n<=90;n++){
e=e+pow(cx[s][n]-cp[s][n],2);
}
}
for (s=1;s<=10;s++){
for (n=10;n<=90;n++){
cx[s][n]=cp[s][n];
}
}
if (e < 0.0001) t=1000;
t=t+1;
}
fp = fopen( "test.txt", "w" );
for (n=10;n<=90;n++){
fprintf(fp,"%f",cx[5][n]);
fprintf(fp,"\n");
}
fclose( fp );
return 0;
}
最終更新:2009年12月12日 17:33