|
-
- /*******************************************************************************/
- /* Copyright (C) 2008 Jonathan Moore Liles */
- /* */
- /* This program is free software; you can redistribute it and/or modify it */
- /* under the terms of the GNU General Public License as published by the */
- /* Free Software Foundation; either version 2 of the License, or (at your */
- /* option) any later version. */
- /* */
- /* This program is distributed in the hope that it will be useful, but WITHOUT */
- /* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */
- /* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for */
- /* more details. */
- /* */
- /* You should have received a copy of the GNU General Public License along */
- /* with This program; see the file COPYING. If not,write to the Free Software */
- /* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
- /*******************************************************************************/
-
- #pragma once
-
- #include <stdlib.h>
-
- #include "types.h"
-
- struct Peak {
- float min;
- float max;
-
- float normalization_factor ( void ) const;
-
- };
-
- class Audio_File;
-
- class Peaks
- {
-
- struct peakdata {
-
- int chunksize; /* should always be a power of 2 */
- Peak data[];
-
- };
-
- struct peakbuffer {
-
- size_t size; /* total allocation size */
- size_t len; /* number of peaks */
- nframes_t offset; /* starting sample */
-
- peakdata *buf;
-
- peakbuffer ( )
- {
- size = len = 0;
- }
- };
-
- static peakbuffer _peakbuf;
-
- Audio_File *_clip;
-
- size_t _len;
-
- mutable float _fpp;
-
- int read_peaks ( nframes_t s, nframes_t e, int npeaks, int chunksize ) const;
- int read_source_peaks ( Peak *peaks, nframes_t s, int npeaks, int chunksize ) const;
- int read_source_peaks ( Peak *peaks, int npeaks, int chunksize ) const;
- int read_peakfile_peaks ( Peak *peaks, nframes_t s, int npeaks, int chunksize ) const;
-
- // const char *peakname ( const char *filename ) const;
-
-
- // Peaks ( );
-
- public:
-
- Peaks ( )
- {
- _len = 0;
- _clip = NULL;
- }
-
- Peaks ( Audio_File *c )
- {
- _len = 0;
- _clip = c;
- }
-
- Peak *peakbuf ( void ) const { return Peaks::_peakbuf.buf->data; }
- void clip ( Audio_File *c ) { _clip = c; }
-
- int fill_buffer ( float fpp, nframes_t s, nframes_t e ) const;
-
- void downsample ( Peak *peaks, int s, int e, float *mhi, float *mlo ) const;
- void read ( int X, float *hi, float *lo ) const;
- bool open ( void );
- // float normalization_factor( float fpp, nframes_t start, nframes_t end ) ;
-
- bool current ( void ) const;
- bool make_peaks ( int chunksize );
-
- Peak & peak ( nframes_t start, nframes_t end ) const;
-
- Peak & operator[] ( int X ) const;
-
- };
-
- #include <stdio.h>
-
- class Peak_Writer
- {
-
- static const int VERSION_MAJOR = 0;
- static const int VERSION_MINOR = 1;
-
- FILE *_fp;
- Peak *_peak;
- int _chunksize;
- int _channels;
-
- int _index;
-
- public:
-
- Peak_Writer ( const char *filename, int chunksize, int channels );
- ~Peak_Writer ( );
-
- void write_header ( void );
- void write ( sample_t *buf, nframes_t nframes );
-
-
- };
|