--- imach/src/imach.c 2016/09/07 14:10:18 1.248
+++ imach/src/imach.c 2016/09/08 16:07:27 1.250
@@ -1,6 +1,12 @@
-/* $Id: imach.c,v 1.248 2016/09/07 14:10:18 brouard Exp $
+/* $Id: imach.c,v 1.250 2016/09/08 16:07:27 brouard Exp $
$State: Exp $
$Log: imach.c,v $
+ Revision 1.250 2016/09/08 16:07:27 brouard
+ Summary: continue
+
+ Revision 1.249 2016/09/07 17:14:18 brouard
+ Summary: Starting values from frequencies
+
Revision 1.248 2016/09/07 14:10:18 brouard
*** empty log message ***
@@ -946,12 +952,12 @@ typedef struct {
#define ODIRSEPARATOR '\\'
#endif
-/* $Id: imach.c,v 1.248 2016/09/07 14:10:18 brouard Exp $ */
+/* $Id: imach.c,v 1.250 2016/09/08 16:07:27 brouard Exp $ */
/* $State: Exp $ */
#include "version.h"
char version[]=__IMACH_VERSION__;
char copyright[]="February 2016,INED-EUROREVES-Institut de longevite-Japan Society for the Promotion of Science (Grant-in-Aid for Scientific Research 25293121), Intel Software 2015-2018";
-char fullversion[]="$Revision: 1.248 $ $Date: 2016/09/07 14:10:18 $";
+char fullversion[]="$Revision: 1.250 $ $Date: 2016/09/08 16:07:27 $";
char strstart[80];
char optionfilext[10], optionfilefiname[FILENAMELENGTH];
int erreur=0, nberr=0, nbwarn=0; /* Error number, number of errors number of warnings */
@@ -4180,12 +4186,12 @@ void pstamp(FILE *fichier)
}
/************ Frequencies ********************/
-void freqsummary(char fileres[], int iagemin, int iagemax, int **s, double **agev, int nlstate, int imx, \
+void freqsummary(char fileres[], double p[], int iagemin, int iagemax, int **s, double **agev, int nlstate, int imx, \
int *Tvaraff, int *invalidvarcomb, int **nbcode, int *ncodemax,double **mint,double **anint, char strstart[], \
int firstpass, int lastpass, int stepm, int weightopt, char model[])
-{ /* Some frequencies */
+{ /* Some frequencies as well as proposing some starting values */
- int i, m, jk, j1, bool, z1,j, k, iv;
+ int i, m, jk, j1, bool, z1,j, k, iv, jj=0;
int iind=0, iage=0;
int mi; /* Effective wave */
int first;
@@ -4249,7 +4255,6 @@ Title=%s
Datafile=%s Firstpass=%d La
j=cptcoveff; /* Only dummy covariates of the model */
if (cptcovn<1) {j=1;ncodemax[1]=1;}
- first=1;
/* Detects if a combination j1 is empty: for a multinomial variable like 3 education levels:
reference=low_education V1=0,V2=0
@@ -4257,7 +4262,11 @@ Title=%s
Datafile=%s Firstpass=%d La
high_educ V1=0 V2=1
Then V1=1 and V2=1 is a noisy combination that we want to exclude for the list 2**cptcoveff
*/
-
+ dateintsum=0;
+ k2cpt=0;
+
+ for (j = 0; j <= cptcoveff; j+=cptcoveff){
+ first=1;
for (j1 = 1; j1 <= (int) pow(2,j); j1++){ /* Loop on covariates combination in order of model, excluding quantitatives V4=0, V3=0 for example, fixed or varying covariates */
posproptt=0.;
/*printf("cptcoveff=%d Tvaraff=%d", cptcoveff,Tvaraff[1]);
@@ -4280,25 +4289,27 @@ Title=%s
Datafile=%s Firstpass=%d La
/* } */
/* } */
- dateintsum=0;
- k2cpt=0;
+ /* dateintsum=0; */
+ /* k2cpt=0; */
+
/* For that combination of covariate j1, we count and print the frequencies in one pass */
for (iind=1; iind<=imx; iind++) { /* For each individual iind */
bool=1;
+ if(j !=0){
if(anyvaryingduminmodel==0){ /* If All fixed covariates */
if (cptcoveff >0) { /* Filter is here: Must be looked at for model=V1+V2+V3+V4 */
/* for (z1=1; z1<= nqfveff; z1++) { */
/* meanq[z1]+=coqvar[Tvar[z1]][iind]; /\* Computes mean of quantitative with selected filter *\/ */
/* } */
- for (z1=1; z1<=cptcoveff; z1++) {
+ for (z1=1; z1<=cptcoveff; z1++) { /* loops on covariates in the model */
/* if(Tvaraff[z1] ==-20){ */
/* /\* sumnew+=cotvar[mw[mi][iind]][z1][iind]; *\/ */
/* }else if(Tvaraff[z1] ==-10){ */
/* /\* sumnew+=coqvar[z1][iind]; *\/ */
/* }else */
- if (covar[Tvaraff[z1]][iind]!= nbcode[Tvaraff[z1]][codtabm(j1,z1)]){
- /* Tests if this individual iind responded to j1 (V4=1 V3=0) */
- bool=0;
+ if (covar[Tvaraff[z1]][iind]!= nbcode[Tvaraff[z1]][codtabm(j1,z1)]){ /* for combination j1 of covariates */
+ /* Tests if this individual iind responded to combination j1 (V4=1 V3=0) */
+ bool=0; /* bool should be equal to 1 to be selected, one covariate value failed */
/* printf("bool=%d i=%d, z1=%d, Tvaraff[%d]=%d, covar[Tvarff][%d]=%2f, codtabm(%d,%d)=%d, nbcode[Tvaraff][codtabm(%d,%d)=%d, j1=%d\n",
bool,i,z1, z1, Tvaraff[z1],i,covar[Tvaraff[z1]][i],j1,z1,codtabm(j1,z1),
j1,z1,nbcode[Tvaraff[z1]][codtabm(j1,z1)],j1);*/
@@ -4307,16 +4318,20 @@ Title=%s
Datafile=%s Firstpass=%d La
} /* end z1 */
} /* cptcovn > 0 */
} /* end any */
+ }/* end j==0 */
if (bool==1){ /* We selected an individual iind satisfying combination j1 or all fixed */
/* for(m=firstpass; m<=lastpass; m++){ */
for(mi=1; miDatafile=%s Firstpass=%d La
}
}
}/* Some are varying covariates, we tried to speed up if all fixed covariates in the model, avoiding waves loop */
+ } /* end j==0 */
/* bool =0 we keep that guy which corresponds to the combination of dummy values */
if(bool==1){
/* dh[m][iind] or dh[mw[mi][iind]][iind] is the delay between two effective (mi) waves m=mw[mi][iind]
@@ -4343,16 +4359,20 @@ Title=%s
Datafile=%s Firstpass=%d La
if(s[m][iind]==-1)
printf(" num=%ld m=%d, iind=%d s1=%d s2=%d agev at m=%d agebegin=%.2f ageend=%.2f, agemed=%d\n", num[iind], m, iind,s[m][iind],s[m+1][iind], (int)agev[m][iind],agebegin, ageend, (int)((agebegin+ageend)/2.));
freq[s[m][iind]][s[m+1][iind]][(int)agev[m][iind]] += weight[iind]; /* At age of beginning of transition, where status is known */
+ /* if((int)agev[m][iind] == 55) */
+ /* printf("j=%d, j1=%d Age %d, iind=%d, num=%09ld m=%d\n",j,j1,(int)agev[m][iind],iind, num[iind],m); */
/* freq[s[m][iind]][s[m+1][iind]][(int)((agebegin+ageend)/2.)] += weight[iind]; */
freq[s[m][iind]][s[m+1][iind]][iagemax+3] += weight[iind]; /* Total is in iagemax+3 *//* At age of beginning of transition, where status is known */
}
} /* end if between passes */
- if ((agev[m][iind]>1) && (agev[m][iind]< (iagemax+3)) && (anint[m][iind]!=9999) && (mint[m][iind]!=99)) {
- dateintsum=dateintsum+k2;
+ if ((agev[m][iind]>1) && (agev[m][iind]< (iagemax+3)) && (anint[m][iind]!=9999) && (mint[m][iind]!=99) && (j==0)) {
+ dateintsum=dateintsum+k2; /* on all covariates ?*/
k2cpt++;
/* printf("iind=%ld dateintmean = %lf dateintsum=%lf k2cpt=%lf k2=%lf\n",iind, dateintsum/k2cpt, dateintsum,k2cpt, k2); */
}
- } /* end bool 2 */
+ }else{
+ bool=1;
+ }/* end bool 2 */
} /* end m */
} /* end bool */
} /* end iind = 1 to imx */
@@ -4362,7 +4382,7 @@ Title=%s
Datafile=%s Firstpass=%d La
/* fprintf(ficresp, "#Count between %.lf/%.lf/%.lf and %.lf/%.lf/%.lf\n",jprev1, mprev1,anprev1,jprev2, mprev2,anprev2);*/
pstamp(ficresp);
- if (cptcoveff>0){
+ if (cptcoveff>0 && j!=0){
fprintf(ficresp, "\n#********** Variable ");
fprintf(ficresphtm, "\n
********** Variable ");
fprintf(ficresphtmfr, "\n
********** Variable ");
@@ -4528,6 +4548,45 @@ Title=%s
Datafile=%s Firstpass=%d La
}
fprintf(ficresphtmfr,"\n");
} /* end selected combination of covariate j1 */
+ if(j==0){ /* We can estimate starting values from the occurences in each case */
+ printf("#Freqsummary\n");
+ fprintf(ficlog,"\n");
+ for(i=1,jk=1; i <=nlstate; i++){
+ for(k=1; k <=(nlstate+ndeath); k++){
+ if (k != i) {
+ printf("%d%d ",i,k);
+ fprintf(ficlog,"%d%d ",i,k);
+ for(jj=1; jj <=ncovmodel; jj++){
+ if(jj==1){
+ printf("%12.7f ln(%12.1f/%12.1f)= %12.7f ",p[jk],freq[i][k][iagemax+3],freq[i][i][iagemax+3], log(freq[i][k][iagemax+3]/freq[i][i][iagemax+3]));
+ fprintf(ficlog,"%12.7f ln(%12.1f/%12.1f)= %12.7f ",p[jk],freq[i][k][iagemax+3],freq[i][i][iagemax+3], log(freq[i][k][iagemax+3]/freq[i][i][iagemax+3]));
+ }
+ /* printf("%12.7f )", param[i][jj][k]); */
+ /* fprintf(ficlog,"%12.7f )", param[i][jj][k]); */
+ jk++;
+ }
+ printf("\n");
+ fprintf(ficlog,"\n");
+ }
+ }
+ }
+ printf("#Freqsummary\n");
+ fprintf(ficlog,"\n");
+ for(jk=-1; jk <=nlstate+ndeath; jk++){
+ for(m=-1; m <=nlstate+ndeath; m++){
+ /* param[i]|j][k]= freq[jk][m][iagemax+3] */
+ printf(" %d%d=%.0f",jk,m,freq[jk][m][iagemax+3]);
+ fprintf(ficlog," %d%d=%.0f",jk,m,freq[jk][m][iagemax+3]);
+ /* if(freq[jk][m][iage] !=0 ) { /\* minimizing output *\/ */
+ /* printf(" %d%d=%.0f",jk,m,freq[jk][m][iagemax+3]); */
+ /* fprintf(ficlog," %d%d=%.0f",jk,m,freq[jk][m][iagemax+3]); */
+ /* } */
+ }
+ } /* end loop jk */
+ printf("\n");
+ fprintf(ficlog,"\n");
+ } /* if j=0 */
+ } /* end j */
dateintmean=dateintsum/k2cpt;
fclose(ficresp);
@@ -10413,7 +10472,7 @@ Title=%s
Datafile=%s Firstpass=%d La
/* Calculates basic frequencies. Computes observed prevalence at single age
and for any valid combination of covariates
and prints on file fileres'p'. */
- freqsummary(fileres, agemin, agemax, s, agev, nlstate, imx, Tvaraff, invalidvarcomb, nbcode, ncodemax,mint,anint,strstart, \
+ freqsummary(fileres, p, agemin, agemax, s, agev, nlstate, imx, Tvaraff, invalidvarcomb, nbcode, ncodemax,mint,anint,strstart, \
firstpass, lastpass, stepm, weightopt, model);
fprintf(fichtm,"\n");