| version 1.114, 2006/02/26 12:57:58 | version 1.127, 2006/04/28 18:11:50 | 
| Line 1 | Line 1 | 
 | /* $Id$ | /* $Id$ | 
 | $State$ | $State$ | 
 | $Log$ | $Log$ | 
 |  | Revision 1.127  2006/04/28 18:11:50  brouard | 
 |  | (Module): Yes the sum of survivors was wrong since | 
 |  | imach-114 because nhstepm was no more computed in the age | 
 |  | loop. Now we define nhstepma in the age loop. | 
 |  | (Module): In order to speed up (in case of numerous covariates) we | 
 |  | compute health expectancies (without variances) in a first step | 
 |  | and then all the health expectancies with variances or standard | 
 |  | deviation (needs data from the Hessian matrices) which slows the | 
 |  | computation. | 
 |  | In the future we should be able to stop the program is only health | 
 |  | expectancies and graph are needed without standard deviations. | 
 |  |  | 
 |  | Revision 1.126  2006/04/28 17:23:28  brouard | 
 |  | (Module): Yes the sum of survivors was wrong since | 
 |  | imach-114 because nhstepm was no more computed in the age | 
 |  | loop. Now we define nhstepma in the age loop. | 
 |  | Version 0.98h | 
 |  |  | 
 |  | Revision 1.125  2006/04/04 15:20:31  lievre | 
 |  | Errors in calculation of health expectancies. Age was not initialized. | 
 |  | Forecasting file added. | 
 |  |  | 
 |  | Revision 1.124  2006/03/22 17:13:53  lievre | 
 |  | Parameters are printed with %lf instead of %f (more numbers after the comma). | 
 |  | The log-likelihood is printed in the log file | 
 |  |  | 
 |  | Revision 1.123  2006/03/20 10:52:43  brouard | 
 |  | * imach.c (Module): <title> changed, corresponds to .htm file | 
 |  | name. <head> headers where missing. | 
 |  |  | 
 |  | * imach.c (Module): Weights can have a decimal point as for | 
 |  | English (a comma might work with a correct LC_NUMERIC environment, | 
 |  | otherwise the weight is truncated). | 
 |  | Modification of warning when the covariates values are not 0 or | 
 |  | 1. | 
 |  | Version 0.98g | 
 |  |  | 
 |  | Revision 1.122  2006/03/20 09:45:41  brouard | 
 |  | (Module): Weights can have a decimal point as for | 
 |  | English (a comma might work with a correct LC_NUMERIC environment, | 
 |  | otherwise the weight is truncated). | 
 |  | Modification of warning when the covariates values are not 0 or | 
 |  | 1. | 
 |  | Version 0.98g | 
 |  |  | 
 |  | Revision 1.121  2006/03/16 17:45:01  lievre | 
 |  | * imach.c (Module): Comments concerning covariates added | 
 |  |  | 
 |  | * imach.c (Module): refinements in the computation of lli if | 
 |  | status=-2 in order to have more reliable computation if stepm is | 
 |  | not 1 month. Version 0.98f | 
 |  |  | 
 |  | Revision 1.120  2006/03/16 15:10:38  lievre | 
 |  | (Module): refinements in the computation of lli if | 
 |  | status=-2 in order to have more reliable computation if stepm is | 
 |  | not 1 month. Version 0.98f | 
 |  |  | 
 |  | Revision 1.119  2006/03/15 17:42:26  brouard | 
 |  | (Module): Bug if status = -2, the loglikelihood was | 
 |  | computed as likelihood omitting the logarithm. Version O.98e | 
 |  |  | 
 |  | Revision 1.118  2006/03/14 18:20:07  brouard | 
 |  | (Module): varevsij Comments added explaining the second | 
 |  | table of variances if popbased=1 . | 
 |  | (Module): Covariances of eij, ekl added, graphs fixed, new html link. | 
 |  | (Module): Function pstamp added | 
 |  | (Module): Version 0.98d | 
 |  |  | 
 |  | Revision 1.117  2006/03/14 17:16:22  brouard | 
 |  | (Module): varevsij Comments added explaining the second | 
 |  | table of variances if popbased=1 . | 
 |  | (Module): Covariances of eij, ekl added, graphs fixed, new html link. | 
 |  | (Module): Function pstamp added | 
 |  | (Module): Version 0.98d | 
 |  |  | 
 |  | Revision 1.116  2006/03/06 10:29:27  brouard | 
 |  | (Module): Variance-covariance wrong links and | 
 |  | varian-covariance of ej. is needed (Saito). | 
 |  |  | 
 |  | Revision 1.115  2006/02/27 12:17:45  brouard | 
 |  | (Module): One freematrix added in mlikeli! 0.98c | 
 |  |  | 
 | Revision 1.114  2006/02/26 12:57:58  brouard | Revision 1.114  2006/02/26 12:57:58  brouard | 
 | (Module): Some improvements in processing parameter | (Module): Some improvements in processing parameter | 
 | filename with strsep. | filename with strsep. | 
| Line 203 | Line 285 | 
 | hPijx. | hPijx. | 
 |  |  | 
 | Also this programme outputs the covariance matrix of the parameters but also | Also this programme outputs the covariance matrix of the parameters but also | 
| of the life expectancies. It also computes the stable prevalence. | of the life expectancies. It also computes the period (stable) prevalence. | 
 |  |  | 
 | Authors: Nicolas Brouard (brouard@ined.fr) and Agnès Lièvre (lievre@ined.fr). | Authors: Nicolas Brouard (brouard@ined.fr) and Agnès Lièvre (lievre@ined.fr). | 
 | Institut national d'études démographiques, Paris. | Institut national d'études démographiques, Paris. | 
| Line 232 | Line 314 | 
 | begin-prev-date,... | begin-prev-date,... | 
 | open gnuplot file | open gnuplot file | 
 | open html file | open html file | 
| stable prevalence | period (stable) prevalence | 
 | for age prevalim() | for age prevalim() | 
 | h Pij x | h Pij x | 
 | variance of p varprob | variance of p varprob | 
| Line 244 | Line 326 | 
 | varevsij() | varevsij() | 
 | if popbased==1 varevsij(,popbased) | if popbased==1 varevsij(,popbased) | 
 | total life expectancies | total life expectancies | 
| Variance of stable prevalence | Variance of period (stable) prevalence | 
 | end | end | 
 | */ | */ | 
 |  |  | 
| Line 304  extern int errno; | Line 386  extern int errno; | 
 | /* $Id$ */ | /* $Id$ */ | 
 | /* $State$ */ | /* $State$ */ | 
 |  |  | 
| char version[]="Imach version 0.98b, January 2006, INED-EUROREVES "; | char version[]="Imach version 0.98h, April 2006, INED-EUROREVES-Institut de longevite "; | 
 | char fullversion[]="$Revision$ $Date$"; | char fullversion[]="$Revision$ $Date$"; | 
 |  | char strstart[80]; | 
 |  | char optionfilext[10], optionfilefiname[FILENAMELENGTH]; | 
 | int erreur, nberr=0, nbwarn=0; /* Error number, number of errors number of warnings  */ | int erreur, nberr=0, nbwarn=0; /* Error number, number of errors number of warnings  */ | 
 | int nvar; | int nvar; | 
 | int cptcovn=0, cptcovage=0, cptcoveff=0,cptcov; | int cptcovn=0, cptcovage=0, cptcoveff=0,cptcov; | 
| Line 329  int **bh; /* bh[mi][i] is the bias (+ or | Line 413  int **bh; /* bh[mi][i] is the bias (+ or | 
 | 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,*ficresf,*ficrespop; | FILE *fic,*ficpar, *ficparo,*ficres, *ficresp, *ficrespl, *ficrespij, *ficrest,*ficresf,*ficrespop; | 
 | FILE *ficlog, *ficrespow; | FILE *ficlog, *ficrespow; | 
 | int globpr; /* Global variable for printing or not */ | int globpr; /* Global variable for printing or not */ | 
 | double fretone; /* Only one call to likelihood */ | double fretone; /* Only one call to likelihood */ | 
| Line 343  FILE *ficresprobmorprev; | Line 427  FILE *ficresprobmorprev; | 
 | FILE *fichtm, *fichtmcov; /* Html File */ | FILE *fichtm, *fichtmcov; /* Html File */ | 
 | FILE *ficreseij; | FILE *ficreseij; | 
 | char filerese[FILENAMELENGTH]; | char filerese[FILENAMELENGTH]; | 
 |  | FILE *ficresstdeij; | 
 |  | char fileresstde[FILENAMELENGTH]; | 
 |  | FILE *ficrescveij; | 
 |  | char filerescve[FILENAMELENGTH]; | 
 | FILE  *ficresvij; | FILE  *ficresvij; | 
 | char fileresv[FILENAMELENGTH]; | char fileresv[FILENAMELENGTH]; | 
 | FILE  *ficresvpl; | FILE  *ficresvpl; | 
 | char fileresvpl[FILENAMELENGTH]; | char fileresvpl[FILENAMELENGTH]; | 
 | char title[MAXLINE]; | char title[MAXLINE]; | 
 | char optionfile[FILENAMELENGTH], datafile[FILENAMELENGTH],  filerespl[FILENAMELENGTH]; | char optionfile[FILENAMELENGTH], datafile[FILENAMELENGTH],  filerespl[FILENAMELENGTH]; | 
| char optionfilext[10], optionfilefiname[FILENAMELENGTH], plotcmd[FILENAMELENGTH], pplotcmd[FILENAMELENGTH]; | char plotcmd[FILENAMELENGTH], pplotcmd[FILENAMELENGTH]; | 
 | char tmpout[FILENAMELENGTH],  tmpout2[FILENAMELENGTH]; | char tmpout[FILENAMELENGTH],  tmpout2[FILENAMELENGTH]; | 
 | char command[FILENAMELENGTH]; | char command[FILENAMELENGTH]; | 
 | int  outcmd=0; | int  outcmd=0; | 
| Line 373  char strcurr[80], strfor[80]; | Line 461  char strcurr[80], strfor[80]; | 
 |  |  | 
 | char *endptr; | char *endptr; | 
 | long lval; | long lval; | 
 |  | double dval; | 
 |  |  | 
 | #define NR_END 1 | #define NR_END 1 | 
 | #define FREE_ARG char* | #define FREE_ARG char* | 
| Line 938  void powell(double p[], double **xi, int | Line 1027  void powell(double p[], double **xi, int | 
 | last_time=curr_time; | last_time=curr_time; | 
 | (void) gettimeofday(&curr_time,&tzp); | (void) gettimeofday(&curr_time,&tzp); | 
 | printf("\nPowell iter=%d -2*LL=%.12f %ld sec. %ld sec.",*iter,*fret, curr_time.tv_sec-last_time.tv_sec, curr_time.tv_sec-start_time.tv_sec);fflush(stdout); | printf("\nPowell iter=%d -2*LL=%.12f %ld sec. %ld sec.",*iter,*fret, curr_time.tv_sec-last_time.tv_sec, curr_time.tv_sec-start_time.tv_sec);fflush(stdout); | 
| /*    fprintf(ficlog,"\nPowell iter=%d -2*LL=%.12f %ld sec. %ld sec.",*iter,*fret, curr_time.tv_sec-last_time.tv_sec, curr_time.tv_sec-start_time.tv_sec); | fprintf(ficlog,"\nPowell iter=%d -2*LL=%.12f %ld sec. %ld sec.",*iter,*fret, curr_time.tv_sec-last_time.tv_sec, curr_time.tv_sec-start_time.tv_sec); fflush(ficlog); | 
| fprintf(ficrespow,"%d %.12f %ld",*iter,*fret,curr_time.tv_sec-start_time.tv_sec); | /*     fprintf(ficrespow,"%d %.12f %ld",*iter,*fret,curr_time.tv_sec-start_time.tv_sec); */ | 
| */ |  | 
 | for (i=1;i<=n;i++) { | for (i=1;i<=n;i++) { | 
 | printf(" %d %.12f",i, p[i]); | printf(" %d %.12f",i, p[i]); | 
 | fprintf(ficlog," %d %.12lf",i, p[i]); | fprintf(ficlog," %d %.12lf",i, p[i]); | 
| Line 1062  void powell(double p[], double **xi, int | Line 1150  void powell(double p[], double **xi, int | 
 | } | } | 
 | } | } | 
 |  |  | 
| /**** Prevalence limit (stable prevalence)  ****************/ | /**** Prevalence limit (stable or period prevalence)  ****************/ | 
 |  |  | 
 | double **prevalim(double **prlim, int nlstate, double x[], double age, double **oldm, double **savm, double ftolpl, int ij) | double **prevalim(double **prlim, int nlstate, double x[], double age, double **oldm, double **savm, double ftolpl, int ij) | 
 | { | { | 
| Line 1355  double func( double *x) | Line 1443  double func( double *x) | 
 |  |  | 
 | } else if  (s2==-2) { | } else if  (s2==-2) { | 
 | for (j=1,survp=0. ; j<=nlstate; j++) | for (j=1,survp=0. ; j<=nlstate; j++) | 
| survp += out[s1][j]; | survp += (1.+bbh)*out[s1][j]- bbh*savm[s1][j]; | 
| lli= survp; | /*survp += out[s1][j]; */ | 
|  | lli= log(survp); | 
 | } | } | 
 |  |  | 
| else if  (s2==-4) { | else if  (s2==-4) { | 
| for (j=3,survp=0. ; j<=nlstate; j++) | for (j=3,survp=0. ; j<=nlstate; j++) | 
| survp += out[s1][j]; | survp += (1.+bbh)*out[s1][j]- bbh*savm[s1][j]; | 
| lli= survp; | lli= log(survp); | 
| } | } | 
|  |  | 
| else if  (s2==-5) { |  | 
| for (j=1,survp=0. ; j<=2; j++) |  | 
| survp += out[s1][j]; |  | 
| lli= survp; |  | 
| } |  | 
|  |  | 
 |  |  | 
 |  | else if  (s2==-5) { | 
 |  | for (j=1,survp=0. ; j<=2; j++) | 
 |  | survp += (1.+bbh)*out[s1][j]- bbh*savm[s1][j]; | 
 |  | lli= log(survp); | 
 |  | } | 
 |  |  | 
 | else{ | else{ | 
 | lli= log((1.+bbh)*out[s1][s2]- bbh*savm[s1][s2]); /* linear interpolation */ | lli= log((1.+bbh)*out[s1][s2]- bbh*savm[s1][s2]); /* linear interpolation */ | 
 | /*  lli= (savm[s1][s2]>(double)1.e-8 ?log((1.+bbh)*out[s1][s2]- bbh*(savm[s1][s2])):log((1.+bbh)*out[s1][s2]));*/ /* linear interpolation */ | /*  lli= (savm[s1][s2]>(double)1.e-8 ?log((1.+bbh)*out[s1][s2]- bbh*(savm[s1][s2])):log((1.+bbh)*out[s1][s2]));*/ /* linear interpolation */ | 
| Line 1566  double funcone( double *x) | Line 1654  double funcone( double *x) | 
 | */ | */ | 
 | if( s2 > nlstate && (mle <5) ){  /* Jackson */ | if( s2 > nlstate && (mle <5) ){  /* Jackson */ | 
 | lli=log(out[s1][s2] - savm[s1][s2]); | lli=log(out[s1][s2] - savm[s1][s2]); | 
| } else if (mle==1){ | } else if  (s2==-2) { | 
|  | for (j=1,survp=0. ; j<=nlstate; j++) | 
|  | survp += (1.+bbh)*out[s1][j]- bbh*savm[s1][j]; | 
|  | lli= log(survp); | 
|  | }else if (mle==1){ | 
 | lli= log((1.+bbh)*out[s1][s2]- bbh*savm[s1][s2]); /* linear interpolation */ | lli= log((1.+bbh)*out[s1][s2]- bbh*savm[s1][s2]); /* linear interpolation */ | 
 | } else if(mle==2){ | } else if(mle==2){ | 
 | lli= (savm[s1][s2]>(double)1.e-8 ?log((1.+bbh)*out[s1][s2]- bbh*savm[s1][s2]):log((1.+bbh)*out[s1][s2])); /* linear interpolation */ | lli= (savm[s1][s2]>(double)1.e-8 ?log((1.+bbh)*out[s1][s2]- bbh*savm[s1][s2]):log((1.+bbh)*out[s1][s2])); /* linear interpolation */ | 
| Line 1582  double funcone( double *x) | Line 1674  double funcone( double *x) | 
 | ll[s[mw[mi][i]][i]] += 2*weight[i]*lli; | ll[s[mw[mi][i]][i]] += 2*weight[i]*lli; | 
 | /*       printf("i=%6d s1=%1d s2=%1d mi=%1d mw=%1d dh=%3d prob=%10.6f w=%6.4f out=%10.6f sav=%10.6f\n",i,s1,s2,mi,mw[mi][i],dh[mi][i],exp(lli),weight[i],out[s1][s2],savm[s1][s2]); */ | /*       printf("i=%6d s1=%1d s2=%1d mi=%1d mw=%1d dh=%3d prob=%10.6f w=%6.4f out=%10.6f sav=%10.6f\n",i,s1,s2,mi,mw[mi][i],dh[mi][i],exp(lli),weight[i],out[s1][s2],savm[s1][s2]); */ | 
 | if(globpr){ | if(globpr){ | 
| fprintf(ficresilk,"%9d %6d %1d %1d %1d %1d %3d %10.6f %6.4f\ | fprintf(ficresilk,"%9d %6d %2d %2d %1d %1d %3d %11.6f %8.4f\ | 
| %10.6f %10.6f %10.6f ", \ | %11.6f %11.6f %11.6f ", \ | 
 | num[i],i,s1,s2,mi,mw[mi][i],dh[mi][i],exp(lli),weight[i], | num[i],i,s1,s2,mi,mw[mi][i],dh[mi][i],exp(lli),weight[i], | 
 | 2*weight[i]*lli,out[s1][s2],savm[s1][s2]); | 2*weight[i]*lli,out[s1][s2],savm[s1][s2]); | 
 | for(k=1,llt=0.,l=0.; k<=nlstate; k++){ | for(k=1,llt=0.,l=0.; k<=nlstate; k++){ | 
| Line 1668  void mlikeli(FILE *ficres,double p[], in | Line 1760  void mlikeli(FILE *ficres,double p[], in | 
 |  |  | 
 | powell(p,xi,npar,ftol,&iter,&fret,func); | powell(p,xi,npar,ftol,&iter,&fret,func); | 
 |  |  | 
 |  | free_matrix(xi,1,npar,1,npar); | 
 | fclose(ficrespow); | fclose(ficrespow); | 
 | printf("\n#Number of iterations = %d, -2 Log likelihood = %.12f\n",iter,func(p)); | printf("\n#Number of iterations = %d, -2 Log likelihood = %.12f\n",iter,func(p)); | 
 | fprintf(ficlog,"\n#Number of iterations = %d, -2 Log likelihood = %.12f \n",iter,func(p)); | fprintf(ficlog,"\n#Number of iterations = %d, -2 Log likelihood = %.12f \n",iter,func(p)); | 
| Line 1935  void lubksb(double **a, int n, int *indx | Line 2028  void lubksb(double **a, int n, int *indx | 
 | } | } | 
 | } | } | 
 |  |  | 
 |  | void pstamp(FILE *fichier) | 
 |  | { | 
 |  | fprintf(fichier,"# %s.%s\n#%s\n#%s\n# %s", optionfilefiname,optionfilext,version,fullversion,strstart); | 
 |  | } | 
 |  |  | 
 | /************ Frequencies ********************/ | /************ Frequencies ********************/ | 
 | void  freqsummary(char fileres[], int iagemin, int iagemax, int **s, double **agev, int nlstate, int imx, int *Tvaraff, int **nbcode, int *ncodemax,double **mint,double **anint, char strstart[]) | void  freqsummary(char fileres[], int iagemin, int iagemax, int **s, double **agev, int nlstate, int imx, int *Tvaraff, int **nbcode, int *ncodemax,double **mint,double **anint, char strstart[]) | 
 | {  /* Some frequencies */ | {  /* Some frequencies */ | 
| Line 1944  void  freqsummary(char fileres[], int ia | Line 2042  void  freqsummary(char fileres[], int ia | 
 | double ***freq; /* Frequencies */ | double ***freq; /* Frequencies */ | 
 | double *pp, **prop; | double *pp, **prop; | 
 | double pos,posprop, k2, dateintsum=0,k2cpt=0; | double pos,posprop, k2, dateintsum=0,k2cpt=0; | 
 | FILE *ficresp; |  | 
 | char fileresp[FILENAMELENGTH]; | char fileresp[FILENAMELENGTH]; | 
 |  |  | 
 | pp=vector(1,nlstate); | pp=vector(1,nlstate); | 
| Line 2009  void  freqsummary(char fileres[], int ia | Line 2106  void  freqsummary(char fileres[], int ia | 
 | } | } | 
 |  |  | 
 | /*      fprintf(ficresp, "#Count between %.lf/%.lf/%.lf and %.lf/%.lf/%.lf\n",jprev1, mprev1,anprev1,jprev2, mprev2,anprev2);*/ | /*      fprintf(ficresp, "#Count between %.lf/%.lf/%.lf and %.lf/%.lf/%.lf\n",jprev1, mprev1,anprev1,jprev2, mprev2,anprev2);*/ | 
| fprintf(ficresp, "#Local time at start: %s", strstart); | pstamp(ficresp); | 
 | if  (cptcovn>0) { | if  (cptcovn>0) { | 
 | fprintf(ficresp, "\n#********** Variable "); | fprintf(ficresp, "\n#********** Variable "); | 
 | for (z1=1; z1<=cptcoveff; z1++) fprintf(ficresp, "V%d=%d ",Tvaraff[z1],nbcode[Tvaraff[z1]][codtab[j1][z1]]); | for (z1=1; z1<=cptcoveff; z1++) fprintf(ficresp, "V%d=%d ",Tvaraff[z1],nbcode[Tvaraff[z1]][codtab[j1][z1]]); | 
| Line 2382  void tricode(int *Tvar, int **nbcode, in | Line 2479  void tricode(int *Tvar, int **nbcode, in | 
 |  |  | 
 | /*********** Health Expectancies ****************/ | /*********** Health Expectancies ****************/ | 
 |  |  | 
| void evsij(char fileres[], double ***eij, double x[], int nlstate, int stepm, int bage, int fage, double **oldm, double **savm, int ij, int estepm,double delti[],double **matcov,char strstart[] ) | void evsij(double ***eij, double x[], int nlstate, int stepm, int bage, int fage, double **oldm, double **savm, int cij, int estepm,char strstart[] ) | 
|  |  | 
|  | { | 
|  | /* Health expectancies, no variances */ | 
|  | int i, j, nhstepm, hstepm, h, nstepm, k, cptj, cptj2, i2, j2; | 
|  | int nhstepma, nstepma; /* Decreasing with age */ | 
|  | double age, agelim, hf; | 
|  | double ***p3mat; | 
|  | double eip; | 
|  |  | 
|  | pstamp(ficreseij); | 
|  | fprintf(ficreseij,"# (a) Life expectancies by health status at initial age and (b) health expectancies by health status at initial age\n"); | 
|  | fprintf(ficreseij,"# Age"); | 
|  | for(i=1; i<=nlstate;i++){ | 
|  | for(j=1; j<=nlstate;j++){ | 
|  | fprintf(ficreseij," e%1d%1d ",i,j); | 
|  | } | 
|  | fprintf(ficreseij," e%1d. ",i); | 
|  | } | 
|  | fprintf(ficreseij,"\n"); | 
|  |  | 
|  |  | 
|  | if(estepm < stepm){ | 
|  | printf ("Problem %d lower than %d\n",estepm, stepm); | 
|  | } | 
|  | else  hstepm=estepm; | 
|  | /* We compute the life expectancy from trapezoids spaced every estepm months | 
|  | * This is mainly to measure the difference between two models: for example | 
|  | * if stepm=24 months pijx are given only every 2 years and by summing them | 
|  | * we are calculating an estimate of the Life Expectancy assuming a linear | 
|  | * progression in between and thus overestimating or underestimating according | 
|  | * to the curvature of the survival function. If, for the same date, we | 
|  | * estimate the model with stepm=1 month, we can keep estepm to 24 months | 
|  | * to compare the new estimate of Life expectancy with the same linear | 
|  | * hypothesis. A more precise result, taking into account a more precise | 
|  | * curvature will be obtained if estepm is as small as stepm. */ | 
|  |  | 
|  | /* For example we decided to compute the life expectancy with the smallest unit */ | 
|  | /* hstepm beeing the number of stepms, if hstepm=1 the length of hstepm is stepm. | 
|  | nhstepm is the number of hstepm from age to agelim | 
|  | nstepm is the number of stepm from age to agelin. | 
|  | Look at hpijx to understand the reason of that which relies in memory size | 
|  | and note for a fixed period like estepm months */ | 
|  | /* We decided (b) to get a life expectancy respecting the most precise curvature of the | 
|  | survival function given by stepm (the optimization length). Unfortunately it | 
|  | means that if the survival funtion is printed only each two years of age and if | 
|  | you sum them up and add 1 year (area under the trapezoids) you won't get the same | 
|  | results. So we changed our mind and took the option of the best precision. | 
|  | */ | 
|  | hstepm=hstepm/stepm; /* Typically in stepm units, if stepm=6 & estepm=24 , = 24/6 months = 4 */ | 
|  |  | 
|  | agelim=AGESUP; | 
|  | /* If stepm=6 months */ | 
|  | /* Computed by stepm unit matrices, product of hstepm matrices, stored | 
|  | in an array of nhstepm length: nhstepm=10, hstepm=4, stepm=6 months */ | 
|  |  | 
|  | /* nhstepm age range expressed in number of stepm */ | 
|  | nstepm=(int) rint((agelim-bage)*YEARM/stepm); /* Biggest nstepm */ | 
|  | /* Typically if 20 years nstepm = 20*12/6=40 stepm */ | 
|  | /* if (stepm >= YEARM) hstepm=1;*/ | 
|  | nhstepm = nstepm/hstepm;/* Expressed in hstepm, typically nhstepm=40/4=10 */ | 
|  | p3mat=ma3x(1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm); | 
|  |  | 
|  | for (age=bage; age<=fage; age ++){ | 
|  | nstepma=(int) rint((agelim-bage)*YEARM/stepm); /* Biggest nstepm */ | 
|  | /* Typically if 20 years nstepm = 20*12/6=40 stepm */ | 
|  | /* if (stepm >= YEARM) hstepm=1;*/ | 
|  | nhstepma = nstepma/hstepm;/* Expressed in hstepm, typically nhstepma=40/4=10 */ | 
|  |  | 
|  | /* If stepm=6 months */ | 
|  | /* Computed by stepm unit matrices, product of hstepma matrices, stored | 
|  | in an array of nhstepma length: nhstepma=10, hstepm=4, stepm=6 months */ | 
|  |  | 
|  | hpxij(p3mat,nhstepma,age,hstepm,x,nlstate,stepm,oldm, savm, cij); | 
|  |  | 
|  | hf=hstepm*stepm/YEARM;  /* Duration of hstepm expressed in year unit. */ | 
|  |  | 
|  | printf("%d|",(int)age);fflush(stdout); | 
|  | fprintf(ficlog,"%d|",(int)age);fflush(ficlog); | 
|  |  | 
|  | /* Computing expectancies */ | 
|  | for(i=1; i<=nlstate;i++) | 
|  | for(j=1; j<=nlstate;j++) | 
|  | for (h=0, eij[i][j][(int)age]=0; h<=nhstepm-1; h++){ | 
|  | eij[i][j][(int)age] += (p3mat[i][j][h]+p3mat[i][j][h+1])/2.0*hf; | 
|  |  | 
|  | /* if((int)age==70)printf("i=%2d,j=%2d,h=%2d,age=%3d,%9.4f,%9.4f,%9.4f\n",i,j,h,(int)age,p3mat[i][j][h],hf,eij[i][j][(int)age]);*/ | 
|  |  | 
|  | } | 
|  |  | 
|  | fprintf(ficreseij,"%3.0f",age ); | 
|  | for(i=1; i<=nlstate;i++){ | 
|  | eip=0; | 
|  | for(j=1; j<=nlstate;j++){ | 
|  | eip +=eij[i][j][(int)age]; | 
|  | fprintf(ficreseij,"%9.4f", eij[i][j][(int)age] ); | 
|  | } | 
|  | fprintf(ficreseij,"%9.4f", eip ); | 
|  | } | 
|  | fprintf(ficreseij,"\n"); | 
|  |  | 
|  | } | 
|  | free_ma3x(p3mat,1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm); | 
|  | printf("\n"); | 
|  | fprintf(ficlog,"\n"); | 
|  |  | 
|  | } | 
|  |  | 
|  | void cvevsij(double ***eij, double x[], int nlstate, int stepm, int bage, int fage, double **oldm, double **savm, int cij, int estepm,double delti[],double **matcov,char strstart[] ) | 
 |  |  | 
 | { | { | 
| /* Health expectancies */ | /* Covariances of health expectancies eij and of total life expectancies according | 
| int i, j, nhstepm, hstepm, h, nstepm, k, cptj; | to initial status i, ei. . | 
|  | */ | 
|  | int i, j, nhstepm, hstepm, h, nstepm, k, cptj, cptj2, i2, j2, ij, ji; | 
|  | int nhstepma, nstepma; /* Decreasing with age */ | 
 | double age, agelim, hf; | double age, agelim, hf; | 
| double ***p3mat,***varhe; | double ***p3matp, ***p3matm, ***varhe; | 
 | double **dnewm,**doldm; | double **dnewm,**doldm; | 
| double *xp; | double *xp, *xm; | 
 | double **gp, **gm; | double **gp, **gm; | 
 | double ***gradg, ***trgradg; | double ***gradg, ***trgradg; | 
 | int theta; | int theta; | 
 |  |  | 
 |  | double eip, vip; | 
 |  |  | 
 | varhe=ma3x(1,nlstate*nlstate,1,nlstate*nlstate,(int) bage, (int) fage); | varhe=ma3x(1,nlstate*nlstate,1,nlstate*nlstate,(int) bage, (int) fage); | 
 | xp=vector(1,npar); | xp=vector(1,npar); | 
 |  | xm=vector(1,npar); | 
 | dnewm=matrix(1,nlstate*nlstate,1,npar); | dnewm=matrix(1,nlstate*nlstate,1,npar); | 
 | doldm=matrix(1,nlstate*nlstate,1,nlstate*nlstate); | doldm=matrix(1,nlstate*nlstate,1,nlstate*nlstate); | 
 |  |  | 
| fprintf(ficreseij,"# Local time at start: %s", strstart); | pstamp(ficresstdeij); | 
| fprintf(ficreseij,"# Health expectancies\n"); | fprintf(ficresstdeij,"# Health expectancies with standard errors\n"); | 
| fprintf(ficreseij,"# Age"); | fprintf(ficresstdeij,"# Age"); | 
| for(i=1; i<=nlstate;i++) | for(i=1; i<=nlstate;i++){ | 
 | for(j=1; j<=nlstate;j++) | for(j=1; j<=nlstate;j++) | 
| fprintf(ficreseij," %1d-%1d (SE)",i,j); | fprintf(ficresstdeij," e%1d%1d (SE)",i,j); | 
| fprintf(ficreseij,"\n"); | fprintf(ficresstdeij," e%1d. ",i); | 
|  | } | 
|  | fprintf(ficresstdeij,"\n"); | 
 |  |  | 
 |  | pstamp(ficrescveij); | 
 |  | fprintf(ficrescveij,"# Subdiagonal matrix of covariances of health expectancies by age: cov(eij,ekl)\n"); | 
 |  | fprintf(ficrescveij,"# Age"); | 
 |  | for(i=1; i<=nlstate;i++) | 
 |  | for(j=1; j<=nlstate;j++){ | 
 |  | cptj= (j-1)*nlstate+i; | 
 |  | for(i2=1; i2<=nlstate;i2++) | 
 |  | for(j2=1; j2<=nlstate;j2++){ | 
 |  | cptj2= (j2-1)*nlstate+i2; | 
 |  | if(cptj2 <= cptj) | 
 |  | fprintf(ficrescveij,"  %1d%1d,%1d%1d",i,j,i2,j2); | 
 |  | } | 
 |  | } | 
 |  | fprintf(ficrescveij,"\n"); | 
 |  |  | 
 | if(estepm < stepm){ | if(estepm < stepm){ | 
 | printf ("Problem %d lower than %d\n",estepm, stepm); | printf ("Problem %d lower than %d\n",estepm, stepm); | 
 | } | } | 
| Line 2437  void evsij(char fileres[], double ***eij | Line 2665  void evsij(char fileres[], double ***eij | 
 | */ | */ | 
 | hstepm=hstepm/stepm; /* Typically in stepm units, if stepm=6 & estepm=24 , = 24/6 months = 4 */ | hstepm=hstepm/stepm; /* Typically in stepm units, if stepm=6 & estepm=24 , = 24/6 months = 4 */ | 
 |  |  | 
 |  | /* If stepm=6 months */ | 
 |  | /* nhstepm age range expressed in number of stepm */ | 
 | agelim=AGESUP; | agelim=AGESUP; | 
| for (age=bage; age<=fage; age ++){ /* If stepm=6 months */ | nstepm=(int) rint((agelim-bage)*YEARM/stepm); | 
| /* nhstepm age range expressed in number of stepm */ | /* Typically if 20 years nstepm = 20*12/6=40 stepm */ | 
| nstepm=(int) rint((agelim-age)*YEARM/stepm); | /* if (stepm >= YEARM) hstepm=1;*/ | 
|  | nhstepm = nstepm/hstepm;/* Expressed in hstepm, typically nhstepm=40/4=10 */ | 
|  |  | 
|  | p3matp=ma3x(1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm); | 
|  | p3matm=ma3x(1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm); | 
|  | gradg=ma3x(0,nhstepm,1,npar,1,nlstate*nlstate); | 
|  | trgradg =ma3x(0,nhstepm,1,nlstate*nlstate,1,npar); | 
|  | gp=matrix(0,nhstepm,1,nlstate*nlstate); | 
|  | gm=matrix(0,nhstepm,1,nlstate*nlstate); | 
|  |  | 
|  | for (age=bage; age<=fage; age ++){ | 
|  | nstepma=(int) rint((agelim-bage)*YEARM/stepm); /* Biggest nstepm */ | 
 | /* Typically if 20 years nstepm = 20*12/6=40 stepm */ | /* Typically if 20 years nstepm = 20*12/6=40 stepm */ | 
 | /* if (stepm >= YEARM) hstepm=1;*/ | /* if (stepm >= YEARM) hstepm=1;*/ | 
| nhstepm = nstepm/hstepm;/* Expressed in hstepm, typically nhstepm=40/4=10 */ | nhstepma = nstepma/hstepm;/* Expressed in hstepm, typically nhstepma=40/4=10 */ | 
| p3mat=ma3x(1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm); |  | 
| gradg=ma3x(0,nhstepm,1,npar,1,nlstate*nlstate); |  | 
| gp=matrix(0,nhstepm,1,nlstate*nlstate); |  | 
| gm=matrix(0,nhstepm,1,nlstate*nlstate); |  | 
|  |  | 
| /* Computed by stepm unit matrices, product of hstepm matrices, stored |  | 
| in an array of nhstepm length: nhstepm=10, hstepm=4, stepm=6 months */ |  | 
| hpxij(p3mat,nhstepm,age,hstepm,x,nlstate,stepm,oldm, savm, ij); |  | 
|  |  | 
 |  |  | 
 |  | /* If stepm=6 months */ | 
 |  | /* Computed by stepm unit matrices, product of hstepma matrices, stored | 
 |  | in an array of nhstepma length: nhstepma=10, hstepm=4, stepm=6 months */ | 
 |  |  | 
 | hf=hstepm*stepm/YEARM;  /* Duration of hstepm expressed in year unit. */ | hf=hstepm*stepm/YEARM;  /* Duration of hstepm expressed in year unit. */ | 
 |  |  | 
 | /* Computing  Variances of health expectancies */ | /* Computing  Variances of health expectancies */ | 
|  | /* Gradient is computed with plus gp and minus gm. Code is duplicated in order to | 
| for(theta=1; theta <=npar; theta++){ | decrease memory allocation */ | 
|  | for(theta=1; theta <=npar; theta++){ | 
 | for(i=1; i<=npar; i++){ | for(i=1; i<=npar; i++){ | 
 | xp[i] = x[i] + (i==theta ?delti[theta]:0); | xp[i] = x[i] + (i==theta ?delti[theta]:0); | 
 |  | xm[i] = x[i] - (i==theta ?delti[theta]:0); | 
 | } | } | 
| hpxij(p3mat,nhstepm,age,hstepm,xp,nlstate,stepm,oldm,savm, ij); | hpxij(p3matp,nhstepm,age,hstepm,xp,nlstate,stepm,oldm,savm, cij); | 
|  | hpxij(p3matm,nhstepm,age,hstepm,xm,nlstate,stepm,oldm,savm, cij); | 
 |  |  | 
 | cptj=0; |  | 
 | for(j=1; j<= nlstate; j++){ | for(j=1; j<= nlstate; j++){ | 
 | for(i=1; i<=nlstate; i++){ | for(i=1; i<=nlstate; i++){ | 
| cptj=cptj+1; | for(h=0; h<=nhstepm-1; h++){ | 
| for(h=0, gp[h][cptj]=0.; h<=nhstepm-1; h++){ | gp[h][(j-1)*nlstate + i] = (p3matp[i][j][h]+p3matp[i][j][h+1])/2.; | 
| gp[h][cptj] = (p3mat[i][j][h]+p3mat[i][j][h+1])/2.; | gm[h][(j-1)*nlstate + i] = (p3matm[i][j][h]+p3matm[i][j][h+1])/2.; | 
 | } | } | 
 | } | } | 
 | } | } | 
 |  |  | 
|  | for(ij=1; ij<= nlstate*nlstate; ij++) | 
| for(i=1; i<=npar; i++) |  | 
| xp[i] = x[i] - (i==theta ?delti[theta]:0); |  | 
| hpxij(p3mat,nhstepm,age,hstepm,xp,nlstate,stepm,oldm,savm, ij); |  | 
|  |  | 
| cptj=0; |  | 
| for(j=1; j<= nlstate; j++){ |  | 
| for(i=1;i<=nlstate;i++){ |  | 
| cptj=cptj+1; |  | 
| for(h=0, gm[h][cptj]=0.; h<=nhstepm-1; h++){ |  | 
|  |  | 
| gm[h][cptj] = (p3mat[i][j][h]+p3mat[i][j][h+1])/2.; |  | 
| } |  | 
| } |  | 
| } |  | 
| for(j=1; j<= nlstate*nlstate; j++) |  | 
 | for(h=0; h<=nhstepm-1; h++){ | for(h=0; h<=nhstepm-1; h++){ | 
| gradg[h][theta][j]= (gp[h][j]-gm[h][j])/2./delti[theta]; | gradg[h][theta][ij]= (gp[h][ij]-gm[h][ij])/2./delti[theta]; | 
 | } | } | 
| } | }/* End theta */ | 
|  |  | 
| /* End theta */ |  | 
|  | for(h=0; h<=nhstepm-1; h++) | 
| trgradg =ma3x(0,nhstepm,1,nlstate*nlstate,1,npar); |  | 
|  |  | 
| for(h=0; h<=nhstepm-1; h++) |  | 
 | for(j=1; j<=nlstate*nlstate;j++) | for(j=1; j<=nlstate*nlstate;j++) | 
 | for(theta=1; theta <=npar; theta++) | for(theta=1; theta <=npar; theta++) | 
 | trgradg[h][j][theta]=gradg[h][theta][j]; | trgradg[h][j][theta]=gradg[h][theta][j]; | 
|  |  | 
 |  |  | 
| for(i=1;i<=nlstate*nlstate;i++) | for(ij=1;ij<=nlstate*nlstate;ij++) | 
| for(j=1;j<=nlstate*nlstate;j++) | for(ji=1;ji<=nlstate*nlstate;ji++) | 
| varhe[i][j][(int)age] =0.; | varhe[ij][ji][(int)age] =0.; | 
 |  |  | 
 | printf("%d|",(int)age);fflush(stdout); | printf("%d|",(int)age);fflush(stdout); | 
 | fprintf(ficlog,"%d|",(int)age);fflush(ficlog); | fprintf(ficlog,"%d|",(int)age);fflush(ficlog); | 
| Line 2515  void evsij(char fileres[], double ***eij | Line 2735  void evsij(char fileres[], double ***eij | 
 | for(k=0;k<=nhstepm-1;k++){ | for(k=0;k<=nhstepm-1;k++){ | 
 | matprod2(dnewm,trgradg[h],1,nlstate*nlstate,1,npar,1,npar,matcov); | matprod2(dnewm,trgradg[h],1,nlstate*nlstate,1,npar,1,npar,matcov); | 
 | matprod2(doldm,dnewm,1,nlstate*nlstate,1,npar,1,nlstate*nlstate,gradg[k]); | matprod2(doldm,dnewm,1,nlstate*nlstate,1,npar,1,nlstate*nlstate,gradg[k]); | 
| for(i=1;i<=nlstate*nlstate;i++) | for(ij=1;ij<=nlstate*nlstate;ij++) | 
| for(j=1;j<=nlstate*nlstate;j++) | for(ji=1;ji<=nlstate*nlstate;ji++) | 
| varhe[i][j][(int)age] += doldm[i][j]*hf*hf; | varhe[ij][ji][(int)age] += doldm[ij][ji]*hf*hf; | 
 | } | } | 
 | } | } | 
 |  |  | 
 | /* Computing expectancies */ | /* Computing expectancies */ | 
 |  | hpxij(p3matm,nhstepm,age,hstepm,x,nlstate,stepm,oldm, savm, cij); | 
 | for(i=1; i<=nlstate;i++) | for(i=1; i<=nlstate;i++) | 
 | for(j=1; j<=nlstate;j++) | for(j=1; j<=nlstate;j++) | 
 | for (h=0, eij[i][j][(int)age]=0; h<=nhstepm-1; h++){ | for (h=0, eij[i][j][(int)age]=0; h<=nhstepm-1; h++){ | 
| eij[i][j][(int)age] += (p3mat[i][j][h]+p3mat[i][j][h+1])/2.0*hf; | eij[i][j][(int)age] += (p3matm[i][j][h]+p3matm[i][j][h+1])/2.0*hf; | 
 |  |  | 
| /* if((int)age==70)printf("i=%2d,j=%2d,h=%2d,age=%3d,%9.4f,%9.4f,%9.4f\n",i,j,h,(int)age,p3mat[i][j][h],hf,eij[i][j][(int)age]);*/ | /* if((int)age==70)printf("i=%2d,j=%2d,h=%2d,age=%3d,%9.4f,%9.4f,%9.4f\n",i,j,h,(int)age,p3mat[i][j][h],hf,eij[i][j][(int)age]);*/ | 
 |  |  | 
 | } | } | 
 |  |  | 
| fprintf(ficreseij,"%3.0f",age ); | fprintf(ficresstdeij,"%3.0f",age ); | 
| cptj=0; | for(i=1; i<=nlstate;i++){ | 
|  | eip=0.; | 
|  | vip=0.; | 
|  | for(j=1; j<=nlstate;j++){ | 
|  | eip += eij[i][j][(int)age]; | 
|  | for(k=1; k<=nlstate;k++) /* Sum on j and k of cov(eij,eik) */ | 
|  | vip += varhe[(j-1)*nlstate+i][(k-1)*nlstate+i][(int)age]; | 
|  | fprintf(ficresstdeij," %9.4f (%.4f)", eij[i][j][(int)age], sqrt(varhe[(j-1)*nlstate+i][(j-1)*nlstate+i][(int)age]) ); | 
|  | } | 
|  | fprintf(ficresstdeij," %9.4f (%.4f)", eip, sqrt(vip)); | 
|  | } | 
|  | fprintf(ficresstdeij,"\n"); | 
|  |  | 
|  | fprintf(ficrescveij,"%3.0f",age ); | 
 | for(i=1; i<=nlstate;i++) | for(i=1; i<=nlstate;i++) | 
 | for(j=1; j<=nlstate;j++){ | for(j=1; j<=nlstate;j++){ | 
| cptj++; | cptj= (j-1)*nlstate+i; | 
| fprintf(ficreseij," %9.4f (%.4f)", eij[i][j][(int)age], sqrt(varhe[cptj][cptj][(int)age]) ); | for(i2=1; i2<=nlstate;i2++) | 
|  | for(j2=1; j2<=nlstate;j2++){ | 
|  | cptj2= (j2-1)*nlstate+i2; | 
|  | if(cptj2 <= cptj) | 
|  | fprintf(ficrescveij," %.4f", varhe[cptj][cptj2][(int)age]); | 
|  | } | 
 | } | } | 
| fprintf(ficreseij,"\n"); | fprintf(ficrescveij,"\n"); | 
 |  |  | 
 | free_matrix(gm,0,nhstepm,1,nlstate*nlstate); |  | 
 | free_matrix(gp,0,nhstepm,1,nlstate*nlstate); |  | 
 | free_ma3x(gradg,0,nhstepm,1,npar,1,nlstate*nlstate); |  | 
 | free_ma3x(trgradg,0,nhstepm,1,nlstate*nlstate,1,npar); |  | 
 | free_ma3x(p3mat,1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm); |  | 
 | } | } | 
 |  | free_matrix(gm,0,nhstepm,1,nlstate*nlstate); | 
 |  | free_matrix(gp,0,nhstepm,1,nlstate*nlstate); | 
 |  | free_ma3x(gradg,0,nhstepm,1,npar,1,nlstate*nlstate); | 
 |  | free_ma3x(trgradg,0,nhstepm,1,nlstate*nlstate,1,npar); | 
 |  | free_ma3x(p3matm,1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm); | 
 |  | free_ma3x(p3matp,1,nlstate+ndeath,1, nlstate+ndeath, 0,nhstepm); | 
 | printf("\n"); | printf("\n"); | 
 | fprintf(ficlog,"\n"); | fprintf(ficlog,"\n"); | 
 |  |  | 
 |  | free_vector(xm,1,npar); | 
 | free_vector(xp,1,npar); | free_vector(xp,1,npar); | 
 | free_matrix(dnewm,1,nlstate*nlstate,1,npar); | free_matrix(dnewm,1,nlstate*nlstate,1,npar); | 
 | free_matrix(doldm,1,nlstate*nlstate,1,nlstate*nlstate); | free_matrix(doldm,1,nlstate*nlstate,1,nlstate*nlstate); | 
| Line 2608  void varevsij(char optionfilefiname[], d | Line 2850  void varevsij(char optionfilefiname[], d | 
 | printf("Computing total mortality p.j=w1*p1j+w2*p2j+..: result on file '%s' \n",fileresprobmorprev); | printf("Computing total mortality p.j=w1*p1j+w2*p2j+..: result on file '%s' \n",fileresprobmorprev); | 
 |  |  | 
 | fprintf(ficlog,"Computing total mortality p.j=w1*p1j+w2*p2j+..: result on file '%s' \n",fileresprobmorprev); | fprintf(ficlog,"Computing total mortality p.j=w1*p1j+w2*p2j+..: result on file '%s' \n",fileresprobmorprev); | 
| fprintf(ficresprobmorprev, "#Local time at start: %s", strstart); | pstamp(ficresprobmorprev); | 
 | fprintf(ficresprobmorprev,"# probabilities of dying before estepm=%d months for people of exact age and weighted probabilities w1*p1j+w2*p2j+... stand dev in()\n",estepm); | fprintf(ficresprobmorprev,"# probabilities of dying before estepm=%d months for people of exact age and weighted probabilities w1*p1j+w2*p2j+... stand dev in()\n",estepm); | 
 | fprintf(ficresprobmorprev,"# Age cov=%-d",ij); | fprintf(ficresprobmorprev,"# Age cov=%-d",ij); | 
 | for(j=nlstate+1; j<=(nlstate+ndeath);j++){ | for(j=nlstate+1; j<=(nlstate+ndeath);j++){ | 
| Line 2623  void varevsij(char optionfilefiname[], d | Line 2865  void varevsij(char optionfilefiname[], d | 
 | fprintf(fichtm,"\n<br>%s  <br>\n",digitp); | fprintf(fichtm,"\n<br>%s  <br>\n",digitp); | 
 | /*   } */ | /*   } */ | 
 | varppt = matrix(nlstate+1,nlstate+ndeath,nlstate+1,nlstate+ndeath); | varppt = matrix(nlstate+1,nlstate+ndeath,nlstate+1,nlstate+ndeath); | 
| fprintf(ficresvij, "#Local time at start: %s", strstart); | pstamp(ficresvij); | 
| fprintf(ficresvij,"# Variance and covariance of health expectancies e.j \n#  (weighted average of eij where weights are the stable prevalence in health states i\n"); | fprintf(ficresvij,"# Variance and covariance of health expectancies e.j \n#  (weighted average of eij where weights are "); | 
|  | if(popbased==1) | 
|  | fprintf(ficresvij,"the age specific prevalence observed in the population i.e cross-sectionally\n in each health state (popbased=1)"); | 
|  | else | 
|  | fprintf(ficresvij,"the age specific period (stable) prevalences in each health state \n"); | 
 | fprintf(ficresvij,"# Age"); | fprintf(ficresvij,"# Age"); | 
 | for(i=1; i<=nlstate;i++) | for(i=1; i<=nlstate;i++) | 
 | for(j=1; j<=nlstate;j++) | for(j=1; j<=nlstate;j++) | 
| fprintf(ficresvij," Cov(e%1d, e%1d)",i,j); | fprintf(ficresvij," Cov(e.%1d, e.%1d)",i,j); | 
 | fprintf(ficresvij,"\n"); | fprintf(ficresvij,"\n"); | 
 |  |  | 
 | xp=vector(1,npar); | xp=vector(1,npar); | 
| Line 2869  void varprevlim(char fileres[], double * | Line 3115  void varprevlim(char fileres[], double * | 
 | double **gradg, **trgradg; | double **gradg, **trgradg; | 
 | double age,agelim; | double age,agelim; | 
 | int theta; | int theta; | 
| fprintf(ficresvpl, "#Local time at start: %s", strstart); |  | 
| fprintf(ficresvpl,"# Standard deviation of stable prevalences \n"); | pstamp(ficresvpl); | 
|  | fprintf(ficresvpl,"# Standard deviation of period (stable) prevalences \n"); | 
 | fprintf(ficresvpl,"# Age"); | fprintf(ficresvpl,"# Age"); | 
 | for(i=1; i<=nlstate;i++) | for(i=1; i<=nlstate;i++) | 
 | fprintf(ficresvpl," %1d-%1d",i,i); | fprintf(ficresvpl," %1d-%1d",i,i); | 
| Line 2984  void varprob(char optionfilefiname[], do | Line 3231  void varprob(char optionfilefiname[], do | 
 | fprintf(ficlog,"Computing matrix of variance covariance of one-step probabilities: result on file '%s' \n",fileresprobcov); | fprintf(ficlog,"Computing matrix of variance covariance of one-step probabilities: result on file '%s' \n",fileresprobcov); | 
 | printf("and correlation matrix of one-step probabilities: result on file '%s' \n",fileresprobcor); | printf("and correlation matrix of one-step probabilities: result on file '%s' \n",fileresprobcor); | 
 | fprintf(ficlog,"and correlation matrix of one-step probabilities: result on file '%s' \n",fileresprobcor); | fprintf(ficlog,"and correlation matrix of one-step probabilities: result on file '%s' \n",fileresprobcor); | 
| fprintf(ficresprob, "#Local time at start: %s", strstart); | pstamp(ficresprob); | 
 | fprintf(ficresprob,"#One-step probabilities and stand. devi in ()\n"); | fprintf(ficresprob,"#One-step probabilities and stand. devi in ()\n"); | 
 | fprintf(ficresprob,"# Age"); | fprintf(ficresprob,"# Age"); | 
| fprintf(ficresprobcov, "#Local time at start: %s", strstart); | pstamp(ficresprobcov); | 
 | fprintf(ficresprobcov,"#One-step probabilities and covariance matrix\n"); | fprintf(ficresprobcov,"#One-step probabilities and covariance matrix\n"); | 
 | fprintf(ficresprobcov,"# Age"); | fprintf(ficresprobcov,"# Age"); | 
| fprintf(ficresprobcor, "#Local time at start: %s", strstart); | pstamp(ficresprobcor); | 
 | fprintf(ficresprobcor,"#One-step probabilities and correlation matrix\n"); | fprintf(ficresprobcor,"#One-step probabilities and correlation matrix\n"); | 
| fprintf(ficresprobcov,"# Age"); | fprintf(ficresprobcor,"# Age"); | 
 |  |  | 
 |  |  | 
 | for(i=1; i<=nlstate;i++) | for(i=1; i<=nlstate;i++) | 
| Line 3273  void printinghtml(char fileres[], char t | Line 3520  void printinghtml(char fileres[], char t | 
 | - Estimated transition probabilities over %d (stepm) months: <a href=\"%s\">%s</a><br>\n ", | - Estimated transition probabilities over %d (stepm) months: <a href=\"%s\">%s</a><br>\n ", | 
 | stepm,subdirf2(fileres,"pij"),subdirf2(fileres,"pij")); | stepm,subdirf2(fileres,"pij"),subdirf2(fileres,"pij")); | 
 | fprintf(fichtm,"\ | fprintf(fichtm,"\ | 
| - Stable prevalence in each health state: <a href=\"%s\">%s</a> <br>\n", | - Period (stable) prevalence in each health state: <a href=\"%s\">%s</a> <br>\n", | 
 | subdirf2(fileres,"pl"),subdirf2(fileres,"pl")); | subdirf2(fileres,"pl"),subdirf2(fileres,"pl")); | 
 | fprintf(fichtm,"\ | fprintf(fichtm,"\ | 
| - Life expectancies by age and initial health status (estepm=%2d months): \ | - (a) Life expectancies by health status at initial age, (b) health expectancies by health status at initial age:  ei., eij . If one or more covariate are included, specific tables for each value of the covariate are output in sequences within the same file (estepm=%2d months): \ | 
| <a href=\"%s\">%s</a> <br>\n</li>", | <a href=\"%s\">%s</a> <br>\n", | 
 | estepm,subdirf2(fileres,"e"),subdirf2(fileres,"e")); | estepm,subdirf2(fileres,"e"),subdirf2(fileres,"e")); | 
 |  | fprintf(fichtm,"\ | 
 |  | - Population projections by age and states: \ | 
 |  | <a href=\"%s\">%s</a> <br>\n</li>", subdirf2(fileres,"f"),subdirf2(fileres,"f")); | 
 |  |  | 
 | fprintf(fichtm," \n<ul><li><b>Graphs</b></li><p>"); | fprintf(fichtm," \n<ul><li><b>Graphs</b></li><p>"); | 
 |  |  | 
| Line 3296  fprintf(fichtm," \n<ul><li><b>Graphs</b> | Line 3546  fprintf(fichtm," \n<ul><li><b>Graphs</b> | 
 | fprintf(fichtm," ************\n<hr size=\"2\" color=\"#EC5E5E\">"); | fprintf(fichtm," ************\n<hr size=\"2\" color=\"#EC5E5E\">"); | 
 | } | } | 
 | /* Pij */ | /* Pij */ | 
| fprintf(fichtm,"<br>- Pij or Conditional probabilities to be observed in state j being in state i, %d (stepm) months before: %s%d1.png<br> \ | fprintf(fichtm,"<br>- Pij or Conditional probabilities to be observed in state j being in state i, %d (stepm) months before: <a href=\"%s%d1.png\">%s%d1.png</a><br> \ | 
| <img src=\"%s%d1.png\">",stepm,subdirf2(optionfilefiname,"pe"),jj1,subdirf2(optionfilefiname,"pe"),jj1); | <img src=\"%s%d1.png\">",stepm,subdirf2(optionfilefiname,"pe"),jj1,subdirf2(optionfilefiname,"pe"),jj1,subdirf2(optionfilefiname,"pe"),jj1); | 
 | /* Quasi-incidences */ | /* Quasi-incidences */ | 
 | fprintf(fichtm,"<br>- Pij or Conditional probabilities to be observed in state j being in state i %d (stepm) months\ | fprintf(fichtm,"<br>- Pij or Conditional probabilities to be observed in state j being in state i %d (stepm) months\ | 
| before but expressed in per year i.e. quasi incidences if stepm is small and probabilities too: %s%d2.png<br> \ | before but expressed in per year i.e. quasi incidences if stepm is small and probabilities too: <a href=\"%s%d2.png\">%s%d2.png</a><br> \ | 
| <img src=\"%s%d2.png\">",stepm,subdirf2(optionfilefiname,"pe"),jj1,subdirf2(optionfilefiname,"pe"),jj1); | <img src=\"%s%d2.png\">",stepm,subdirf2(optionfilefiname,"pe"),jj1,subdirf2(optionfilefiname,"pe"),jj1,subdirf2(optionfilefiname,"pe"),jj1); | 
| /* Stable prevalence in each health state */ | /* Period (stable) prevalence in each health state */ | 
 | for(cpt=1; cpt<nlstate;cpt++){ | for(cpt=1; cpt<nlstate;cpt++){ | 
| fprintf(fichtm,"<br>- Stable prevalence in each health state : p%s%d%d.png<br> \ | fprintf(fichtm,"<br>- Period (stable) prevalence in each health state : <a href=\"%s%d%d.png\">%s%d%d.png</a><br> \ | 
| <img src=\"%s%d%d.png\">",subdirf2(optionfilefiname,"p"),cpt,jj1,subdirf2(optionfilefiname,"p"),cpt,jj1); | <img src=\"%s%d%d.png\">",subdirf2(optionfilefiname,"p"),cpt,jj1,subdirf2(optionfilefiname,"p"),cpt,jj1,subdirf2(optionfilefiname,"p"),cpt,jj1); | 
 | } | } | 
 | for(cpt=1; cpt<=nlstate;cpt++) { | for(cpt=1; cpt<=nlstate;cpt++) { | 
| fprintf(fichtm,"\n<br>- Health life expectancies by age and initial health state (%d): %s%d%d.png <br> \ | fprintf(fichtm,"\n<br>- Life expectancy by health state (%d) at initial age and its decomposition into health expectancies : <a href=\"%s%d%d.png\">%s%d%d.png</a> <br> \ | 
| <img src=\"%s%d%d.png\">",cpt,subdirf2(optionfilefiname,"exp"),cpt,jj1,subdirf2(optionfilefiname,"exp"),cpt,jj1); | <img src=\"%s%d%d.png\">",cpt,subdirf2(optionfilefiname,"exp"),cpt,jj1,subdirf2(optionfilefiname,"exp"),cpt,jj1,subdirf2(optionfilefiname,"exp"),cpt,jj1); | 
 | } | } | 
 | } /* end i1 */ | } /* end i1 */ | 
 | }/* End k1 */ | }/* End k1 */ | 
| Line 3330  fprintf(fichtm," \n<ul><li><b>Graphs</b> | Line 3580  fprintf(fichtm," \n<ul><li><b>Graphs</b> | 
 | - Correlation matrix of one-step probabilities: <a href=\"%s\">%s</a> <br>\n", | - Correlation matrix of one-step probabilities: <a href=\"%s\">%s</a> <br>\n", | 
 | subdirf2(fileres,"probcor"),subdirf2(fileres,"probcor")); | subdirf2(fileres,"probcor"),subdirf2(fileres,"probcor")); | 
 | fprintf(fichtm,"\ | fprintf(fichtm,"\ | 
| - Variances and covariances of life expectancies by age and initial health status (estepm=%d months): <a href=\"%s\">%s</a><br>\n", | - Variances and covariances of health expectancies by age and <b>initial health status</b> (cov(e<sup>ij</sup>,e<sup>kl</sup>)(estepm=%2d months): \ | 
|  | <a href=\"%s\">%s</a> <br>\n</li>", | 
|  | estepm,subdirf2(fileres,"cve"),subdirf2(fileres,"cve")); | 
|  | fprintf(fichtm,"\ | 
|  | - (a) Health expectancies by health status at initial age (e<sup>ij</sup>) and standard errors (in parentheses) (b) life expectancies and standard errors (e<sup>i.</sup>=e<sup>i1</sup>+e<sup>i2</sup>+...)(estepm=%2d months): \ | 
|  | <a href=\"%s\">%s</a> <br>\n</li>", | 
|  | estepm,subdirf2(fileres,"stde"),subdirf2(fileres,"stde")); | 
|  | fprintf(fichtm,"\ | 
|  | - Variances and covariances of health expectancies by age. Status (i) based health expectancies (in state j), eij are weighted by the period prevalences in each state i (if popbased=1, an additional computation is done using the cross-sectional prevalences (i.e population based) (estepm=%d months): <a href=\"%s\">%s</a><br>\n", | 
 | estepm, subdirf2(fileres,"v"),subdirf2(fileres,"v")); | estepm, subdirf2(fileres,"v"),subdirf2(fileres,"v")); | 
 | fprintf(fichtm,"\ | fprintf(fichtm,"\ | 
| - Health expectancies with their variances (no covariance): <a href=\"%s\">%s</a> <br>\n", | - Total life expectancy and total health expectancies to be spent in each health state e<sup>.j</sup> with their standard errors: <a href=\"%s\">%s</a> <br>\n", | 
 | subdirf2(fileres,"t"),subdirf2(fileres,"t")); | subdirf2(fileres,"t"),subdirf2(fileres,"t")); | 
 | fprintf(fichtm,"\ | fprintf(fichtm,"\ | 
| - Standard deviation of stable prevalences: <a href=\"%s\">%s</a> <br>\n",\ | - Standard deviation of period (stable) prevalences: <a href=\"%s\">%s</a> <br>\n",\ | 
 | subdirf2(fileres,"vpl"),subdirf2(fileres,"vpl")); | subdirf2(fileres,"vpl"),subdirf2(fileres,"vpl")); | 
 |  |  | 
 | /*  if(popforecast==1) fprintf(fichtm,"\n */ | /*  if(popforecast==1) fprintf(fichtm,"\n */ | 
| Line 3408  plot [%.f:%.f] \"%s\" every :::%d::%d u | Line 3666  plot [%.f:%.f] \"%s\" every :::%d::%d u | 
 | if (i==cpt) fprintf(ficgp," \%%lf (\%%lf)"); | if (i==cpt) fprintf(ficgp," \%%lf (\%%lf)"); | 
 | else fprintf(ficgp," \%%*lf (\%%*lf)"); | else fprintf(ficgp," \%%*lf (\%%*lf)"); | 
 | } | } | 
| fprintf(ficgp,"\" t\"Stable prevalence\" w l 0,\"%s\" every :::%d::%d u 1:($2+1.96*$3) \"\%%lf",subdirf2(fileres,"vpl"),k1-1,k1-1); | fprintf(ficgp,"\" t\"Period (stable) prevalence\" w l 0,\"%s\" every :::%d::%d u 1:($2+1.96*$3) \"\%%lf",subdirf2(fileres,"vpl"),k1-1,k1-1); | 
 | for (i=1; i<= nlstate ; i ++) { | for (i=1; i<= nlstate ; i ++) { | 
 | if (i==cpt) fprintf(ficgp," \%%lf (\%%lf)"); | if (i==cpt) fprintf(ficgp," \%%lf (\%%lf)"); | 
 | else fprintf(ficgp," \%%*lf (\%%*lf)"); | else fprintf(ficgp," \%%*lf (\%%*lf)"); | 
| Line 3456  plot [%.f:%.f] \"%s\" every :::%d::%d u | Line 3714  plot [%.f:%.f] \"%s\" every :::%d::%d u | 
 |  |  | 
 | for (k1=1; k1<= m ; k1 ++) { | for (k1=1; k1<= m ; k1 ++) { | 
 | for (cpt=1; cpt<= nlstate ; cpt ++) { | for (cpt=1; cpt<= nlstate ; cpt ++) { | 
| k=2+nlstate*(2*cpt-2); | /*       k=2+nlstate*(2*cpt-2); */ | 
|  | k=2+(nlstate+1)*(cpt-1); | 
 | fprintf(ficgp,"\nset out \"%s%d%d.png\" \n",subdirf2(optionfilefiname,"exp"),cpt,k1); | fprintf(ficgp,"\nset out \"%s%d%d.png\" \n",subdirf2(optionfilefiname,"exp"),cpt,k1); | 
 | fprintf(ficgp,"set ter png small\n\ | fprintf(ficgp,"set ter png small\n\ | 
 | set size 0.65,0.65\n\ | set size 0.65,0.65\n\ | 
| Line 3470  plot [%.f:%.f] \"%s\" every :::%d::%d u | Line 3729  plot [%.f:%.f] \"%s\" every :::%d::%d u | 
 |  |  | 
 | */ | */ | 
 | for (i=1; i< nlstate ; i ++) { | for (i=1; i< nlstate ; i ++) { | 
| fprintf(ficgp," ,\"%s\" every :::%d::%d u 1:%d t \"e%d%d\" w l",subdirf2(fileres,"e"),k1-1,k1-1,k+2*i,cpt,i+1); | fprintf(ficgp," ,\"%s\" every :::%d::%d u 1:%d t \"e%d%d\" w l",subdirf2(fileres,"e"),k1-1,k1-1,k+i,cpt,i+1); | 
|  | /*      fprintf(ficgp," ,\"%s\" every :::%d::%d u 1:%d t \"e%d%d\" w l",subdirf2(fileres,"e"),k1-1,k1-1,k+2*i,cpt,i+1);*/ | 
 |  |  | 
 | } | } | 
 |  | fprintf(ficgp," ,\"%s\" every :::%d::%d u 1:%d t \"e%d.\" w l",subdirf2(fileres,"e"),k1-1,k1-1,k+nlstate,cpt); | 
 | } | } | 
 | } | } | 
 |  |  | 
| Line 4113  void printinggnuplotmort(char fileres[], | Line 4374  void printinggnuplotmort(char fileres[], | 
 |  |  | 
 |  |  | 
 |  |  | 
 |  |  | 
 | /***********************************************/ | /***********************************************/ | 
 | /**************** Main Program *****************/ | /**************** Main Program *****************/ | 
 | /***********************************************/ | /***********************************************/ | 
| Line 4181  int main(int argc, char *argv[]) | Line 4443  int main(int argc, char *argv[]) | 
 | char z[1]="c", occ; | char z[1]="c", occ; | 
 |  |  | 
 | char stra[80], strb[80], strc[80], strd[80],stre[80],modelsav[80]; | char stra[80], strb[80], strc[80], strd[80],stre[80],modelsav[80]; | 
| char strstart[80], *strt, strtend[80]; | char  *strt, strtend[80]; | 
 | char *stratrunc; | char *stratrunc; | 
 | int lstra; | int lstra; | 
 |  |  | 
| Line 4232  int main(int argc, char *argv[]) | Line 4494  int main(int argc, char *argv[]) | 
 | while ((val = strsep(&tok, "\"" )) != NULL && *val == '\0'); | while ((val = strsep(&tok, "\"" )) != NULL && *val == '\0'); | 
 | printf("val= |%s| pathr=%s\n",val,pathr); | printf("val= |%s| pathr=%s\n",val,pathr); | 
 | strcpy (pathtot, val); | strcpy (pathtot, val); | 
| if(pathr[0] == '\0') break; /* Un peu sale */ | if(pathr[0] == '\0') break; /* Dirty */ | 
 | } | } | 
 | } | } | 
 | else{ | else{ | 
| Line 4251  int main(int argc, char *argv[]) | Line 4513  int main(int argc, char *argv[]) | 
 | /* Split argv[1]=pathtot, parameter file name to get path, optionfile, extension and name */ | /* Split argv[1]=pathtot, parameter file name to get path, optionfile, extension and name */ | 
 | split(pathtot,path,optionfile,optionfilext,optionfilefiname); | split(pathtot,path,optionfile,optionfilext,optionfilefiname); | 
 | printf("\npathtot=%s,\npath=%s,\noptionfile=%s \noptionfilext=%s \noptionfilefiname=%s\n",pathtot,path,optionfile,optionfilext,optionfilefiname); | printf("\npathtot=%s,\npath=%s,\noptionfile=%s \noptionfilext=%s \noptionfilefiname=%s\n",pathtot,path,optionfile,optionfilext,optionfilefiname); | 
| chdir(path); | chdir(path); /* Can be a relative path */ | 
|  | if(getcwd(pathcd,MAXLINE) > 0) /* So pathcd is the full path */ | 
|  | printf("Current directory %s!\n",pathcd); | 
 | strcpy(command,"mkdir "); | strcpy(command,"mkdir "); | 
 | strcat(command,optionfilefiname); | strcat(command,optionfilefiname); | 
 | if((outcmd=system(command)) != 0){ | if((outcmd=system(command)) != 0){ | 
| Line 4360  int main(int argc, char *argv[]) | Line 4624  int main(int argc, char *argv[]) | 
 | free_ma3x(delti3,1,nlstate,1, nlstate+ndeath-1,1,ncovmodel); | free_ma3x(delti3,1,nlstate,1, nlstate+ndeath-1,1,ncovmodel); | 
 | fclose (ficparo); | fclose (ficparo); | 
 | fclose (ficlog); | fclose (ficlog); | 
 |  | goto end; | 
 | exit(0); | exit(0); | 
 | } | } | 
 | else if(mle==-3) { | else if(mle==-3) { | 
| Line 4390  int main(int argc, char *argv[]) | Line 4655  int main(int argc, char *argv[]) | 
 | j++; | j++; | 
 | fscanf(ficpar,"%1d%1d",&i1,&j1); | fscanf(ficpar,"%1d%1d",&i1,&j1); | 
 | if ((i1 != i) && (j1 != j)){ | if ((i1 != i) && (j1 != j)){ | 
| printf("Error in line parameters number %d, %1d%1d instead of %1d%1d \n",numlinepar, i,j, i1, j1); | printf("Error in line parameters number %d, %1d%1d instead of %1d%1d \n \ | 
|  | It might be a problem of design; if ncovcol and the model are correct\n \ | 
|  | run imach with mle=-1 to get a correct template of the parameter file.\n",numlinepar, i,j, i1, j1); | 
 | exit(1); | exit(1); | 
 | } | } | 
 | fprintf(ficparo,"%1d%1d",i1,j1); | fprintf(ficparo,"%1d%1d",i1,j1); | 
| Line 4517  int main(int argc, char *argv[]) | Line 4784  int main(int argc, char *argv[]) | 
 |  |  | 
 | /*-------- data file ----------*/ | /*-------- data file ----------*/ | 
 | if((fic=fopen(datafile,"r"))==NULL)    { | if((fic=fopen(datafile,"r"))==NULL)    { | 
| printf("Problem with datafile: %s\n", datafile);goto end; | printf("Problem while opening datafile: %s\n", datafile);goto end; | 
| fprintf(ficlog,"Problem with datafile: %s\n", datafile);goto end; | fprintf(ficlog,"Problem while opening datafile: %s\n", datafile);goto end; | 
 | } | } | 
 |  |  | 
 | n= lastobs; | n= lastobs; | 
| Line 4614  int main(int argc, char *argv[]) | Line 4881  int main(int argc, char *argv[]) | 
 |  |  | 
 | cutv(stra, strb,line,' '); | cutv(stra, strb,line,' '); | 
 | errno=0; | errno=0; | 
| lval=strtol(strb,&endptr,10); | dval=strtod(strb,&endptr); | 
 | if( strb[0]=='\0' || (*endptr != '\0')){ | if( strb[0]=='\0' || (*endptr != '\0')){ | 
| printf("Error reading data around '%d' at line number %ld %s for individual %d\nShould be a weight.  Exiting.\n",lval, i,line,linei); | printf("Error reading data around '%f' at line number %ld, \"%s\" for individual %d\nShould be a weight.  Exiting.\n",dval, i,line,linei); | 
 | exit(1); | exit(1); | 
 | } | } | 
| weight[i]=(double)(lval); | weight[i]=dval; | 
 | strcpy(line,stra); | strcpy(line,stra); | 
 |  |  | 
 | for (j=ncovcol;j>=1;j--){ | for (j=ncovcol;j>=1;j--){ | 
| Line 4631  int main(int argc, char *argv[]) | Line 4898  int main(int argc, char *argv[]) | 
 | exit(1); | exit(1); | 
 | } | } | 
 | if(lval <-1 || lval >1){ | if(lval <-1 || lval >1){ | 
| printf("Error reading data around '%d' at line number %ld %s for individual %d, '%s'\nShould be a value of the %d covar (meaning 0 for the reference or 1. IMaCh does not build design variables, do it your self).  Exiting.\n",lval,linei, i,line,j); | printf("Error reading data around '%d' at line number %ld for individual %d, '%s'\n \ | 
|  | Should be a value of %d(nth) covariate (0 should be the value for the reference and 1\n \ | 
|  | for the alternative. IMaCh does not build design variables automatically, do it yourself.\n \ | 
|  | For example, for multinomial values like 1, 2 and 3,\n \ | 
|  | build V1=0 V2=0 for the reference value (1),\n \ | 
|  | V1=1 V2=0 for (2) \n \ | 
|  | and V1=0 V2=1 for (3). V1=1 V2=1 should not exist and the corresponding\n \ | 
|  | output of IMaCh is often meaningless.\n \ | 
|  | Exiting.\n",lval,linei, i,line,j); | 
 | exit(1); | exit(1); | 
 | } | } | 
 | covar[j][i]=(double)(lval); | covar[j][i]=(double)(lval); | 
| Line 4927  int main(int argc, char *argv[]) | Line 5202  int main(int argc, char *argv[]) | 
 | printf("Problem with %s \n",optionfilehtmcov), exit(0); | printf("Problem with %s \n",optionfilehtmcov), exit(0); | 
 | } | } | 
 | else{ | else{ | 
| fprintf(fichtmcov,"<body>\n<title>IMaCh Cov %s</title>\n <font size=\"2\">%s <br> %s</font> \ | fprintf(fichtmcov,"<html><head>\n<title>IMaCh Cov %s</title></head>\n <body><font size=\"2\">%s <br> %s</font> \ | 
 | <hr size=\"2\" color=\"#EC5E5E\"> \n\ | <hr size=\"2\" color=\"#EC5E5E\"> \n\ | 
 | Title=%s <br>Datafile=%s Firstpass=%d Lastpass=%d Stepm=%d Weight=%d Model=%s<br>\n",\ | Title=%s <br>Datafile=%s Firstpass=%d Lastpass=%d Stepm=%d Weight=%d Model=%s<br>\n",\ | 
| fileres,version,fullversion,title,datafile,firstpass,lastpass,stepm, weightopt, model); | optionfilehtmcov,version,fullversion,title,datafile,firstpass,lastpass,stepm, weightopt, model); | 
 | } | } | 
 |  |  | 
| fprintf(fichtm,"<body>\n<title>IMaCh %s</title>\n <font size=\"2\">%s <br> %s</font> \ | fprintf(fichtm,"<html><head>\n<title>IMaCh %s</title></head>\n <body><font size=\"2\">%s <br> %s</font> \ | 
 | <hr size=\"2\" color=\"#EC5E5E\"> \n\ | <hr size=\"2\" color=\"#EC5E5E\"> \n\ | 
 | Title=%s <br>Datafile=%s Firstpass=%d Lastpass=%d Stepm=%d Weight=%d Model=%s<br>\n\ | Title=%s <br>Datafile=%s Firstpass=%d Lastpass=%d Stepm=%d Weight=%d Model=%s<br>\n\ | 
 | \n\ | \n\ | 
 | <hr  size=\"2\" color=\"#EC5E5E\">\ | <hr  size=\"2\" color=\"#EC5E5E\">\ | 
 | <ul><li><h4>Parameter files</h4>\n\ | <ul><li><h4>Parameter files</h4>\n\ | 
 |  | - Parameter file: <a href=\"%s.%s\">%s.%s</a><br>\n\ | 
 | - Copy of the parameter file: <a href=\"o%s\">o%s</a><br>\n\ | - Copy of the parameter file: <a href=\"o%s\">o%s</a><br>\n\ | 
 | - Log file of the run: <a href=\"%s\">%s</a><br>\n\ | - Log file of the run: <a href=\"%s\">%s</a><br>\n\ | 
 | - Gnuplot file name: <a href=\"%s\">%s</a><br>\n\ | - Gnuplot file name: <a href=\"%s\">%s</a><br>\n\ | 
 | - Date and time at start: %s</ul>\n",\ | - Date and time at start: %s</ul>\n",\ | 
| fileres,version,fullversion,title,datafile,firstpass,lastpass,stepm, weightopt, model,\ | optionfilehtm,version,fullversion,title,datafile,firstpass,lastpass,stepm, weightopt, model,\ | 
|  | optionfilefiname,optionfilext,optionfilefiname,optionfilext,\ | 
 | fileres,fileres,\ | fileres,fileres,\ | 
 | filelog,filelog,optionfilegnuplot,optionfilegnuplot,strstart); | filelog,filelog,optionfilegnuplot,optionfilegnuplot,strstart); | 
 | fflush(fichtm); | fflush(fichtm); | 
| Line 5082  Interval (in months) between two waves: | Line 5359  Interval (in months) between two waves: | 
 | printf("%d %.0lf %lf %.0lf %.0lf %.0lf %lf\n",k,lsurv[k],p[1]*exp(p[2]*(k-agegomp)),(p[1]*exp(p[2]*(k-agegomp)))*lsurv[k],lpop[k],tpop[k],tpop[k]/lsurv[k]); | printf("%d %.0lf %lf %.0lf %.0lf %.0lf %lf\n",k,lsurv[k],p[1]*exp(p[2]*(k-agegomp)),(p[1]*exp(p[2]*(k-agegomp)))*lsurv[k],lpop[k],tpop[k],tpop[k]/lsurv[k]); | 
 |  |  | 
 |  |  | 
| replace_back_to_slash(pathc,path); /* Even gnuplot wants a / */ | replace_back_to_slash(pathc,pathcd); /* Even gnuplot wants a / */ | 
 | printinggnuplotmort(fileres, optionfilefiname,ageminpar,agemaxpar,fage, pathc,p); | printinggnuplotmort(fileres, optionfilefiname,ageminpar,agemaxpar,fage, pathc,p); | 
 |  |  | 
 | printinghtmlmort(fileres,title,datafile, firstpass, lastpass, \ | printinghtmlmort(fileres,title,datafile, firstpass, lastpass, \ | 
| Line 5125  Interval (in months) between two waves: | Line 5402  Interval (in months) between two waves: | 
 | fprintf(ficlog,"%d%d ",i,k); | fprintf(ficlog,"%d%d ",i,k); | 
 | fprintf(ficres,"%1d%1d ",i,k); | fprintf(ficres,"%1d%1d ",i,k); | 
 | for(j=1; j <=ncovmodel; j++){ | for(j=1; j <=ncovmodel; j++){ | 
| printf("%f ",p[jk]); | printf("%lf ",p[jk]); | 
| fprintf(ficlog,"%f ",p[jk]); | fprintf(ficlog,"%lf ",p[jk]); | 
| fprintf(ficres,"%f ",p[jk]); | fprintf(ficres,"%lf ",p[jk]); | 
 | jk++; | jk++; | 
 | } | } | 
 | printf("\n"); | printf("\n"); | 
| Line 5319  Interval (in months) between two waves: | Line 5596  Interval (in months) between two waves: | 
 | /*  freqsummary(fileres, agemin, agemax, s, agev, nlstate, imx,Tvaraff,nbcode, ncodemax,mint,anint);*/ | /*  freqsummary(fileres, agemin, agemax, s, agev, nlstate, imx,Tvaraff,nbcode, ncodemax,mint,anint);*/ | 
 | /*,dateprev1,dateprev2,jprev1, mprev1,anprev1,jprev2, mprev2,anprev2);*/ | /*,dateprev1,dateprev2,jprev1, mprev1,anprev1,jprev2, mprev2,anprev2);*/ | 
 |  |  | 
| replace_back_to_slash(pathc,path); /* Even gnuplot wants a / */ | replace_back_to_slash(pathc,pathcd); /* Even gnuplot wants a / */ | 
 | printinggnuplot(fileres, optionfilefiname,ageminpar,agemaxpar,fage, pathc,p); | printinggnuplot(fileres, optionfilefiname,ageminpar,agemaxpar,fage, pathc,p); | 
 |  |  | 
 | printinghtml(fileres,title,datafile, firstpass, lastpass, stepm, weightopt,\ | printinghtml(fileres,title,datafile, firstpass, lastpass, stepm, weightopt,\ | 
| Line 5341  Interval (in months) between two waves: | Line 5618  Interval (in months) between two waves: | 
 | fclose(ficres); | fclose(ficres); | 
 |  |  | 
 |  |  | 
| /*--------------- Prevalence limit  (stable prevalence) --------------*/ | /*--------------- Prevalence limit  (period or stable prevalence) --------------*/ | 
 |  |  | 
 | strcpy(filerespl,"pl"); | strcpy(filerespl,"pl"); | 
 | strcat(filerespl,fileres); | strcat(filerespl,fileres); | 
 | if((ficrespl=fopen(filerespl,"w"))==NULL) { | if((ficrespl=fopen(filerespl,"w"))==NULL) { | 
| printf("Problem with stable prevalence resultfile: %s\n", filerespl);goto end; | printf("Problem with period (stable) prevalence resultfile: %s\n", filerespl);goto end; | 
| fprintf(ficlog,"Problem with stable prevalence resultfile: %s\n", filerespl);goto end; | fprintf(ficlog,"Problem with period (stable) prevalence resultfile: %s\n", filerespl);goto end; | 
 | } | } | 
| printf("Computing stable prevalence: result on file '%s' \n", filerespl); | printf("Computing period (stable) prevalence: result on file '%s' \n", filerespl); | 
| fprintf(ficlog,"Computing stable prevalence: result on file '%s' \n", filerespl); | fprintf(ficlog,"Computing period (stable) prevalence: result on file '%s' \n", filerespl); | 
| fprintf(ficrespl, "#Local time at start: %s", strstart); | pstamp(ficrespl); | 
| fprintf(ficrespl,"#Stable prevalence \n"); | fprintf(ficrespl,"# Period (stable) prevalence \n"); | 
 | fprintf(ficrespl,"#Age "); | fprintf(ficrespl,"#Age "); | 
 | for(i=1; i<=nlstate;i++) fprintf(ficrespl,"%d-%d ",i,i); | for(i=1; i<=nlstate;i++) fprintf(ficrespl,"%d-%d ",i,i); | 
 | fprintf(ficrespl,"\n"); | fprintf(ficrespl,"\n"); | 
| Line 5412  Interval (in months) between two waves: | Line 5689  Interval (in months) between two waves: | 
 | hstepm=hstepm/stepm; /* Typically 2 years, = 2/6 months = 4 */ | hstepm=hstepm/stepm; /* Typically 2 years, = 2/6 months = 4 */ | 
 |  |  | 
 | /* hstepm=1;   aff par mois*/ | /* hstepm=1;   aff par mois*/ | 
| fprintf(ficrespij, "#Local time at start: %s", strstart); | pstamp(ficrespij); | 
 | fprintf(ficrespij,"#****** h Pij x Probability to be in state j at age x+h being in i at x "); | fprintf(ficrespij,"#****** h Pij x Probability to be in state j at age x+h being in i at x "); | 
 | for(cptcov=1,k=0;cptcov<=i1;cptcov++){ | for(cptcov=1,k=0;cptcov<=i1;cptcov++){ | 
 | for(cptcod=1;cptcod<=ncodemax[cptcov];cptcod++){ | for(cptcod=1;cptcod<=ncodemax[cptcov];cptcod++){ | 
| Line 5474  Interval (in months) between two waves: | Line 5751  Interval (in months) between two waves: | 
 | } | } | 
 |  |  | 
 |  |  | 
| /*---------- Health expectancies and variances ------------*/ | /* Computes prevalence between agemin (i.e minimal age computed) and no more ageminpar */ | 
 |  |  | 
| strcpy(filerest,"t"); | prevalence(probs, agemin, agemax, s, agev, nlstate, imx, Tvar, nbcode, ncodemax, mint, anint, dateprev1, dateprev2, firstpass, lastpass); | 
| strcat(filerest,fileres); | /*  printf("ageminpar=%f, agemax=%f, s[lastpass][imx]=%d, agev[lastpass][imx]=%f, nlstate=%d, imx=%d,  mint[lastpass][imx]=%f, anint[lastpass][imx]=%f,dateprev1=%f, dateprev2=%f, firstpass=%d, lastpass=%d\n",\ | 
| if((ficrest=fopen(filerest,"w"))==NULL) { | ageminpar, agemax, s[lastpass][imx], agev[lastpass][imx], nlstate, imx, mint[lastpass][imx],anint[lastpass][imx], dateprev1, dateprev2, firstpass, lastpass); | 
| printf("Problem with total LE resultfile: %s\n", filerest);goto end; | */ | 
| fprintf(ficlog,"Problem with total LE resultfile: %s\n", filerest);goto end; |  | 
|  | if (mobilav!=0) { | 
|  | mobaverage= ma3x(1, AGESUP,1,NCOVMAX, 1,NCOVMAX); | 
|  | if (movingaverage(probs, bage, fage, mobaverage,mobilav)!=0){ | 
|  | fprintf(ficlog," Error in movingaverage mobilav=%d\n",mobilav); | 
|  | printf(" Error in movingaverage mobilav=%d\n",mobilav); | 
|  | } | 
 | } | } | 
 | printf("Computing Total LEs with variances: file '%s' \n", filerest); |  | 
 | fprintf(ficlog,"Computing Total LEs with variances: file '%s' \n", filerest); |  | 
 |  |  | 
 |  |  | 
 |  | /*---------- Health expectancies, no variances ------------*/ | 
 |  |  | 
 | strcpy(filerese,"e"); | strcpy(filerese,"e"); | 
 | strcat(filerese,fileres); | strcat(filerese,fileres); | 
 | if((ficreseij=fopen(filerese,"w"))==NULL) { | if((ficreseij=fopen(filerese,"w"))==NULL) { | 
| Line 5494  Interval (in months) between two waves: | Line 5777  Interval (in months) between two waves: | 
 | } | } | 
 | printf("Computing Health Expectancies: result on file '%s' \n", filerese); | printf("Computing Health Expectancies: result on file '%s' \n", filerese); | 
 | fprintf(ficlog,"Computing Health Expectancies: result on file '%s' \n", filerese); | fprintf(ficlog,"Computing Health Expectancies: result on file '%s' \n", filerese); | 
 |  | for(cptcov=1,k=0;cptcov<=i1;cptcov++){ | 
 |  | for(cptcod=1;cptcod<=ncodemax[cptcov];cptcod++){ | 
 |  | k=k+1; | 
 |  | fprintf(ficreseij,"\n#****** "); | 
 |  | for(j=1;j<=cptcoveff;j++) { | 
 |  | fprintf(ficreseij,"V%d=%d ",Tvaraff[j],nbcode[Tvaraff[j]][codtab[k][j]]); | 
 |  | } | 
 |  | fprintf(ficreseij,"******\n"); | 
 |  |  | 
 |  | eij=ma3x(1,nlstate,1,nlstate,(int) bage, (int) fage); | 
 |  | oldm=oldms;savm=savms; | 
 |  | evsij(eij, p, nlstate, stepm, (int) bage, (int)fage, oldm, savm, k, estepm, strstart); | 
 |  |  | 
 |  | free_ma3x(eij,1,nlstate,1,nlstate,(int) bage, (int)fage); | 
 |  | } | 
 |  | } | 
 |  | fclose(ficreseij); | 
 |  |  | 
 |  |  | 
 |  | /*---------- Health expectancies and variances ------------*/ | 
 |  |  | 
 |  |  | 
 |  | strcpy(filerest,"t"); | 
 |  | strcat(filerest,fileres); | 
 |  | if((ficrest=fopen(filerest,"w"))==NULL) { | 
 |  | printf("Problem with total LE resultfile: %s\n", filerest);goto end; | 
 |  | fprintf(ficlog,"Problem with total LE resultfile: %s\n", filerest);goto end; | 
 |  | } | 
 |  | printf("Computing Total Life expectancies with their standard errors: file '%s' \n", filerest); | 
 |  | fprintf(ficlog,"Computing Total Life expectancies with their standard errors: file '%s' \n", filerest); | 
 |  |  | 
 |  |  | 
 |  | strcpy(fileresstde,"stde"); | 
 |  | strcat(fileresstde,fileres); | 
 |  | if((ficresstdeij=fopen(fileresstde,"w"))==NULL) { | 
 |  | printf("Problem with Health Exp. and std errors resultfile: %s\n", fileresstde); exit(0); | 
 |  | fprintf(ficlog,"Problem with Health Exp. and std errors resultfile: %s\n", fileresstde); exit(0); | 
 |  | } | 
 |  | printf("Computing Health Expectancies and standard errors: result on file '%s' \n", fileresstde); | 
 |  | fprintf(ficlog,"Computing Health Expectancies and standard errors: result on file '%s' \n", fileresstde); | 
 |  |  | 
 |  | strcpy(filerescve,"cve"); | 
 |  | strcat(filerescve,fileres); | 
 |  | if((ficrescveij=fopen(filerescve,"w"))==NULL) { | 
 |  | printf("Problem with Covar. Health Exp. resultfile: %s\n", filerescve); exit(0); | 
 |  | fprintf(ficlog,"Problem with Covar. Health Exp. resultfile: %s\n", filerescve); exit(0); | 
 |  | } | 
 |  | printf("Computing Covar. of Health Expectancies: result on file '%s' \n", filerescve); | 
 |  | fprintf(ficlog,"Computing Covar. of Health Expectancies: result on file '%s' \n", filerescve); | 
 |  |  | 
 | strcpy(fileresv,"v"); | strcpy(fileresv,"v"); | 
 | strcat(fileresv,fileres); | strcat(fileresv,fileres); | 
| Line 5504  Interval (in months) between two waves: | Line 5836  Interval (in months) between two waves: | 
 | printf("Computing Variance-covariance of DFLEs: file '%s' \n", fileresv); | printf("Computing Variance-covariance of DFLEs: file '%s' \n", fileresv); | 
 | fprintf(ficlog,"Computing Variance-covariance of DFLEs: file '%s' \n", fileresv); | fprintf(ficlog,"Computing Variance-covariance of DFLEs: file '%s' \n", fileresv); | 
 |  |  | 
 | /* Computes prevalence between agemin (i.e minimal age computed) and no more ageminpar */ |  | 
 | prevalence(probs, agemin, agemax, s, agev, nlstate, imx, Tvar, nbcode, ncodemax, mint, anint, dateprev1, dateprev2, firstpass, lastpass); |  | 
 | /*  printf("ageminpar=%f, agemax=%f, s[lastpass][imx]=%d, agev[lastpass][imx]=%f, nlstate=%d, imx=%d,  mint[lastpass][imx]=%f, anint[lastpass][imx]=%f,dateprev1=%f, dateprev2=%f, firstpass=%d, lastpass=%d\n",\ |  | 
 | ageminpar, agemax, s[lastpass][imx], agev[lastpass][imx], nlstate, imx, mint[lastpass][imx],anint[lastpass][imx], dateprev1, dateprev2, firstpass, lastpass); |  | 
 | */ |  | 
 |  |  | 
 | if (mobilav!=0) { |  | 
 | mobaverage= ma3x(1, AGESUP,1,NCOVMAX, 1,NCOVMAX); |  | 
 | if (movingaverage(probs, bage, fage, mobaverage,mobilav)!=0){ |  | 
 | fprintf(ficlog," Error in movingaverage mobilav=%d\n",mobilav); |  | 
 | printf(" Error in movingaverage mobilav=%d\n",mobilav); |  | 
 | } |  | 
 | } |  | 
 |  |  | 
 | for(cptcov=1,k=0;cptcov<=i1;cptcov++){ | for(cptcov=1,k=0;cptcov<=i1;cptcov++){ | 
 | for(cptcod=1;cptcod<=ncodemax[cptcov];cptcod++){ | for(cptcod=1;cptcod<=ncodemax[cptcov];cptcod++){ | 
 | k=k+1; | k=k+1; | 
| Line 5526  Interval (in months) between two waves: | Line 5844  Interval (in months) between two waves: | 
 | fprintf(ficrest,"V%d=%d ",Tvaraff[j],nbcode[Tvaraff[j]][codtab[k][j]]); | fprintf(ficrest,"V%d=%d ",Tvaraff[j],nbcode[Tvaraff[j]][codtab[k][j]]); | 
 | fprintf(ficrest,"******\n"); | fprintf(ficrest,"******\n"); | 
 |  |  | 
| fprintf(ficreseij,"\n#****** "); | fprintf(ficresstdeij,"\n#****** "); | 
| for(j=1;j<=cptcoveff;j++) | fprintf(ficrescveij,"\n#****** "); | 
| fprintf(ficreseij,"V%d=%d ",Tvaraff[j],nbcode[Tvaraff[j]][codtab[k][j]]); | for(j=1;j<=cptcoveff;j++) { | 
| fprintf(ficreseij,"******\n"); | fprintf(ficresstdeij,"V%d=%d ",Tvaraff[j],nbcode[Tvaraff[j]][codtab[k][j]]); | 
|  | fprintf(ficrescveij,"V%d=%d ",Tvaraff[j],nbcode[Tvaraff[j]][codtab[k][j]]); | 
|  | } | 
|  | fprintf(ficresstdeij,"******\n"); | 
|  | fprintf(ficrescveij,"******\n"); | 
 |  |  | 
 | fprintf(ficresvij,"\n#****** "); | fprintf(ficresvij,"\n#****** "); | 
 | for(j=1;j<=cptcoveff;j++) | for(j=1;j<=cptcoveff;j++) | 
| Line 5538  Interval (in months) between two waves: | Line 5860  Interval (in months) between two waves: | 
 |  |  | 
 | eij=ma3x(1,nlstate,1,nlstate,(int) bage, (int) fage); | eij=ma3x(1,nlstate,1,nlstate,(int) bage, (int) fage); | 
 | oldm=oldms;savm=savms; | oldm=oldms;savm=savms; | 
| evsij(fileres, eij, p, nlstate, stepm, (int) bage, (int)fage, oldm, savm, k, estepm, delti, matcov, strstart); | cvevsij(eij, p, nlstate, stepm, (int) bage, (int)fage, oldm, savm, k, estepm, delti, matcov, strstart); | 
 |  |  | 
 | vareij=ma3x(1,nlstate,1,nlstate,(int) bage, (int) fage); | vareij=ma3x(1,nlstate,1,nlstate,(int) bage, (int) fage); | 
 | oldm=oldms;savm=savms; | oldm=oldms;savm=savms; | 
| Line 5547  Interval (in months) between two waves: | Line 5869  Interval (in months) between two waves: | 
 | varevsij(optionfilefiname, vareij, matcov, p, delti, nlstate, stepm, (int) bage, (int) fage, oldm, savm, prlim, ftolpl,k, estepm, cptcov,cptcod,popbased,mobilav, strstart); | varevsij(optionfilefiname, vareij, matcov, p, delti, nlstate, stepm, (int) bage, (int) fage, oldm, savm, prlim, ftolpl,k, estepm, cptcov,cptcod,popbased,mobilav, strstart); | 
 | } | } | 
 |  |  | 
| fprintf(ficrest, "#Local time at start: %s", strstart); | pstamp(ficrest); | 
| fprintf(ficrest,"#Total LEs with variances: e.. (std) "); | fprintf(ficrest,"# Total life expectancy with std error and decomposition into time to be expected in each health state\n# Age ( e.. (std) "); | 
 | for (i=1;i<=nlstate;i++) fprintf(ficrest,"e.%d (std) ",i); | for (i=1;i<=nlstate;i++) fprintf(ficrest,"e.%d (std) ",i); | 
 | fprintf(ficrest,"\n"); | fprintf(ficrest,"\n"); | 
 |  |  | 
| Line 5595  Interval (in months) between two waves: | Line 5917  Interval (in months) between two waves: | 
 | free_matrix(mint,1,maxwav,1,n); | free_matrix(mint,1,maxwav,1,n); | 
 | free_ivector(cod,1,n); | free_ivector(cod,1,n); | 
 | free_ivector(tab,1,NCOVMAX); | free_ivector(tab,1,NCOVMAX); | 
| fclose(ficreseij); | fclose(ficresstdeij); | 
|  | fclose(ficrescveij); | 
 | fclose(ficresvij); | fclose(ficresvij); | 
 | fclose(ficrest); | fclose(ficrest); | 
 | fclose(ficpar); | fclose(ficpar); | 
 |  |  | 
| /*------- Variance of stable prevalence------*/ | /*------- Variance of period (stable) prevalence------*/ | 
 |  |  | 
 | strcpy(fileresvpl,"vpl"); | strcpy(fileresvpl,"vpl"); | 
 | strcat(fileresvpl,fileres); | strcat(fileresvpl,fileres); | 
 | if((ficresvpl=fopen(fileresvpl,"w"))==NULL) { | if((ficresvpl=fopen(fileresvpl,"w"))==NULL) { | 
| printf("Problem with variance of stable prevalence  resultfile: %s\n", fileresvpl); | printf("Problem with variance of period (stable) prevalence  resultfile: %s\n", fileresvpl); | 
 | exit(0); | exit(0); | 
 | } | } | 
| printf("Computing Variance-covariance of stable prevalence: file '%s' \n", fileresvpl); | printf("Computing Variance-covariance of period (stable) prevalence: file '%s' \n", fileresvpl); | 
 |  |  | 
 | for(cptcov=1,k=0;cptcov<=i1;cptcov++){ | for(cptcov=1,k=0;cptcov<=i1;cptcov++){ | 
 | for(cptcod=1;cptcod<=ncodemax[cptcov];cptcod++){ | for(cptcod=1;cptcod<=ncodemax[cptcov];cptcod++){ | 
| Line 5679  Interval (in months) between two waves: | Line 6002  Interval (in months) between two waves: | 
 | fprintf(ficlog,"Total time was %d Sec.\n", end_time.tv_sec -start_time.tv_sec); | fprintf(ficlog,"Total time was %d Sec.\n", end_time.tv_sec -start_time.tv_sec); | 
 | /*  printf("Total time was %d uSec.\n", total_usecs);*/ | /*  printf("Total time was %d uSec.\n", total_usecs);*/ | 
 | /*   if(fileappend(fichtm,optionfilehtm)){ */ | /*   if(fileappend(fichtm,optionfilehtm)){ */ | 
| fprintf(fichtm,"<br>Local time at start %s<br>Local time at end   %s<br>",strstart, strtend); | fprintf(fichtm,"<br>Local time at start %s<br>Local time at end   %s<br>\n</body></html>",strstart, strtend); | 
 | fclose(fichtm); | fclose(fichtm); | 
 |  | fprintf(fichtmcov,"<br>Local time at start %s<br>Local time at end   %s<br>\n</body></html>",strstart, strtend); | 
 | fclose(fichtmcov); | fclose(fichtmcov); | 
 | fclose(ficgp); | fclose(ficgp); | 
 | fclose(ficlog); | fclose(ficlog); | 
 | /*------ End -----------*/ | /*------ End -----------*/ | 
 |  |  | 
| chdir(path); |  | 
|  | printf("Before Current directory %s!\n",pathcd); | 
|  | if(chdir(pathcd) != 0) | 
|  | printf("Can't move to directory %s!\n",path); | 
|  | if(getcwd(pathcd,MAXLINE) > 0) | 
|  | printf("Current directory %s!\n",pathcd); | 
 | /*strcat(plotcmd,CHARSEPARATOR);*/ | /*strcat(plotcmd,CHARSEPARATOR);*/ | 
 | sprintf(plotcmd,"gnuplot"); | sprintf(plotcmd,"gnuplot"); | 
 | #ifndef UNIX | #ifndef UNIX |