version 1.10, 2001/05/09 14:25:42
|
version 1.13, 2002/02/20 17:02:08
|
Line 8
|
Line 8
|
Health expectancies are computed from the transistions observed between
|
Health expectancies are computed from the transistions observed between
|
waves and are computed for each degree of severity of disability (number
|
waves and are computed for each degree of severity of disability (number
|
of life states). More degrees you consider, more time is necessary to
|
of life states). More degrees you consider, more time is necessary to
|
reach the Maximum Likelihood of the parameters involved in the model.
|
reach the Maximum Likelihood of the parameters involved in the model.
|
The simplest model is the multinomial logistic model where pij is
|
The simplest model is the multinomial logistic model where pij is
|
the probabibility to be observed in state j at the second wave conditional
|
the probabibility to be observed in state j at the second wave conditional
|
to be observed in state i at the first wave. Therefore the model is:
|
to be observed in state i at the first wave. Therefore the model is:
|
Line 22
|
Line 22
|
delay between waves is not identical for each individual, or if some
|
delay between waves is not identical for each individual, or if some
|
individual missed an interview, the information is not rounded or lost, but
|
individual missed an interview, the information is not rounded or lost, but
|
taken into account using an interpolation or extrapolation.
|
taken into account using an interpolation or extrapolation.
|
hPijx is the probability to be
|
hPijx is the probability to be
|
observed in state i at age x+h conditional to the observed state i at age
|
observed in state i at age x+h conditional to the observed state i at age
|
x. The delay 'h' can be split into an exact number (nh*stepm) of
|
x. The delay 'h' can be split into an exact number (nh*stepm) of
|
unobserved intermediate states. This elementary transition (by month or
|
unobserved intermediate states. This elementary transition (by month or
|
Line 83 int **dh; /* dh[mi][i] is number of step
|
Line 83 int **dh; /* dh[mi][i] is number of step
|
double jmean; /* Mean space between 2 waves */
|
double jmean; /* Mean space between 2 waves */
|
double **oldm, **newm, **savm; /* Working pointers to matrices */
|
double **oldm, **newm, **savm; /* Working pointers to matrices */
|
double **oldms, **newms, **savms; /* Fixed working pointers to matrices */
|
double **oldms, **newms, **savms; /* Fixed working pointers to matrices */
|
FILE *fic,*ficpar, *ficparo,*ficres, *ficrespl, *ficrespij, *ficrest;
|
FILE *fic,*ficpar, *ficparo,*ficres, *ficrespl, *ficrespij, *ficrest,*ficresf;
|
FILE *ficgp, *fichtm;
|
FILE *ficgp, *fichtm,*ficresprob;
|
FILE *ficreseij;
|
FILE *ficreseij;
|
char filerese[FILENAMELENGTH];
|
char filerese[FILENAMELENGTH];
|
FILE *ficresvij;
|
FILE *ficresvij;
|
Line 127 int stepm;
|
Line 127 int stepm;
|
int m,nb;
|
int m,nb;
|
int *num, firstpass=0, lastpass=4,*cod, *ncodemax, *Tage;
|
int *num, firstpass=0, lastpass=4,*cod, *ncodemax, *Tage;
|
double **agev,*moisnais, *annais, *moisdc, *andc,**mint, **anint;
|
double **agev,*moisnais, *annais, *moisdc, *andc,**mint, **anint;
|
double **pmmij;
|
double **pmmij, ***probs, ***mobaverage;
|
|
|
double *weight;
|
double *weight;
|
int **s; /* Status */
|
int **s; /* Status */
|
Line 693 double **prevalim(double **prlim, int nl
|
Line 693 double **prevalim(double **prlim, int nl
|
}
|
}
|
}
|
}
|
|
|
/*************** transition probabilities **********/
|
/*************** transition probabilities ***************/
|
|
|
double **pmij(double **ps, double *cov, int ncovmodel, double *x, int nlstate )
|
double **pmij(double **ps, double *cov, int ncovmodel, double *x, int nlstate )
|
{
|
{
|
Line 716 double **pmij(double **ps, double *cov,
|
Line 716 double **pmij(double **ps, double *cov,
|
s2 += x[(i-1)*nlstate*ncovmodel+(j-2)*ncovmodel+nc+(i-1)*(ndeath-1)*ncovmodel]*cov[nc];
|
s2 += x[(i-1)*nlstate*ncovmodel+(j-2)*ncovmodel+nc+(i-1)*(ndeath-1)*ncovmodel]*cov[nc];
|
/*printf("Int j>i s1=%.17e, s2=%.17e %lx %lx\n",s1,s2,s1,s2);*/
|
/*printf("Int j>i s1=%.17e, s2=%.17e %lx %lx\n",s1,s2,s1,s2);*/
|
}
|
}
|
ps[i][j]=s2;
|
ps[i][j]=(s2);
|
}
|
}
|
}
|
}
|
|
/*ps[3][2]=1;*/
|
|
|
for(i=1; i<= nlstate; i++){
|
for(i=1; i<= nlstate; i++){
|
s1=0;
|
s1=0;
|
for(j=1; j<i; j++)
|
for(j=1; j<i; j++)
|
Line 740 double **pmij(double **ps, double *cov,
|
Line 742 double **pmij(double **ps, double *cov,
|
}
|
}
|
}
|
}
|
|
|
|
|
/* for(ii=1; ii<= nlstate+ndeath; ii++){
|
/* for(ii=1; ii<= nlstate+ndeath; ii++){
|
for(jj=1; jj<= nlstate+ndeath; jj++){
|
for(jj=1; jj<= nlstate+ndeath; jj++){
|
printf("%lf ",ps[ii][jj]);
|
printf("%lf ",ps[ii][jj]);
|
Line 757 double **pmij(double **ps, double *cov,
|
Line 760 double **pmij(double **ps, double *cov,
|
|
|
double **matprod2(double **out, double **in,long nrl, long nrh, long ncl, long nch, long ncolol, long ncoloh, double **b)
|
double **matprod2(double **out, double **in,long nrl, long nrh, long ncl, long nch, long ncolol, long ncoloh, double **b)
|
{
|
{
|
/* Computes the matric product of in(1,nrh-nrl+1)(1,nch-ncl+1) times
|
/* Computes the matrix product of in(1,nrh-nrl+1)(1,nch-ncl+1) times
|
b(1,nch-ncl+1)(1,ncoloh-ncolol+1) into out(...) */
|
b(1,nch-ncl+1)(1,ncoloh-ncolol+1) into out(...) */
|
/* in, b, out are matrice of pointers which should have been initialized
|
/* in, b, out are matrice of pointers which should have been initialized
|
before: only the contents of out is modified. The function returns
|
before: only the contents of out is modified. The function returns
|
Line 804 double ***hpxij(double ***po, int nhstep
|
Line 807 double ***hpxij(double ***po, int nhstep
|
cov[1]=1.;
|
cov[1]=1.;
|
cov[2]=age+((h-1)*hstepm + (d-1))*stepm/YEARM;
|
cov[2]=age+((h-1)*hstepm + (d-1))*stepm/YEARM;
|
for (k=1; k<=cptcovn;k++) cov[2+k]=nbcode[Tvar[k]][codtab[ij][Tvar[k]]];
|
for (k=1; k<=cptcovn;k++) cov[2+k]=nbcode[Tvar[k]][codtab[ij][Tvar[k]]];
|
for (k=1; k<=cptcovage;k++)
|
for (k=1; k<=cptcovage;k++)
|
cov[2+Tage[k]]=cov[2+Tage[k]]*cov[2];
|
cov[2+Tage[k]]=cov[2+Tage[k]]*cov[2];
|
for (k=1; k<=cptcovprod;k++)
|
for (k=1; k<=cptcovprod;k++)
|
cov[2+Tprod[k]]=nbcode[Tvard[k][1]][codtab[ij][Tvard[k][1]]]*nbcode[Tvard[k][2]][codtab[ij][Tvard[k][2]]];
|
cov[2+Tprod[k]]=nbcode[Tvard[k][1]][codtab[ij][Tvard[k][1]]]*nbcode[Tvard[k][2]][codtab[ij][Tvard[k][2]]];
|
|
|
|
|
Line 913 void hesscov(double **matcov, double p[]
|
Line 916 void hesscov(double **matcov, double p[]
|
void lubksb(double **a, int npar, int *indx, double b[]) ;
|
void lubksb(double **a, int npar, int *indx, double b[]) ;
|
void ludcmp(double **a, int npar, int *indx, double *d) ;
|
void ludcmp(double **a, int npar, int *indx, double *d) ;
|
|
|
|
|
hess=matrix(1,npar,1,npar);
|
hess=matrix(1,npar,1,npar);
|
|
|
printf("\nCalculation of the hessian matrix. Wait...\n");
|
printf("\nCalculation of the hessian matrix. Wait...\n");
|
Line 921 void hesscov(double **matcov, double p[]
|
Line 923 void hesscov(double **matcov, double p[]
|
printf("%d",i);fflush(stdout);
|
printf("%d",i);fflush(stdout);
|
hess[i][i]=hessii(p,ftolhess,i,delti);
|
hess[i][i]=hessii(p,ftolhess,i,delti);
|
/*printf(" %f ",p[i]);*/
|
/*printf(" %f ",p[i]);*/
|
|
/*printf(" %lf ",hess[i][i]);*/
|
}
|
}
|
|
|
for (i=1;i<=npar;i++) {
|
for (i=1;i<=npar;i++) {
|
for (j=1;j<=npar;j++) {
|
for (j=1;j<=npar;j++) {
|
if (j>i) {
|
if (j>i) {
|
printf(".%d%d",i,j);fflush(stdout);
|
printf(".%d%d",i,j);fflush(stdout);
|
hess[i][j]=hessij(p,delti,i,j);
|
hess[i][j]=hessij(p,delti,i,j);
|
hess[j][i]=hess[i][j];
|
hess[j][i]=hess[i][j];
|
|
/*printf(" %lf ",hess[i][j]);*/
|
}
|
}
|
}
|
}
|
}
|
}
|
Line 1032 double hessii( double x[], double delta,
|
Line 1036 double hessii( double x[], double delta,
|
}
|
}
|
}
|
}
|
delti[theta]=delts;
|
delti[theta]=delts;
|
return res;
|
return res;
|
|
|
}
|
}
|
|
|
Line 1156 void freqsummary(char fileres[], int ag
|
Line 1160 void freqsummary(char fileres[], int ag
|
char fileresp[FILENAMELENGTH];
|
char fileresp[FILENAMELENGTH];
|
|
|
pp=vector(1,nlstate);
|
pp=vector(1,nlstate);
|
|
probs= ma3x(1,130 ,1,8, 1,8);
|
strcpy(fileresp,"p");
|
strcpy(fileresp,"p");
|
strcat(fileresp,fileres);
|
strcat(fileresp,fileres);
|
if((ficresp=fopen(fileresp,"w"))==NULL) {
|
if((ficresp=fopen(fileresp,"w"))==NULL) {
|
Line 1233 void freqsummary(char fileres[], int ag
|
Line 1237 void freqsummary(char fileres[], int ag
|
else
|
else
|
printf(" %d.=%.0f prev[%d]=NaNQ%%",jk,pp[jk],jk);
|
printf(" %d.=%.0f prev[%d]=NaNQ%%",jk,pp[jk],jk);
|
if( i <= (int) agemax){
|
if( i <= (int) agemax){
|
if(pos>=1.e-5)
|
if(pos>=1.e-5){
|
fprintf(ficresp," %d %.5f %.0f %.0f",i,pp[jk]/pos, pp[jk],pos);
|
fprintf(ficresp," %d %.5f %.0f %.0f",i,pp[jk]/pos, pp[jk],pos);
|
|
probs[i][jk][j1]= pp[jk]/pos;
|
|
/*printf("\ni=%d jk=%d j1=%d %.5f %.0f %.0f %f",i,jk,j1,pp[jk]/pos, pp[jk],pos,probs[i][jk][j1]);*/
|
|
}
|
else
|
else
|
fprintf(ficresp," %d NaNq %.0f %.0f",i,pp[jk],pos);
|
fprintf(ficresp," %d NaNq %.0f %.0f",i,pp[jk],pos);
|
}
|
}
|
Line 1270 void concatwav(int wav[], int **dh, int
|
Line 1277 void concatwav(int wav[], int **dh, int
|
/* int j, k=0,jk, ju, jl,jmin=1e+5, jmax=-1;
|
/* int j, k=0,jk, ju, jl,jmin=1e+5, jmax=-1;
|
double sum=0., jmean=0.;*/
|
double sum=0., jmean=0.;*/
|
|
|
int j, k=0,jk, ju, jl;
|
int j, k=0,jk, ju, jl;
|
double sum=0.;
|
double sum=0.;
|
jmin=1e+5;
|
jmin=1e+5;
|
jmax=-1;
|
jmax=-1;
|
jmean=0.;
|
jmean=0.;
|
for(i=1; i<=imx; i++){
|
for(i=1; i<=imx; i++){
|
mi=0;
|
mi=0;
|
m=firstpass;
|
m=firstpass;
|
Line 1309 jmean=0.;
|
Line 1316 jmean=0.;
|
if(j==0) j=1; /* Survives at least one month after exam */
|
if(j==0) j=1; /* Survives at least one month after exam */
|
k=k+1;
|
k=k+1;
|
if (j >= jmax) jmax=j;
|
if (j >= jmax) jmax=j;
|
else if (j <= jmin)jmin=j;
|
if (j <= jmin) jmin=j;
|
sum=sum+j;
|
sum=sum+j;
|
if (j<0) printf("j=%d num=%d ",j,i);
|
/* if (j<10) printf("j=%d num=%d ",j,i); */
|
}
|
}
|
}
|
}
|
else{
|
else{
|
Line 1319 jmean=0.;
|
Line 1326 jmean=0.;
|
k=k+1;
|
k=k+1;
|
if (j >= jmax) jmax=j;
|
if (j >= jmax) jmax=j;
|
else if (j <= jmin)jmin=j;
|
else if (j <= jmin)jmin=j;
|
|
/* if (j<10) printf("j=%d jmin=%d num=%d ",j,jmin,i); */
|
sum=sum+j;
|
sum=sum+j;
|
}
|
}
|
jk= j/stepm;
|
jk= j/stepm;
|
Line 1335 jmean=0.;
|
Line 1343 jmean=0.;
|
}
|
}
|
jmean=sum/k;
|
jmean=sum/k;
|
printf("Delay (in months) between two waves Min=%d Max=%d Mean=%f\n\n ",jmin, jmax,jmean);
|
printf("Delay (in months) between two waves Min=%d Max=%d Mean=%f\n\n ",jmin, jmax,jmean);
|
}
|
}
|
/*********** Tricode ****************************/
|
/*********** Tricode ****************************/
|
void tricode(int *Tvar, int **nbcode, int imx)
|
void tricode(int *Tvar, int **nbcode, int imx)
|
{
|
{
|
Line 1373 void tricode(int *Tvar, int **nbcode, in
|
Line 1381 void tricode(int *Tvar, int **nbcode, in
|
|
|
for (k=0; k<19; k++) Ndum[k]=0;
|
for (k=0; k<19; k++) Ndum[k]=0;
|
|
|
for (i=1; i<=ncovmodel; i++) {
|
for (i=1; i<=ncovmodel-2; i++) {
|
ij=Tvar[i];
|
ij=Tvar[i];
|
Ndum[ij]++;
|
Ndum[ij]++;
|
}
|
}
|
Line 1448 void varevsij(char fileres[], double ***
|
Line 1456 void varevsij(char fileres[], double ***
|
double **dnewm,**doldm;
|
double **dnewm,**doldm;
|
int i, j, nhstepm, hstepm, h;
|
int i, j, nhstepm, hstepm, h;
|
int k, cptcode;
|
int k, cptcode;
|
double *xp;
|
double *xp;
|
double **gp, **gm;
|
double **gp, **gm;
|
double ***gradg, ***trgradg;
|
double ***gradg, ***trgradg;
|
double ***p3mat;
|
double ***p3mat;
|
Line 1630 void varprevlim(char fileres[], double *
|
Line 1638 void varprevlim(char fileres[], double *
|
|
|
}
|
}
|
|
|
|
/************ Variance of one-step probabilities ******************/
|
|
void varprob(char fileres[], double **matcov, double x[], double delti[], int nlstate, double bage, double fage, int ij)
|
|
{
|
|
int i, j;
|
|
int k=0, cptcode;
|
|
double **dnewm,**doldm;
|
|
double *xp;
|
|
double *gp, *gm;
|
|
double **gradg, **trgradg;
|
|
double age,agelim, cov[NCOVMAX];
|
|
int theta;
|
|
char fileresprob[FILENAMELENGTH];
|
|
|
|
strcpy(fileresprob,"prob");
|
|
strcat(fileresprob,fileres);
|
|
if((ficresprob=fopen(fileresprob,"w"))==NULL) {
|
|
printf("Problem with resultfile: %s\n", fileresprob);
|
|
}
|
|
printf("Computing variance of one-step probabilities: result on file '%s' \n",fileresprob);
|
|
|
|
|
|
xp=vector(1,npar);
|
|
dnewm=matrix(1,(nlstate+ndeath)*(nlstate+ndeath),1,npar);
|
|
doldm=matrix(1,(nlstate+ndeath)*(nlstate+ndeath),1,(nlstate+ndeath)*(nlstate+ndeath));
|
|
|
|
cov[1]=1;
|
|
for (age=bage; age<=fage; age ++){
|
|
cov[2]=age;
|
|
gradg=matrix(1,npar,1,9);
|
|
trgradg=matrix(1,9,1,npar);
|
|
gp=vector(1,(nlstate+ndeath)*(nlstate+ndeath));
|
|
gm=vector(1,(nlstate+ndeath)*(nlstate+ndeath));
|
|
|
|
for(theta=1; theta <=npar; theta++){
|
|
for(i=1; i<=npar; i++)
|
|
xp[i] = x[i] + (i==theta ?delti[theta]:0);
|
|
|
|
pmij(pmmij,cov,ncovmodel,xp,nlstate);
|
|
|
|
k=0;
|
|
for(i=1; i<= (nlstate+ndeath); i++){
|
|
for(j=1; j<=(nlstate+ndeath);j++){
|
|
k=k+1;
|
|
gp[k]=pmmij[i][j];
|
|
}
|
|
}
|
|
|
|
for(i=1; i<=npar; i++)
|
|
xp[i] = x[i] - (i==theta ?delti[theta]:0);
|
|
|
|
|
|
pmij(pmmij,cov,ncovmodel,xp,nlstate);
|
|
k=0;
|
|
for(i=1; i<=(nlstate+ndeath); i++){
|
|
for(j=1; j<=(nlstate+ndeath);j++){
|
|
k=k+1;
|
|
gm[k]=pmmij[i][j];
|
|
}
|
|
}
|
|
|
|
for(i=1; i<= (nlstate+ndeath)*(nlstate+ndeath); i++)
|
|
gradg[theta][i]=(gp[i]-gm[i])/2./delti[theta];
|
|
}
|
|
|
|
for(j=1; j<=(nlstate+ndeath)*(nlstate+ndeath);j++)
|
|
for(theta=1; theta <=npar; theta++)
|
|
trgradg[j][theta]=gradg[theta][j];
|
|
|
|
matprod2(dnewm,trgradg,1,9,1,npar,1,npar,matcov);
|
|
matprod2(doldm,dnewm,1,9,1,npar,1,9,gradg);
|
|
|
|
pmij(pmmij,cov,ncovmodel,x,nlstate);
|
|
|
|
k=0;
|
|
for(i=1; i<=(nlstate+ndeath); i++){
|
|
for(j=1; j<=(nlstate+ndeath);j++){
|
|
k=k+1;
|
|
gm[k]=pmmij[i][j];
|
|
}
|
|
}
|
|
|
|
/*printf("\n%d ",(int)age);
|
|
for (i=1; i<=(nlstate+ndeath)*(nlstate+ndeath-1);i++){
|
|
|
|
|
|
printf("%e [%e ;%e] ",gm[i],gm[i]-2*sqrt(doldm[i][i]),gm[i]+2*sqrt(doldm[i][i]));
|
|
}*/
|
|
|
|
fprintf(ficresprob,"\n%d ",(int)age);
|
|
|
|
for (i=1; i<=(nlstate+ndeath)*(nlstate+ndeath-1);i++){
|
|
if (i== 2) fprintf(ficresprob,"%.3e %.3e ",gm[i],doldm[i][i]);
|
|
if (i== 4) fprintf(ficresprob,"%.3e %.3e ",gm[i],doldm[i][i]);
|
|
}
|
|
|
|
free_vector(gp,1,(nlstate+ndeath)*(nlstate+ndeath));
|
|
free_vector(gm,1,(nlstate+ndeath)*(nlstate+ndeath));
|
|
free_matrix(trgradg,1,(nlstate+ndeath)*(nlstate+ndeath),1,npar);
|
|
free_matrix(gradg,1,(nlstate+ndeath)*(nlstate+ndeath),1,npar);
|
|
}
|
|
free_vector(xp,1,npar);
|
|
fclose(ficresprob);
|
|
exit(0);
|
|
}
|
|
|
/***********************************************/
|
/***********************************************/
|
/**************** Main Program *****************/
|
/**************** Main Program *****************/
|
Line 1653 int main()
|
Line 1764 int main()
|
char line[MAXLINE], linepar[MAXLINE];
|
char line[MAXLINE], linepar[MAXLINE];
|
char title[MAXLINE];
|
char title[MAXLINE];
|
char optionfile[FILENAMELENGTH], datafile[FILENAMELENGTH], filerespl[FILENAMELENGTH], optionfilehtm[FILENAMELENGTH];
|
char optionfile[FILENAMELENGTH], datafile[FILENAMELENGTH], filerespl[FILENAMELENGTH], optionfilehtm[FILENAMELENGTH];
|
char fileres[FILENAMELENGTH], filerespij[FILENAMELENGTH], filereso[FILENAMELENGTH];
|
char fileres[FILENAMELENGTH], filerespij[FILENAMELENGTH], filereso[FILENAMELENGTH], fileresf[FILENAMELENGTH];
|
char filerest[FILENAMELENGTH];
|
char filerest[FILENAMELENGTH];
|
char fileregp[FILENAMELENGTH];
|
char fileregp[FILENAMELENGTH];
|
char path[80],pathc[80],pathcd[80],pathtot[80],model[20];
|
char path[80],pathc[80],pathcd[80],pathtot[80],model[20];
|
Line 1663 int main()
|
Line 1774 int main()
|
int ju,jl, mi;
|
int ju,jl, mi;
|
int i1,j1, k1,k2,k3,jk,aa,bb, stepsize, ij;
|
int i1,j1, k1,k2,k3,jk,aa,bb, stepsize, ij;
|
int jnais,jdc,jint4,jint1,jint2,jint3,**outcome,**adl,*tab;
|
int jnais,jdc,jint4,jint1,jint2,jint3,**outcome,**adl,*tab;
|
|
|
int hstepm, nhstepm;
|
int hstepm, nhstepm;
|
double bage, fage, age, agelim, agebase;
|
double bage, fage, age, agelim, agebase;
|
double ftolpl=FTOL;
|
double ftolpl=FTOL;
|
Line 1677 int main()
|
Line 1788 int main()
|
double ***eij, ***vareij;
|
double ***eij, ***vareij;
|
double **varpl; /* Variances of prevalence limits by age */
|
double **varpl; /* Variances of prevalence limits by age */
|
double *epj, vepp;
|
double *epj, vepp;
|
|
double kk1;
|
|
|
char version[80]="Imach version 64b, May 2001, INED-EUROREVES ";
|
char version[80]="Imach version 64b, May 2001, INED-EUROREVES ";
|
char *alph[]={"a","a","b","c","d","e"}, str[4];
|
char *alph[]={"a","a","b","c","d","e"}, str[4];
|
|
|
|
|
char z[1]="c", occ;
|
char z[1]="c", occ;
|
#include <sys/time.h>
|
#include <sys/time.h>
|
#include <time.h>
|
#include <time.h>
|
Line 1772 split(pathtot, path,optionfile);
|
Line 1886 split(pathtot, path,optionfile);
|
fprintf(ficparo,"\n");
|
fprintf(ficparo,"\n");
|
}
|
}
|
|
|
npar= (nlstate+ndeath-1)*nlstate*ncovmodel;
|
npar= (nlstate+ndeath-1)*nlstate*ncovmodel;
|
|
|
p=param[1][1];
|
p=param[1][1];
|
|
|
/* Reads comments: lines beginning with '#' */
|
/* Reads comments: lines beginning with '#' */
|
Line 1862 split(pathtot, path,optionfile);
|
Line 1977 split(pathtot, path,optionfile);
|
tab=ivector(1,NCOVMAX);
|
tab=ivector(1,NCOVMAX);
|
ncodemax=ivector(1,8);
|
ncodemax=ivector(1,8);
|
|
|
i=1;
|
i=1;
|
while (fgets(line, MAXLINE, fic) != NULL) {
|
while (fgets(line, MAXLINE, fic) != NULL) {
|
if ((i >= firstobs) && (i <=lastobs)) {
|
if ((i >= firstobs) && (i <=lastobs)) {
|
|
|
Line 1884 split(pathtot, path,optionfile);
|
Line 1999 split(pathtot, path,optionfile);
|
cutv(stra, strb,line,' '); covar[j][i]=(double)(atoi(strb)); strcpy(line,stra);
|
cutv(stra, strb,line,' '); covar[j][i]=(double)(atoi(strb)); strcpy(line,stra);
|
}
|
}
|
num[i]=atol(stra);
|
num[i]=atol(stra);
|
|
|
/*printf("%d %.lf %.lf %.lf %.lf/%.lf %.lf/%.lf %.lf/%.lf %d %.lf/%.lf %d %.lf/%.lf %d %.lf/%.lf %d\n",num[i],(covar[1][i]), (covar[2][i]), (weight[i]), (moisnais[i]), (annais[i]), (moisdc[i]), (andc[i]), (mint[1][i]), (anint[1][i]), (s[1][i]), (mint[2][i]), (anint[2][i]), (s[2][i]), (mint[3][i]), (anint[3][i]), (s[3][i]), (mint[4][i]), (anint[4][i]), (s[4][i]));*/
|
/*if((s[2][i]==2) && (s[3][i]==-1)&&(s[4][i]==9)){
|
|
printf("%d %.lf %.lf %.lf %.lf/%.lf %.lf/%.lf %.lf/%.lf %d %.lf/%.lf %d %.lf/%.lf %d %.lf/%.lf %d\n",num[i],(covar[1][i]), (covar[2][i]),weight[i], (moisnais[i]), (annais[i]), (moisdc[i]), (andc[i]), (mint[1][i]), (anint[1][i]), (s[1][i]), (mint[2][i]), (anint[2][i]), (s[2][i]), (mint[3][i]), (anint[3][i]), (s[3][i]), (mint[4][i]), (anint[4][i]), (s[4][i])); ij=ij+1;}*/
|
|
|
i=i+1;
|
i=i+1;
|
}
|
}
|
}
|
}
|
|
/* printf("ii=%d", ij);
|
/*scanf("%d",i);*/
|
scanf("%d",i);*/
|
imx=i-1; /* Number of individuals */
|
imx=i-1; /* Number of individuals */
|
|
|
|
/* for (i=1; i<=imx; i++){
|
|
if ((s[1][i]==3) && (s[2][i]==2)) s[2][i]=3;
|
|
if ((s[2][i]==3) && (s[3][i]==2)) s[3][i]=3;
|
|
if ((s[3][i]==3) && (s[4][i]==2)) s[4][i]=3;
|
|
}
|
|
for (i=1; i<=imx; i++) printf("%d %.lf %.lf %.lf %.lf/%.lf %.lf/%.lf %.lf/%.lf %d %.lf/%.lf %d %.lf/%.lf %d %.lf/%.lf %d\n",num[i],(covar[1][i]), (covar[2][i]), (weight[i]), (moisnais[i]), (annais[i]), (moisdc[i]), (andc[i]), (mint[1][i]), (anint[1][i]), (s[1][i]), (mint[2][i]), (anint[2][i]), (s[2][i]), (mint[3][i]), (anint[3][i]), (s[3][i]), (mint[4][i]), (anint[4][i]), (s[4][i]));*/
|
|
|
/* Calculation of the number of parameter from char model*/
|
/* Calculation of the number of parameter from char model*/
|
Tvar=ivector(1,15);
|
Tvar=ivector(1,15);
|
Tprod=ivector(1,15);
|
Tprod=ivector(1,15);
|
Line 1975 split(pathtot, path,optionfile);
|
Line 2098 split(pathtot, path,optionfile);
|
}
|
}
|
/*-calculation of age at interview from date of interview and age at death -*/
|
/*-calculation of age at interview from date of interview and age at death -*/
|
agev=matrix(1,maxwav,1,imx);
|
agev=matrix(1,maxwav,1,imx);
|
|
|
|
for (i=1; i<=imx; i++)
|
|
for(m=2; (m<= maxwav); m++)
|
|
if ((mint[m][i]== 99) && (s[m][i] <= nlstate)){
|
|
anint[m][i]=9999;
|
|
s[m][i]=-1;
|
|
}
|
|
|
for (i=1; i<=imx; i++) {
|
for (i=1; i<=imx; i++) {
|
agedc[i]=(moisdc[i]/12.+andc[i])-(moisnais[i]/12.+annais[i]);
|
agedc[i]=(moisdc[i]/12.+andc[i])-(moisnais[i]/12.+annais[i]);
|
Line 2083 printf("Total number of individuals= %d,
|
Line 2213 printf("Total number of individuals= %d,
|
newms= matrix(1,nlstate+ndeath,1,nlstate+ndeath); /* creation */
|
newms= matrix(1,nlstate+ndeath,1,nlstate+ndeath); /* creation */
|
savms= matrix(1,nlstate+ndeath,1,nlstate+ndeath); /* creation */
|
savms= matrix(1,nlstate+ndeath,1,nlstate+ndeath); /* creation */
|
oldm=oldms; newm=newms; savm=savms; /* Keeps fixed addresses to free */
|
oldm=oldms; newm=newms; savm=savms; /* Keeps fixed addresses to free */
|
|
|
/* For Powell, parameters are in a vector p[] starting at p[1]
|
/* For Powell, parameters are in a vector p[] starting at p[1]
|
so we point p on param[1][1] so that p[1] maps on param[1][1][1] */
|
so we point p on param[1][1] so that p[1] maps on param[1][1][1] */
|
p=param[1][1]; /* *(*(*(param +1)+1)+0) */
|
p=param[1][1]; /* *(*(*(param +1)+1)+0) */
|
Line 2279 fprintf(ficgp,"\nset out \"v%s%d%d.gif\"
|
Line 2409 fprintf(ficgp,"\nset out \"v%s%d%d.gif\"
|
fprintf(ficgp,")) t\"prev(%d,%d)\" w l\n",cpt+1,cpt+1);
|
fprintf(ficgp,")) t\"prev(%d,%d)\" w l\n",cpt+1,cpt+1);
|
fprintf(ficgp,"set out \"p%s%d%d.gif\" \nreplot\n\n",strtok(optionfile, "."),cpt,k1);
|
fprintf(ficgp,"set out \"p%s%d%d.gif\" \nreplot\n\n",strtok(optionfile, "."),cpt,k1);
|
}
|
}
|
}
|
}
|
|
|
/* proba elementaires */
|
/* proba elementaires */
|
for(i=1,jk=1; i <=nlstate; i++){
|
for(i=1,jk=1; i <=nlstate; i++){
|
Line 2480 fclose(fichtm);
|
Line 2610 fclose(fichtm);
|
}
|
}
|
}
|
}
|
fclose(ficrespl);
|
fclose(ficrespl);
|
|
|
/*------------- h Pij x at various ages ------------*/
|
/*------------- h Pij x at various ages ------------*/
|
|
|
strcpy(filerespij,"pij"); strcat(filerespij,fileres);
|
strcpy(filerespij,"pij"); strcat(filerespij,fileres);
|
Line 2489 fclose(fichtm);
|
Line 2620 fclose(fichtm);
|
printf("Computing pij: result on file '%s' \n", filerespij);
|
printf("Computing pij: result on file '%s' \n", filerespij);
|
|
|
stepsize=(int) (stepm+YEARM-1)/YEARM;
|
stepsize=(int) (stepm+YEARM-1)/YEARM;
|
if (stepm<=24) stepsize=2;
|
/*if (stepm<=24) stepsize=2;*/
|
|
|
agelim=AGESUP;
|
agelim=AGESUP;
|
hstepm=stepsize*YEARM; /* Every year of age */
|
hstepm=stepsize*YEARM; /* Every year of age */
|
Line 2528 fclose(fichtm);
|
Line 2659 fclose(fichtm);
|
}
|
}
|
}
|
}
|
|
|
|
/* varprob(fileres, matcov, p, delti, nlstate, (int) bage, (int) fage,k);*/
|
|
|
fclose(ficrespij);
|
fclose(ficrespij);
|
|
|
|
exit(0);
|
|
/*---------- Forecasting ------------------*/
|
|
|
|
strcpy(fileresf,"f");
|
|
strcat(fileresf,fileres);
|
|
if((ficresf=fopen(fileresf,"w"))==NULL) {
|
|
printf("Problem with forecast resultfile: %s\n", fileresf);goto end;
|
|
}
|
|
printf("Computing forecasting: result on file '%s' \n", fileresf);
|
|
|
|
/* Mobile average */
|
|
|
|
/* for (agedeb=bage; agedeb<=fage; agedeb++)
|
|
for (i=1; i<=nlstate;i++)
|
|
for (cptcod=1;cptcod<=ncodemax[cptcoveff];cptcod++)
|
|
printf("%f %d i=%d j1=%d\n", probs[(int)agedeb][i][cptcod],(int) agedeb,i,cptcod);*/
|
|
|
|
if (cptcoveff==0) ncodemax[cptcoveff]=1;
|
|
|
|
mobaverage= ma3x(1,130 ,1,8, 1,8);
|
|
for (agedeb=bage+3; agedeb<=fage-2; agedeb++)
|
|
for (i=1; i<=nlstate;i++)
|
|
for (cptcod=1;cptcod<=ncodemax[cptcov];cptcod++)
|
|
mobaverage[(int)agedeb][i][cptcod]=0.;
|
|
|
|
for (agedeb=bage+4; agedeb<=fage; agedeb++){
|
|
for (i=1; i<=nlstate;i++){
|
|
for (cptcod=1;cptcod<=ncodemax[cptcoveff];cptcod++){
|
|
for (cpt=0;cpt<=4;cpt++){
|
|
mobaverage[(int)agedeb-2][i][cptcod]=mobaverage[(int)agedeb-2][i][cptcod]+probs[(int)agedeb-cpt][i][cptcod];
|
|
}
|
|
mobaverage[(int)agedeb-2][i][cptcod]=mobaverage[(int)agedeb-2][i][cptcod]/5;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* if (cptcod==2) printf("m=%f p=%f %d age=%d ",mobaverage[(int)agedeb-2][i][cptcod],probs[(int)agedeb-cpt][i][cptcod],cpt,(int)agedeb-2);*/
|
|
|
|
|
|
stepsize=(int) (stepm+YEARM-1)/YEARM;
|
|
if (stepm<=24) stepsize=2;
|
|
|
|
agelim=AGESUP;
|
|
hstepm=stepsize*YEARM; /* Every year of age */
|
|
hstepm=hstepm/stepm; /* Typically 2 years, = 2/6 months = 4 */
|
|
hstepm=12;
|
|
k=0;
|
|
for(cptcov=1;cptcov<=i1;cptcov++){
|
|
for(cptcod=1;cptcod<=ncodemax[cptcoveff];cptcod++){
|
|
k=k+1;
|
|
fprintf(ficresf,"\n#****** ");
|
|
for(j=1;j<=cptcoveff;j++) {
|
|
fprintf(ficresf,"V%d=%d ",Tvaraff[j],nbcode[Tvaraff[j]][codtab[k][j]]);
|
|
}
|
|
|
|
fprintf(ficresf,"******\n");
|
|
|
|
fprintf(ficresf,"# StartingAge FinalAge Horizon(in years)");
|
|
for(j=1; j<=nlstate+ndeath;j++) fprintf(ficresf," P.%d",j);
|
|
|
|
for (agedeb=fage; agedeb>=bage; agedeb--){
|
|
fprintf(ficresf,"\n%d %.f %.f 0 ",k,agedeb, agedeb);
|
|
for(j=1; j<=nlstate;j++)
|
|
fprintf(ficresf,"%.3f ",mobaverage[(int)agedeb][j][cptcod]);
|
|
}
|
|
for(j=1; j<=ndeath;j++) fprintf(ficresf,"0.");
|
|
|
|
for (cpt=1; cpt<=8;cpt++)
|
|
for (agedeb=fage; agedeb>=bage; agedeb--){ /* If stepm=6 months */
|
|
|
|
nhstepm=(int) rint((agelim-agedeb)*YEARM/stepm); /* Typically 20 years = 20*12/6=40 */
|
|
nhstepm = nhstepm/hstepm; /* Typically 40/4=10 */
|
|
/*printf("stepm=%d hstepm=%d nhstepm=%d \n",stepm,hstepm,nhstepm);*/
|
|
|
|
p3mat=ma3x(1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm);
|
|
oldm=oldms;savm=savms;
|
|
hpxij(p3mat,nhstepm,agedeb,hstepm,p,nlstate,stepm,oldm,savm, k);
|
|
|
|
for (h=0; h<=nhstepm; h++){
|
|
|
|
if (h*hstepm/YEARM*stepm==cpt)
|
|
fprintf(ficresf,"\n%d %.f %.f %.f",k,agedeb, agedeb+ h*hstepm/YEARM*stepm, h*hstepm/YEARM*stepm);
|
|
|
|
for(j=1; j<=nlstate+ndeath;j++) {
|
|
kk1=0.;
|
|
for(i=1; i<=nlstate;i++) {
|
|
/* kk1=kk1+p3mat[i][j][h]*probs[(int)agedeb][i][cptcod];*/
|
|
kk1=kk1+p3mat[i][j][h]*mobaverage[(int)agedeb][i][cptcod];
|
|
}
|
|
|
|
if (h*hstepm/YEARM*stepm==cpt)
|
|
fprintf(ficresf," %.5f ", kk1);
|
|
}
|
|
}
|
|
free_ma3x(p3mat,1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm);
|
|
}
|
|
}
|
|
}
|
|
fclose(ficresf);
|
|
|
/*---------- Health expectancies and variances ------------*/
|
/*---------- Health expectancies and variances ------------*/
|
|
|
strcpy(filerest,"t");
|
strcpy(filerest,"t");
|
Line 2608 fclose(fichtm);
|
Line 2841 fclose(fichtm);
|
}
|
}
|
}
|
}
|
|
|
|
|
|
|
|
|
fclose(ficreseij);
|
fclose(ficreseij);
|
fclose(ficresvij);
|
fclose(ficresvij);
|
fclose(ficrest);
|
fclose(ficrest);
|
Line 2653 strcpy(fileresvpl,"vpl");
|
Line 2889 strcpy(fileresvpl,"vpl");
|
free_matrix(oldms, 1,nlstate+ndeath,1,nlstate+ndeath);
|
free_matrix(oldms, 1,nlstate+ndeath,1,nlstate+ndeath);
|
free_matrix(newms, 1,nlstate+ndeath,1,nlstate+ndeath);
|
free_matrix(newms, 1,nlstate+ndeath,1,nlstate+ndeath);
|
free_matrix(savms, 1,nlstate+ndeath,1,nlstate+ndeath);
|
free_matrix(savms, 1,nlstate+ndeath,1,nlstate+ndeath);
|
|
|
free_matrix(matcov,1,npar,1,npar);
|
free_matrix(matcov,1,npar,1,npar);
|
free_vector(delti,1,npar);
|
free_vector(delti,1,npar);
|
|
|
Line 2666 strcpy(fileresvpl,"vpl");
|
Line 2902 strcpy(fileresvpl,"vpl");
|
/*printf("Total time was %d uSec.\n", total_usecs);*/
|
/*printf("Total time was %d uSec.\n", total_usecs);*/
|
/*------ End -----------*/
|
/*------ End -----------*/
|
|
|
|
|
end:
|
end:
|
#ifdef windows
|
#ifdef windows
|
chdir(pathcd);
|
chdir(pathcd);
|
#endif
|
#endif
|
/*system("wgnuplot graph.plt");*/
|
|
system("../gp37mgw/wgnuplot graph.plt");
|
system("..\\gp37mgw\\wgnuplot graph.plt");
|
|
|
#ifdef windows
|
#ifdef windows
|
while (z[0] != 'q') {
|
while (z[0] != 'q') {
|