1 /********************************************************************
3 * THIS FILE IS PART OF THE Ogg Vorbis SOFTWARE CODEC SOURCE CODE. *
4 * USE, DISTRIBUTION AND REPRODUCTION OF THIS SOURCE IS GOVERNED BY *
5 * THE GNU PUBLIC LICENSE 2, WHICH IS INCLUDED WITH THIS SOURCE. *
6 * PLEASE READ THESE TERMS DISTRIBUTING. *
8 * THE OggSQUISH SOURCE CODE IS (C) COPYRIGHT 1994-2000 *
9 * by Monty <monty@xiph.org> and The XIPHOPHORUS Company *
10 * http://www.xiph.org/ *
12 ********************************************************************
14 function: window functions
15 last mod: $Id: window.c,v 1.3 1999/12/30 07:26:55 xiphmont Exp $
17 ********************************************************************/
23 /* The 'vorbis window' is sin(sin(x)*sin(x)*2pi) */
25 double *_vorbis_window(int window,int left,int right){
26 double *ret=calloc(window,sizeof(double));
27 int leftbegin=window/4-left/2;
28 int rightbegin=window-window/4-right/2;
32 double x=(i+.5)/left*M_PI/2.;
40 for(i=leftbegin+left;i<rightbegin;i++)
44 double x=(right-i-.5)/right*M_PI/2.;