]> henry.ined.fr Git - .git/commitdiff
Summary: Version 0.99r12
authorN. Brouard <brouard@ined.fr>
Mon, 3 Apr 2017 10:17:47 +0000 (10:17 +0000)
committerN. Brouard <brouard@ined.fr>
Mon, 3 Apr 2017 10:17:47 +0000 (10:17 +0000)
Some cleanings, conformed with updated documentation.

src/imach.c

index 29095b26059cd361072df9badc772198c1a2e866..1a6d8196d2538718bb0c6cc80e84a3d2df057f02 100644 (file)
@@ -1,6 +1,9 @@
 /* $Id$
   $State$
   $Log$
+  Revision 1.257  2017/03/29 16:53:30  brouard
+  Summary: Temp
+
   Revision 1.256  2017/03/27 05:50:23  brouard
   Summary: Temporary
 
@@ -1174,6 +1177,7 @@ int *TvarsQind;
 
 #define MAXRESULTLINES 10
 int nresult=0;
+int parameterline=0; /* # of the parameter (type) line */
 int TKresult[MAXRESULTLINES];
 int Tresult[MAXRESULTLINES][NCOVMAX];/* For dummy variable , value (output) */
 int Tinvresult[MAXRESULTLINES][NCOVMAX];/* For dummy variable , value (output) */
@@ -6372,7 +6376,7 @@ To be simple, these graphs help to understand the significativity of each parame
 void printinghtml(char fileresu[], char title[], char datafile[], int firstpass, \
                  int lastpass, int stepm, int weightopt, char model[],\
                  int imx,int jmin, int jmax, double jmeanint,char rfileres[],\
-                 int popforecast, int prevfcast, int backcast, int estepm , \
+                 int popforecast, int mobilav, int prevfcast, int mobilavproj, int backcast, int estepm , \
                  double jprev1, double mprev1,double anprev1, double dateprev1, \
                  double jprev2, double mprev2,double anprev2, double dateprev2){
   int jj1, k1, i1, cpt, k4, nres;
@@ -6483,8 +6487,8 @@ divided by h: <sub>h</sub>P<sub>ij</sub>/h : <a href=\"%s_%d-3-%d.svg\">%s_%d-3-
      if(prevfcast==1){
        /* Projection of prevalence up to period (stable) prevalence in each health state */
        for(cpt=1; cpt<=nlstate;cpt++){
-        fprintf(fichtm,"<br>\n- Projection of cross-sectional prevalence (estimated with cases observed from %.1f to %.1f) up to period (stable) prevalence in state %d. Or probability to be in state %d being in state (1 to %d) at different ages. <a href=\"%s_%d-%d-%d.svg\">%s_%d-%d-%d.svg</a><br> \
-<img src=\"%s_%d-%d-%d.svg\">", dateprev1, dateprev2, cpt, cpt, nlstate, subdirf2(optionfilefiname,"PROJ_"),cpt,k1,nres,subdirf2(optionfilefiname,"PROJ_"),cpt,k1,nres,subdirf2(optionfilefiname,"PROJ_"),cpt,k1,nres);
+        fprintf(fichtm,"<br>\n- Projection of cross-sectional prevalence (estimated with cases observed from %.1f to %.1f and mobil_average=%d) up to period (stable) prevalence in state %d. Or probability to be in state %d being in state (1 to %d) at different ages. <a href=\"%s_%d-%d-%d.svg\">%s_%d-%d-%d.svg</a><br> \
+<img src=\"%s_%d-%d-%d.svg\">", dateprev1, dateprev2, mobilavproj, cpt, cpt, nlstate, subdirf2(optionfilefiname,"PROJ_"),cpt,k1,nres,subdirf2(optionfilefiname,"PROJ_"),cpt,k1,nres,subdirf2(optionfilefiname,"PROJ_"),cpt,k1,nres);
        }
      }
         
@@ -6572,9 +6576,9 @@ See page 'Matrix of variance-covariance of one-step probabilities' below. \n", r
        }
      }
      for(cpt=1; cpt<=nlstate;cpt++) {
-       fprintf(fichtm,"\n<br>- Observed (cross-sectional) and period (incidence based) \
+       fprintf(fichtm,"\n<br>- Observed (cross-sectional with mov_average=%d) and period (incidence based) \
 prevalence (with 95%% confidence interval) in state (%d): <a href=\"%s_%d-%d-%d.svg\"> %s_%d-%d-%d.svg</a>\n <br>\
-<img src=\"%s_%d-%d-%d.svg\">",cpt,subdirf2(optionfilefiname,"V_"),cpt,k1,nres,subdirf2(optionfilefiname,"V_"),cpt,k1,nres,subdirf2(optionfilefiname,"V_"),cpt,k1,nres);  
+<img src=\"%s_%d-%d-%d.svg\">",mobilav,cpt,subdirf2(optionfilefiname,"V_"),cpt,k1,nres,subdirf2(optionfilefiname,"V_"),cpt,k1,nres,subdirf2(optionfilefiname,"V_"),cpt,k1,nres);  
      }
      fprintf(fichtm,"\n<br>- Total life expectancy by age and \
 health expectancies in states (1) and (2). If popbased=1 the smooth (due to the model) \
@@ -9774,6 +9778,7 @@ int main(int argc, char *argv[])
   int NDIM=2;
   int vpopbased=0;
   int nres=0;
+  int endishere=0;
 
   char ca[32], cb[32];
   /*  FILE *fichtm; *//* Html File */
@@ -11148,11 +11153,9 @@ Please run with mle=-1 to get a correct covariance matrix.\n",ageminpar,agemaxpa
        fprintf(ficlog,"Error: Not 7 (data)parameters in line but %d, for example:begin-prev-date=1/1/1990 end-prev-date=1/6/2004  mov_average=0\n, your line=%s . Probably you are running an older format.\n",num_filled,line);
        goto end;
       }
-    /* fscanf(ficpar,"begin-prev-date=%lf/%lf/%lf end-prev-date=%lf/%lf/%lf mov_average=%d\n",&jprev1, &mprev1,&anprev1,&jprev2, &mprev2,&anprev2,&mobilav); */
       printf("begin-prev-date=%.lf/%.lf/%.lf end-prev-date=%.lf/%.lf/%.lf mov_average=%d\n",jprev1, mprev1,anprev1,jprev2, mprev2,anprev2,mobilav);
       fprintf(ficparo,"begin-prev-date=%.lf/%.lf/%.lf end-prev-date=%.lf/%.lf/%.lf mov_average=%d\n",jprev1, mprev1,anprev1,jprev2, mprev2,anprev2,mobilav);
       fprintf(ficres,"begin-prev-date=%.lf/%.lf/%.lf end-prev-date=%.lf/%.lf/%.lf mov_average=%d\n",jprev1, mprev1,anprev1,jprev2, mprev2,anprev2,mobilav);
-      printf("begin-prev-date=%.lf/%.lf/%.lf end-prev-date=%.lf/%.lf/%.lf mov_average=%d\n",jprev1, mprev1,anprev1,jprev2, mprev2,anprev2,mobilav);
       fprintf(ficlog,"begin-prev-date=%.lf/%.lf/%.lf end-prev-date=%.lf/%.lf/%.lf mov_average=%d\n",jprev1, mprev1,anprev1,jprev2, mprev2,anprev2,mobilav);
     }
 
@@ -11184,125 +11187,92 @@ Please run with mle=-1 to get a correct covariance matrix.\n",ageminpar,agemaxpa
       fprintf(ficres,"pop_based=%d\n",popbased);   
     }
      
-    while(fgets(line, MAXLINE, ficpar)) {
-      /* If line starts with a # it is a comment */
-      if (line[0] == '#') {
-       numlinepar++;
-       fputs(line,stdout);
-       fputs(line,ficparo);
-       fputs(line,ficlog);
-       continue;
-      }else
-       break;
-    }
-   /* while((c=getc(ficpar))=='#' && c!= EOF){ */
-   /*    ungetc(c,ficpar); */
-   /*    fgets(line, MAXLINE, ficpar); */
-   /*    fputs(line,stdout); */
-   /*    fputs(line,ficres); */
-   /*    fputs(line,ficparo); */
-   /*  } */
-   /*  ungetc(c,ficpar); */
-    
-    /* fscanf(ficpar,"prevforecast=%d starting-proj-date=%lf/%lf/%lf final-proj-date=%lf/%lf/%lf mobil_average=%d\n",&prevfcast,&jproj1,&mproj1,&anproj1,&jproj2,&mproj2,&anproj2,&mobilavproj); */
-    if((num_filled=sscanf(line,"prevforecast=%d starting-proj-date=%lf/%lf/%lf final-proj-date=%lf/%lf/%lf mobil_average=%d\n",&prevfcast,&jproj1,&mproj1,&anproj1,&jproj2,&mproj2,&anproj2,&mobilavproj)) !=EOF){
-      if (num_filled != 8) {
-       printf("Error: Not 8 (data)parameters in line but %d, for example:prevforecast=1 starting-proj-date=1/1/1990 final-proj-date=1/1/2000 mobil_average=0\n, your line=%s . Probably you are running an older format.\n",num_filled,line);
-       fprintf(ficlog,"Error: Not 8 (data)parameters in line but %d, for example:prevforecast=1 starting-proj-date=1/1/1990 final-proj-date=1/1/2000 mov_average=0\n, your line=%s . Probably you are running an older format.\n",num_filled,line);
-       goto end;
-      }
-     fprintf(ficparo,"prevforecast=%d starting-proj-date=%.lf/%.lf/%.lf final-proj-date=%.lf/%.lf/%.lf mobil_average=%d\n",prevfcast,jproj1,mproj1,anproj1,jproj2,mproj2,anproj2,mobilavproj);
-     printf("prevforecast=%d starting-proj-date=%.lf/%.lf/%.lf final-proj-date=%.lf/%.lf/%.lf mobil_average=%d\n",prevfcast,jproj1,mproj1,anproj1,jproj2,mproj2,anproj2,mobilavproj);
-     fprintf(ficlog,"prevforecast=%d starting-proj-date=%.lf/%.lf/%.lf final-proj-date=%.lf/%.lf/%.lf mobil_average=%d\n",prevfcast,jproj1,mproj1,anproj1,jproj2,mproj2,anproj2,mobilavproj);
-     fprintf(ficres,"prevforecast=%d starting-proj-date=%.lf/%.lf/%.lf final-proj-date=%.lf/%.lf/%.lf mobil_average=%d\n",prevfcast,jproj1,mproj1,anproj1,jproj2,mproj2,anproj2,mobilavproj);
-    /* day and month of proj2 are not used but only year anproj2.*/
-    }
-     while(fgets(line, MAXLINE, ficpar)) {
-      /* If line starts with a # it is a comment */
-      if (line[0] == '#') {
-       numlinepar++;
-       fputs(line,stdout);
-       fputs(line,ficparo);
-       fputs(line,ficlog);
-       continue;
-      }else
-       break;
-    }
-    /* while((c=getc(ficpar))=='#' && c!= EOF){ */
-    /*   ungetc(c,ficpar); */
-    /*   fgets(line, MAXLINE, ficpar); */
-    /*   fputs(line,stdout); */
-    /*   fputs(line,ficparo); */
-    /*   fputs(line,ficres); */
-    /* } */
-    /* ungetc(c,ficpar); */
-    
-    fscanf(ficpar,"backcast=%d starting-back-date=%lf/%lf/%lf final-back-date=%lf/%lf/%lf mobil_average=%d\n",&backcast,&jback1,&mback1,&anback1,&jback2,&mback2,&anback2,&mobilavproj);
-    if((num_filled=sscanf(line,"backcast=%d starting-back-date=%lf/%lf/%lf final-back-date=%lf/%lf/%lf mobil_average=%d\n",&backcast,&jback1,&mback1,&anback1,&jback2,&mback2,&anback2,&mobilavproj)) !=EOF){
-      if (num_filled != 8) {
-       printf("Error: Not 8 (data)parameters in line but %d, for example:backcast=1 starting-back-date=1/1/1990 finloal-back-date=1/1/1970 mobil_average=1\n, your line=%s . Probably you are running an older format.\n",num_filled,line);
-       fprintf(ficlog,"Error: Not 8 (data)parameters in line but %d, for example:backcast=1 starting-back-date=1/1/1990 finloal-back-date=1/1/1970 mobil_average=1\n, your line=%s . Probably you are running an older format.\n",num_filled,line);
-       goto end;
-      }
-      printf("backcast=%d starting-back-date=%.lf/%.lf/%.lf final-back-date=%.lf/%.lf/%.lf mobil_average=%d\n",backcast,jback1,mback1,anback1,jback2,mback2,anback2,mobilavproj);
-      fprintf(ficparo,"backcast=%d starting-back-date=%.lf/%.lf/%.lf final-back-date=%.lf/%.lf/%.lf mobil_average=%d\n",backcast,jback1,mback1,anback1,jback2,mback2,anback2,mobilavproj);
-      fprintf(ficlog,"backcast=%d starting-back-date=%.lf/%.lf/%.lf final-back-date=%.lf/%.lf/%.lf mobil_average=%d\n",backcast,jback1,mback1,anback1,jback2,mback2,anback2,mobilavproj);
-      fprintf(ficres,"backcast=%d starting-back-date=%.lf/%.lf/%.lf final-back-date=%.lf/%.lf/%.lf mobil_average=%d\n",backcast,jback1,mback1,anback1,jback2,mback2,anback2,mobilavproj);
-    /* day and month of proj2 are not used but only year anproj2.*/
-    }
     /* Results */
     nresult=0;
-    while(fgets(line, MAXLINE, ficpar)) {
-      /* If line starts with a # it is a comment */
-      if (line[0] == '#') {
+    do{
+      if(!fgets(line, MAXLINE, ficpar)){
+       endishere=1;
+       parameterline=14;
+      }else if (line[0] == '#') {
+       /* If line starts with a # it is a comment */
        numlinepar++;
        fputs(line,stdout);
        fputs(line,ficparo);
        fputs(line,ficlog);
-       fputs(line,ficres);
        continue;
-      }else
-       break;
-    }
-    if (!feof(ficpar))
-    while((num_filled=sscanf(line,"result:%[^\n]\n",resultline)) !=EOF){
-      if (num_filled == 0){
-       resultline[0]='\0';
-       printf("Warning %d: no result line should be at minimum 'result: V2=0 V1=1 or result:.\n%s\n", num_filled, line);
-      break;
-      } else if (num_filled != 1){
-       printf("ERROR %d: result line should be at minimum 'result: V2=0 V1=1 or result:.' %s\n",num_filled, line);
-      }
-      nresult++; /* Sum of resultlines */
-      printf("Result %d: result=%s\n",nresult, resultline);
-      if(nresult > MAXRESULTLINES){
-       printf("ERROR: Current version of IMaCh limits the number of resultlines to %d, you used %d\n",MAXRESULTLINES,nresult);
-       fprintf(ficlog,"ERROR: Current version of IMaCh limits the number of resultlines to %d, you used %d\n",MAXRESULTLINES,nresult);
-       goto end;
-      }
-      decoderesult(resultline, nresult); /* Fills TKresult[nresult] combination and Tresult[nresult][k4+1] combination values */
-      fprintf(ficparo,"result: %s\n",resultline);
-      fprintf(ficres,"result: %s\n",resultline);
-      fprintf(ficlog,"result: %s\n",resultline);
-      while(fgets(line, MAXLINE, ficpar)) {
-       /* If line starts with a # it is a comment */
-       if (line[0] == '#') {
-         numlinepar++;
-         fputs(line,stdout);
-         fputs(line,ficparo);
-         fputs(line,ficres);
-         fputs(line,ficlog);
-         continue;
-       }else
-         break;
+      }else if(sscanf(line,"prevforecast=%[^\n]\n",modeltemp))
+       parameterline=11;
+      else if(sscanf(line,"backcast=%[^\n]\n",modeltemp))
+       parameterline=12;
+      else if(sscanf(line,"result:%[^\n]\n",modeltemp))
+       parameterline=13;
+      else{
+       parameterline=14;
       }
-      if (feof(ficpar))
+      switch (parameterline){ 
+      case 11:
+       if((num_filled=sscanf(line,"prevforecast=%d starting-proj-date=%lf/%lf/%lf final-proj-date=%lf/%lf/%lf mobil_average=%d\n",&prevfcast,&jproj1,&mproj1,&anproj1,&jproj2,&mproj2,&anproj2,&mobilavproj)) !=EOF){
+         if (num_filled != 8) {
+           printf("Error: Not 8 (data)parameters in line but %d, for example:prevforecast=1 starting-proj-date=1/1/1990 final-proj-date=1/1/2000 mobil_average=0\n, your line=%s . Probably you are running an older format.\n",num_filled,line);
+           fprintf(ficlog,"Error: Not 8 (data)parameters in line but %d, for example:prevforecast=1 starting-proj-date=1/1/1990 final-proj-date=1/1/2000 mov_average=0\n, your line=%s . Probably you are running an older format.\n",num_filled,line);
+           goto end;
+         }
+         fprintf(ficparo,"prevforecast=%d starting-proj-date=%.lf/%.lf/%.lf final-proj-date=%.lf/%.lf/%.lf mobil_average=%d\n",prevfcast,jproj1,mproj1,anproj1,jproj2,mproj2,anproj2,mobilavproj);
+         printf("prevforecast=%d starting-proj-date=%.lf/%.lf/%.lf final-proj-date=%.lf/%.lf/%.lf mobil_average=%d\n",prevfcast,jproj1,mproj1,anproj1,jproj2,mproj2,anproj2,mobilavproj);
+         fprintf(ficlog,"prevforecast=%d starting-proj-date=%.lf/%.lf/%.lf final-proj-date=%.lf/%.lf/%.lf mobil_average=%d\n",prevfcast,jproj1,mproj1,anproj1,jproj2,mproj2,anproj2,mobilavproj);
+         fprintf(ficres,"prevforecast=%d starting-proj-date=%.lf/%.lf/%.lf final-proj-date=%.lf/%.lf/%.lf mobil_average=%d\n",prevfcast,jproj1,mproj1,anproj1,jproj2,mproj2,anproj2,mobilavproj);
+         /* day and month of proj2 are not used but only year anproj2.*/
+       }
        break;
-      else{ /* Processess output results for this combination of covariate values */
-      }                                   
-    } /* end while */
-
-
+      case 12:
+       /*fscanf(ficpar,"backcast=%d starting-back-date=%lf/%lf/%lf final-back-date=%lf/%lf/%lf mobil_average=%d\n",&backcast,&jback1,&mback1,&anback1,&jback2,&mback2,&anback2,&mobilavproj);*/
+       if((num_filled=sscanf(line,"backcast=%d starting-back-date=%lf/%lf/%lf final-back-date=%lf/%lf/%lf mobil_average=%d\n",&backcast,&jback1,&mback1,&anback1,&jback2,&mback2,&anback2,&mobilavproj)) !=EOF){
+         if (num_filled != 8) {
+           printf("Error: Not 8 (data)parameters in line but %d, for example:backcast=1 starting-back-date=1/1/1990 finloal-back-date=1/1/1970 mobil_average=1\n, your line=%s . Probably you are running an older format.\n",num_filled,line);
+           fprintf(ficlog,"Error: Not 8 (data)parameters in line but %d, for example:backcast=1 starting-back-date=1/1/1990 finloal-back-date=1/1/1970 mobil_average=1\n, your line=%s . Probably you are running an older format.\n",num_filled,line);
+           goto end;
+         }
+         printf("backcast=%d starting-back-date=%.lf/%.lf/%.lf final-back-date=%.lf/%.lf/%.lf mobil_average=%d\n",backcast,jback1,mback1,anback1,jback2,mback2,anback2,mobilavproj);
+         fprintf(ficparo,"backcast=%d starting-back-date=%.lf/%.lf/%.lf final-back-date=%.lf/%.lf/%.lf mobil_average=%d\n",backcast,jback1,mback1,anback1,jback2,mback2,anback2,mobilavproj);
+         fprintf(ficlog,"backcast=%d starting-back-date=%.lf/%.lf/%.lf final-back-date=%.lf/%.lf/%.lf mobil_average=%d\n",backcast,jback1,mback1,anback1,jback2,mback2,anback2,mobilavproj);
+         fprintf(ficres,"backcast=%d starting-back-date=%.lf/%.lf/%.lf final-back-date=%.lf/%.lf/%.lf mobil_average=%d\n",backcast,jback1,mback1,anback1,jback2,mback2,anback2,mobilavproj);
+         /* day and month of proj2 are not used but only year anproj2.*/
+       }
+       break;
+      case 13:
+       if((num_filled=sscanf(line,"result:%[^\n]\n",resultline)) !=EOF){
+         if (num_filled == 0){
+           resultline[0]='\0';
+           printf("Warning %d: no result line! It should be at minimum 'result: V2=0 V1=1 or result:.\n%s\n", num_filled, line);
+           fprintf(ficlog,"Warning %d: no result line! It should be at minimum 'result: V2=0 V1=1 or result:.\n%s\n", num_filled, line);
+           break;
+         } else if (num_filled != 1){
+           printf("ERROR %d: result line! It should be at minimum 'result: V2=0 V1=1 or result:.' %s\n",num_filled, line);
+           fprintf(ficlog,"ERROR %d: result line! It should be at minimum 'result: V2=0 V1=1 or result:.' %s\n",num_filled, line);
+         }
+         nresult++; /* Sum of resultlines */
+         printf("Result %d: result=%s\n",nresult, resultline);
+         if(nresult > MAXRESULTLINES){
+           printf("ERROR: Current version of IMaCh limits the number of resultlines to %d, you used %d\n",MAXRESULTLINES,nresult);
+           fprintf(ficlog,"ERROR: Current version of IMaCh limits the number of resultlines to %d, you used %d\n",MAXRESULTLINES,nresult);
+           goto end;
+         }
+         decoderesult(resultline, nresult); /* Fills TKresult[nresult] combination and Tresult[nresult][k4+1] combination values */
+         fprintf(ficparo,"result: %s\n",resultline);
+         fprintf(ficres,"result: %s\n",resultline);
+         fprintf(ficlog,"result: %s\n",resultline);
+         break;
+       case 14: 
+         if(ncovmodel >2){
+           printf("ERROR: no result line! It should be at minimum 'result: V2=0 V1=1 or result:.' %s\n",line);
+           goto end;
+         }
+       default:
+         nresult=1;
+         decoderesult(".",nresult ); /* No covariate */
+       }
+      } /* End switch parameterline */
+    }while(endishere==0); /* End do */
     
     /* freqsummary(fileres, agemin, agemax, s, agev, nlstate, imx,Tvaraff,nbcode, ncodemax,mint,anint); */
     /* ,dateprev1,dateprev2,jprev1, mprev1,anprev1,jprev2, mprev2,anprev2); */
@@ -11319,7 +11289,7 @@ Please run with mle=-1 to get a correct covariance matrix.\n",ageminpar,agemaxpa
       printinggnuplot(fileresu, optionfilefiname,ageminpar,agemaxpar,fage, prevfcast, backcast, pathc,p);
     }
     printinghtml(fileresu,title,datafile, firstpass, lastpass, stepm, weightopt, \
-                model,imx,jmin,jmax,jmean,rfileres,popforecast,prevfcast,backcast, estepm, \
+                model,imx,jmin,jmax,jmean,rfileres,popforecast,mobilav,prevfcast,mobilavproj,backcast, estepm, \
                 jprev1,mprev1,anprev1,dateprev1,jprev2,mprev2,anprev2,dateprev2);
                
     /*------------ free_vector  -------------*/
@@ -11372,6 +11342,7 @@ Please run with mle=-1 to get a correct covariance matrix.\n",ageminpar,agemaxpa
       mobaverage=mobaverages;
       if (mobilav!=0) {
        printf("Movingaveraging observed prevalence\n");
+       fprintf(ficlog,"Movingaveraging observed prevalence\n");
        if (movingaverage(probs, ageminpar, agemaxpar, mobaverage, mobilav)!=0){
          fprintf(ficlog," Error in movingaverage mobilav=%d\n",mobilav);
          printf(" Error in movingaverage mobilav=%d\n",mobilav);
@@ -11381,6 +11352,7 @@ Please run with mle=-1 to get a correct covariance matrix.\n",ageminpar,agemaxpa
       /* prevalence(probs, ageminpar, agemaxpar, s, agev, nlstate, imx, Tvar, nbcode, ncodemax, mint, anint, dateprev1, dateprev2, firstpass, lastpass); */
       else if (mobilavproj !=0) {
        printf("Movingaveraging projected observed prevalence\n");
+       fprintf(ficlog,"Movingaveraging projected observed prevalence\n");
        if (movingaverage(probs, ageminpar, agemaxpar, mobaverage, mobilavproj)!=0){
          fprintf(ficlog," Error in movingaverage mobilavproj=%d\n",mobilavproj);
          printf(" Error in movingaverage mobilavproj=%d\n",mobilavproj);