|
|
| 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') { |