int main(int argc,char *argv[]){ codebook *b; static_codebook *c; long *lengths; long *hits; int entries=-1,dim=-1,guard=1; FILE *in=NULL; char *line,*name; long j; if(argv[1]==NULL){ fprintf(stderr,"Need a lattice codebook on the command line.\n"); exit(1); } if(argv[2]==NULL){ fprintf(stderr,"Need a codeword data file on the command line.\n"); exit(1); } if(argv[3]!=NULL)guard=0; { char *ptr; char *filename=strdup(argv[1]); b=codebook_load(filename); c=(static_codebook *)(b->c); ptr=strrchr(filename,'.'); if(ptr){ *ptr='\0'; name=strdup(filename); }else{ name=strdup(filename); } } if(c->maptype!=1){ fprintf(stderr,"Provided book is not a latticebook.\n"); exit(1); } entries=b->entries; dim=b->dim; hits=_ogg_malloc(entries*sizeof(long)); lengths=_ogg_calloc(entries,sizeof(long)); for(j=0;j<entries;j++)hits[j]=guard; in=fopen(argv[2],"r"); if(!in){ fprintf(stderr,"Could not open input file %s\n",argv[2]); exit(1); } if(!strrcmp_i(argv[0],"latticetune")){ long lines=0; line=setup_line(in); while(line){ long code; lines++; if(!(lines&0xfff))spinnit("codewords so far...",lines); if(sscanf(line,"%ld",&code)==1) hits[code]++; line=setup_line(in); } } /* now we simply count already collated by-entry data */ if(!strrcmp_i(argv[0],"res0tune") || !strrcmp_i(argv[0],"res1tune")){ line=setup_line(in); while(line){ /* code:hits\n */ /* likely to have multiple listing for each code entry; must accumulate */ char *pos=strchr(line,':'); if(pos){ long code=atol(line); long val=atol(pos+1); hits[code]+=val; } line=setup_line(in); } } fclose(in); /* build the codeword lengths */ build_tree_from_lengths0(entries,hits,lengths); c->lengthlist=lengths; write_codebook(stdout,name,c); { long bins=_book_maptype1_quantvals(c); long i,k,base=c->lengthlist[0]; for(i=0;i<entries;i++) if(c->lengthlist[i]>base)base=c->lengthlist[i]; for(j=0;j<entries;j++){ if(c->lengthlist[j]){ int indexdiv=1; fprintf(stderr,"%4ld: ",j); for(k=0;k<c->dim;k++){ int index= (j/indexdiv)%bins; fprintf(stderr,"%+3.1f,", c->quantlist[index]*_float32_unpack(c->q_delta)+ _float32_unpack(c->q_min)); indexdiv*=bins; } fprintf(stderr,"\t|"); for(k=0;k<base-c->lengthlist[j];k++)fprintf(stderr,"*"); fprintf(stderr,"\n"); } } } fprintf(stderr,"\r " "\nDone.\n"); exit(0); }
int main(int argc, char *argv[]){ char *base; char *infile; int i,j,k,begin,n,subn,guard=1; FILE *file; int maxval=0; int loval=0; if(argc<3)usage(); if(argc==4)guard=0; infile=strdup(argv[1]); base=strdup(infile); if(strrchr(base,'.')) strrchr(base,'.')[0]='\0'; { char *pos=strchr(argv[2],','); char *dpos=strchr(argv[2],'-'); if(dpos){ loval=atoi(argv[2]); maxval=atoi(dpos+1); subn=1; begin=0; }else{ begin=atoi(argv[2]); if(!pos) usage(); else n=atoi(pos+1); pos=strchr(pos+1,','); if(!pos) usage(); else subn=atoi(pos+1); if(n/subn*subn != n){ fprintf(stderr,"n must be divisible by group\n"); exit(1); } } } /* scan the file for maximum value */ file=fopen(infile,"r"); if(!file){ fprintf(stderr,"Could not open file %s\n",infile); if(!maxval) exit(1); else fprintf(stderr," making untrained books.\n"); } if(!maxval){ i=0; while(1){ long v; if(get_next_ivalue(file,&v))break; if(v>maxval)maxval=v; if(!(i++&0xff))spinnit("loading... ",i); } rewind(file); maxval++; } { long vals=pow(maxval,subn); long *hist=_ogg_calloc(vals,sizeof(long)); long *lengths=_ogg_calloc(vals,sizeof(long)); for(j=loval;j<vals;j++)hist[j]=guard; if(file){ reset_next_value(); i/=subn; while(!feof(file)){ long val=getval(file,begin,n,subn,maxval); if(val==-1 || val>=vals)break; hist[val]++; if(!(i--&0xff))spinnit("loading... ",i*subn); } fclose(file); } /* we have the probabilities, build the tree */ fprintf(stderr,"Building tree for %ld entries\n",vals); build_tree_from_lengths0(vals,hist,lengths); /* save the book */ { char *buffer=alloca(strlen(base)+5); strcpy(buffer,base); strcat(buffer,".vqh"); file=fopen(buffer,"w"); if(!file){ fprintf(stderr,"Could not open file %s\n",buffer); exit(1); } } /* first, the static vectors, then the book structure to tie it together. */ /* lengthlist */ fprintf(file,"static const long _huff_lengthlist_%s[] = {\n",base); for(j=0;j<vals;){ fprintf(file,"\t"); for(k=0;k<16 && j<vals;k++,j++) fprintf(file,"%2ld,",lengths[j]); fprintf(file,"\n"); } fprintf(file,"};\n\n"); /* the toplevel book */ fprintf(file,"static const static_codebook _huff_book_%s = {\n",base); fprintf(file,"\t%d, %ld,\n",subn,vals); fprintf(file,"\t(long *)_huff_lengthlist_%s,\n",base); fprintf(file,"\t0, 0, 0, 0, 0,\n"); fprintf(file,"\tNULL,\n"); fprintf(file,"\t0\n};\n\n"); fclose(file); fprintf(stderr,"Done. \n\n"); } exit(0); }