1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- /********************************************************************
- * *
- * THIS FILE IS PART OF THE Ogg Vorbis SOFTWARE CODEC SOURCE CODE. *
- * USE, DISTRIBUTION AND REPRODUCTION OF THIS SOURCE IS GOVERNED BY *
- * THE GNU PUBLIC LICENSE 2, WHICH IS INCLUDED WITH THIS SOURCE. *
- * PLEASE READ THESE TERMS DISTRIBUTING. *
- * *
- * THE OggSQUISH SOURCE CODE IS (C) COPYRIGHT 1994-2000 *
- * by Monty <monty@xiph.org> and The XIPHOPHORUS Company *
- * http://www.xiph.org/ *
- * *
- ********************************************************************
- function: function call to do simple data cascading
- last mod: $Id: cascade.c,v 1.5.4.4 2000/05/04 23:08:10 xiphmont Exp $
- ********************************************************************/
- /* this one outputs residue to stdout. */
- #include <stdlib.h>
- #include <unistd.h>
- #include <math.h>
- #include "vorbis/codebook.h"
- #include "../lib/sharedbook.h"
- #include "bookutil.h"
- /* set up metrics */
- double count=0.;
- void process_preprocess(codebook **bs,char *basename){
- }
- void process_postprocess(codebook **b,char *basename){
- fprintf(stderr,"Done. \n");
- }
- double process_one(codebook *b,double *a,int dim,int step,int addmul,
- double base){
- int j;
- if(b->c->q_sequencep){
- double temp;
- for(j=0;j<dim;j++){
- temp=a[j*step];
- a[j*step]-=base;
- }
- base=temp;
- }
- vorbis_book_besterror(b,a,step,addmul);
-
- return base;
- }
- void process_vector(codebook **bs,int *addmul,int inter,double *a,int n){
- int i,bi=0;
- int booknum=0;
-
- while(*bs){
- double base=0.;
- codebook *b=*bs;
- int dim=b->dim;
-
- if(inter){
- for(i=0;i<n/dim;i++)
- base=process_one(b,a+i,dim,n/dim,addmul[bi],base);
- }else{
- for(i=0;i<=n-dim;i+=dim)
- base=process_one(b,a+i,dim,1,addmul[bi],base);
- }
- bs++;
- booknum++;
- bi++;
- }
- for(i=0;i<n;i++)
- fprintf(stdout,"%f, ",a[i]);
- fprintf(stdout,"\n");
-
- if((long)(count++)%100)spinnit("working.... lines: ",count);
- }
- void process_usage(void){
- fprintf(stderr,
- "usage: vqcascade [-i] +|*<codebook>.vqh [ +|*<codebook.vqh> ]... \n"
- " datafile.vqd [datafile.vqd]...\n\n"
- " data can be taken on stdin. residual error data sent to\n"
- " stdout.\n\n");
- }
|