Changes in / [9ec63a0:e8c4de2]
- Files:
-
- 3 added
- 11 edited
Legend:
- Unmodified
- Added
- Removed
-
doc/web.cfg
r9ec63a0 re8c4de2 703 703 EXCLUDE = ../src/aubio_priv.h \ 704 704 ../src/mathutils .h \ 705 ../src/io/audio_unit.h \ 705 706 ../src/io/source_sndfile.h \ 706 707 ../src/io/source_apple_audio.h \ 708 ../src/io/source_avcodec.h \ 707 709 ../src/io/sink_sndfile.h \ 708 710 ../src/io/sink_apple_audio.h \ -
python/lib/generator.py
r9ec63a0 re8c4de2 58 58 'source_apple_audio', 59 59 'source_sndfile', 60 'source_avcodec', 60 61 #'sampler', 61 62 'audio_unit', -
src/aubio.h
r9ec63a0 re8c4de2 194 194 #include "io/source_sndfile.h" 195 195 #include "io/source_apple_audio.h" 196 #include "io/source_avcodec.h" 196 197 #include "io/sink_sndfile.h" 197 198 #include "io/sink_apple_audio.h" -
src/io/source.c
r9ec63a0 re8c4de2 24 24 #include "fmat.h" 25 25 #include "io/source.h" 26 #ifdef HAVE_AVCODEC 27 #include "io/source_avcodec.h" 28 #endif /* HAVE_AVCODEC */ 26 29 #ifdef __APPLE__ 27 30 #include "io/source_apple_audio.h" … … 29 32 #ifdef HAVE_SNDFILE 30 33 #include "io/source_sndfile.h" 31 #endif 34 #endif /* HAVE_SNDFILE */ 35 36 typedef void (*aubio_source_do_t)(aubio_source_t * s, fvec_t * data, uint_t * read); 37 typedef void (*aubio_source_do_multi_t)(aubio_source_t * s, fmat_t * data, uint_t * read); 38 typedef uint_t (*aubio_source_get_samplerate_t)(aubio_source_t * s); 39 typedef uint_t (*aubio_source_get_channels_t)(aubio_source_t * s); 40 typedef uint_t (*aubio_source_seek_t)(aubio_source_t * s, uint_t seek); 41 typedef uint_t (*del_aubio_source_t)(aubio_source_t * s); 32 42 33 43 struct _aubio_source_t { 34 44 void *source; 45 aubio_source_do_t s_do; 46 aubio_source_do_multi_t s_do_multi; 47 aubio_source_get_samplerate_t s_get_samplerate; 48 aubio_source_get_channels_t s_get_channels; 49 aubio_source_seek_t s_seek; 50 del_aubio_source_t s_del; 35 51 }; 36 52 37 53 aubio_source_t * new_aubio_source(char_t * uri, uint_t samplerate, uint_t hop_size) { 38 54 aubio_source_t * s = AUBIO_NEW(aubio_source_t); 55 #if HAVE_AVCODEC 56 s->source = (void *)new_aubio_source_avcodec(uri, samplerate, hop_size); 57 if (s->source) { 58 s->s_do = (aubio_source_do_t)(aubio_source_avcodec_do); 59 s->s_do_multi = (aubio_source_do_multi_t)(aubio_source_avcodec_do_multi); 60 s->s_get_channels = (aubio_source_get_channels_t)(aubio_source_avcodec_get_channels); 61 s->s_get_samplerate = (aubio_source_get_samplerate_t)(aubio_source_avcodec_get_samplerate); 62 s->s_seek = (aubio_source_seek_t)(aubio_source_avcodec_seek); 63 s->s_del = (del_aubio_source_t)(del_aubio_source_avcodec); 64 return s; 65 } 66 #endif /* HAVE_AVCODEC */ 39 67 #ifdef __APPLE__ 40 68 s->source = (void *)new_aubio_source_apple_audio(uri, samplerate, hop_size); 41 if (s->source) return s; 42 #else /* __APPLE__ */ 69 if (s->source) { 70 s->s_do = (aubio_source_do_t)(aubio_source_apple_audio_do); 71 s->s_do_multi = (aubio_source_do_multi_t)(aubio_source_apple_audio_do_multi); 72 s->s_get_channels = (aubio_source_get_channels_t)(aubio_source_apple_audio_get_channels); 73 s->s_get_samplerate = (aubio_source_get_samplerate_t)(aubio_source_apple_audio_get_samplerate); 74 s->s_seek = (aubio_source_seek_t)(aubio_source_apple_audio_seek); 75 s->s_del = (del_aubio_source_t)(del_aubio_source_apple_audio); 76 return s; 77 } 78 #endif /* __APPLE__ */ 43 79 #if HAVE_SNDFILE 44 80 s->source = (void *)new_aubio_source_sndfile(uri, samplerate, hop_size); 45 if (s->source) return s; 81 if (s->source) { 82 s->s_do = (aubio_source_do_t)(aubio_source_sndfile_do); 83 s->s_do_multi = (aubio_source_do_multi_t)(aubio_source_sndfile_do_multi); 84 s->s_get_channels = (aubio_source_get_channels_t)(aubio_source_sndfile_get_channels); 85 s->s_get_samplerate = (aubio_source_get_samplerate_t)(aubio_source_sndfile_get_samplerate); 86 s->s_seek = (aubio_source_seek_t)(aubio_source_sndfile_seek); 87 s->s_del = (del_aubio_source_t)(del_aubio_source_sndfile); 88 return s; 89 } 46 90 #endif /* HAVE_SNDFILE */ 47 #endif /* __APPLE__ */48 91 AUBIO_ERROR("failed creating aubio source with %s\n", uri); 49 92 AUBIO_FREE(s); … … 52 95 53 96 void aubio_source_do(aubio_source_t * s, fvec_t * data, uint_t * read) { 54 #ifdef __APPLE__ 55 aubio_source_apple_audio_do((aubio_source_apple_audio_t *)s->source, data, read); 56 #else /* __APPLE__ */ 57 #if HAVE_SNDFILE 58 aubio_source_sndfile_do((aubio_source_sndfile_t *)s->source, data, read); 59 #endif /* HAVE_SNDFILE */ 60 #endif /* __APPLE__ */ 97 s->s_do((void *)s->source, data, read); 61 98 } 62 99 63 100 void aubio_source_do_multi(aubio_source_t * s, fmat_t * data, uint_t * read) { 64 #ifdef __APPLE__ 65 aubio_source_apple_audio_do_multi((aubio_source_apple_audio_t *)s->source, data, read); 66 #else /* __APPLE__ */ 67 #if HAVE_SNDFILE 68 aubio_source_sndfile_do_multi((aubio_source_sndfile_t *)s->source, data, read); 69 #endif /* HAVE_SNDFILE */ 70 #endif /* __APPLE__ */ 101 s->s_do_multi((void *)s->source, data, read); 71 102 } 72 103 73 104 void del_aubio_source(aubio_source_t * s) { 74 105 if (!s) return; 75 #ifdef __APPLE__ 76 del_aubio_source_apple_audio((aubio_source_apple_audio_t *)s->source); 77 #else /* __APPLE__ */ 78 #if HAVE_SNDFILE 79 del_aubio_source_sndfile((aubio_source_sndfile_t *)s->source); 80 #endif /* HAVE_SNDFILE */ 81 #endif /* __APPLE__ */ 106 s->s_del((void *)s->source); 82 107 AUBIO_FREE(s); 83 108 } 84 109 85 110 uint_t aubio_source_get_samplerate(aubio_source_t * s) { 86 #ifdef __APPLE__ 87 return aubio_source_apple_audio_get_samplerate((aubio_source_apple_audio_t *)s->source); 88 #else /* __APPLE__ */ 89 #if HAVE_SNDFILE 90 return aubio_source_sndfile_get_samplerate((aubio_source_sndfile_t *)s->source); 91 #endif /* HAVE_SNDFILE */ 92 #endif /* __APPLE__ */ 111 return s->s_get_samplerate((void *)s->source); 93 112 } 94 113 95 114 uint_t aubio_source_get_channels(aubio_source_t * s) { 96 #ifdef __APPLE__ 97 return aubio_source_apple_audio_get_channels((aubio_source_apple_audio_t *)s->source); 98 #else /* __APPLE__ */ 99 #if HAVE_SNDFILE 100 return aubio_source_sndfile_get_channels((aubio_source_sndfile_t *)s->source); 101 #endif /* HAVE_SNDFILE */ 102 #endif /* __APPLE__ */ 115 return s->s_get_channels((void *)s->source); 103 116 } 104 117 105 118 uint_t aubio_source_seek (aubio_source_t * s, uint_t seek ) { 106 #ifdef __APPLE__ 107 return aubio_source_apple_audio_seek ((aubio_source_apple_audio_t *)s->source, seek); 108 #else /* __APPLE__ */ 109 #if HAVE_SNDFILE 110 return aubio_source_sndfile_seek ((aubio_source_sndfile_t *)s->source, seek); 111 #endif /* HAVE_SNDFILE */ 112 #endif /* __APPLE__ */ 119 return s->s_seek((void *)s->source, seek); 113 120 } -
src/io/source.h
r9ec63a0 re8c4de2 77 77 \param s source object, created with ::new_aubio_source 78 78 \param read_to ::fmat_t of data to read to 79 \param read upon returns, equals to number of frames actually read79 \param[out] read upon returns, equals to number of frames actually read 80 80 81 81 Upon returns, `read` contains the number of frames actually read from the -
src/io/source_sndfile.c
r9ec63a0 re8c4de2 67 67 if (path == NULL) { 68 68 AUBIO_ERR("Aborted opening null path\n"); 69 return NULL; 69 goto beach; 70 } 71 if ((sint_t)samplerate < 0) { 72 AUBIO_ERR("Can not open %s with samplerate %d\n", path, samplerate); 73 goto beach; 74 } 75 if ((sint_t)hop_size <= 0) { 76 AUBIO_ERR("Can not open %s with hop_size %d\n", path, hop_size); 77 goto beach; 70 78 } 71 79 … … 74 82 s->path = path; 75 83 76 // try opening the file, get ing the info in sfinfo84 // try opening the file, getting the info in sfinfo 77 85 SF_INFO sfinfo; 78 86 AUBIO_MEMSET(&sfinfo, 0, sizeof (sfinfo)); … … 134 142 135 143 beach: 136 AUBIO_ERR("can not read %s at samplerate %dHz with a hop_size of %d\n",137 s->path, s->samplerate, s->hop_size);144 //AUBIO_ERR("can not read %s at samplerate %dHz with a hop_size of %d\n", 145 // s->path, s->samplerate, s->hop_size); 138 146 del_aubio_source_sndfile(s); 139 147 return NULL; -
src/wscript_build
r9ec63a0 re8c4de2 6 6 uselib += ['SAMPLERATE'] 7 7 uselib += ['SNDFILE'] 8 uselib += ['AVCODEC'] 9 uselib += ['AVFORMAT'] 10 uselib += ['AVRESAMPLE'] 11 uselib += ['AVUTIL'] 8 12 uselib += ['JACK'] 9 13 uselib += ['LASH'] -
tests/src/io/test-source.c
r9ec63a0 re8c4de2 28 28 char_t *source_path = argv[1]; 29 29 30 31 aubio_source_t* s = 32 new_aubio_source(source_path, samplerate, hop_size); 33 if (!s) { err = 1; goto beach; } 30 34 fvec_t *vec = new_fvec(hop_size); 31 32 aubio_source_t* s = new_aubio_source(source_path, samplerate, hop_size);33 if (!s) { err = 1; goto beach; }34 35 35 36 if (samplerate == 0 ) samplerate = aubio_source_get_samplerate(s); … … 44 45 n_frames / hop_size, source_path); 45 46 47 del_fvec (vec); 46 48 del_aubio_source (s); 47 49 beach: 48 del_fvec (vec);49 50 50 return err; 51 51 } -
tests/src/io/test-source_apple_audio.c
r9ec63a0 re8c4de2 12 12 err = 2; 13 13 PRINT_ERR("not enough arguments\n"); 14 PRINT_MSG("usage: %s <source_path> [samplerate]\n", argv[0]); 14 PRINT_MSG("read a wave file as a mono vector\n"); 15 PRINT_MSG("usage: %s <source_path> [samplerate] [hop_size]\n", argv[0]); 16 PRINT_MSG("examples:\n"); 17 PRINT_MSG(" - read file.wav at original samplerate\n"); 18 PRINT_MSG(" %s file.wav\n", argv[0]); 19 PRINT_MSG(" - read file.wav at 32000Hz\n"); 20 PRINT_MSG(" %s file.aif 32000\n", argv[0]); 21 PRINT_MSG(" - read file.wav at original samplerate with 4096 blocks\n"); 22 PRINT_MSG(" %s file.wav 0 4096 \n", argv[0]); 15 23 return err; 16 24 } 17 25 18 26 #if __APPLE__ 19 uint_t samplerate = 32000;27 uint_t samplerate = 0; 20 28 uint_t hop_size = 256; 21 29 uint_t n_frames = 0, read = 0; 22 30 if ( argc == 3 ) samplerate = atoi(argv[2]); 31 if ( argc == 4 ) hop_size = atoi(argv[3]); 23 32 24 33 char_t *source_path = argv[1]; 25 34 35 36 aubio_source_apple_audio_t * s = 37 new_aubio_source_apple_audio(source_path, samplerate, hop_size); 38 if (!s) { err = 1; goto beach; } 26 39 fvec_t *vec = new_fvec(hop_size); 27 aubio_source_apple_audio_t * s = new_aubio_source_apple_audio(source_path, samplerate, hop_size); 40 28 41 if (samplerate == 0 ) samplerate = aubio_source_apple_audio_get_samplerate(s); 29 30 if (!s) { err = 1; goto beach; }31 42 32 43 do { 33 44 aubio_source_apple_audio_do(s, vec, &read); 34 //fvec_print (vec);45 fvec_print (vec); 35 46 n_frames += read; 36 47 } while ( read == hop_size ); 37 48 49 PRINT_MSG("read %d frames at %dHz (%d blocks) from %s\n", n_frames, samplerate, 50 n_frames / hop_size, source_path); 51 52 del_fvec (vec); 53 del_aubio_source_apple_audio (s); 38 54 beach: 39 del_aubio_source_apple_audio (s);40 del_fvec (vec);41 55 #else 42 56 err = 3; -
tests/src/io/test-source_sndfile.c
r9ec63a0 re8c4de2 13 13 err = 2; 14 14 PRINT_ERR("not enough arguments\n"); 15 PRINT_MSG("usage: %s <source_path> [samplerate]\n", argv[0]); 15 PRINT_MSG("read a wave file as a mono vector\n"); 16 PRINT_MSG("usage: %s <source_path> [samplerate] [hop_size]\n", argv[0]); 17 PRINT_MSG("examples:\n"); 18 PRINT_MSG(" - read file.wav at original samplerate\n"); 19 PRINT_MSG(" %s file.wav\n", argv[0]); 20 PRINT_MSG(" - read file.wav at 32000Hz\n"); 21 PRINT_MSG(" %s file.aif 32000\n", argv[0]); 22 PRINT_MSG(" - read file.wav at original samplerate with 4096 blocks\n"); 23 PRINT_MSG(" %s file.wav 0 4096 \n", argv[0]); 16 24 return err; 17 25 } 18 26 19 27 #ifdef HAVE_SNDFILE 20 uint_t samplerate = 32000;28 uint_t samplerate = 0; 21 29 uint_t hop_size = 256; 22 30 uint_t n_frames = 0, read = 0; 23 31 if ( argc == 3 ) samplerate = atoi(argv[2]); 32 if ( argc == 4 ) hop_size = atoi(argv[3]); 24 33 25 34 char_t *source_path = argv[1]; 26 35 36 37 aubio_source_sndfile_t * s = 38 new_aubio_source_sndfile(source_path, samplerate, hop_size); 39 if (!s) { err = 1; goto beach; } 27 40 fvec_t *vec = new_fvec(hop_size); 28 aubio_source_sndfile_t * s = new_aubio_source_sndfile(source_path, samplerate, hop_size); 29 if (!s) { err = 1; goto beach; } 41 30 42 if (samplerate == 0 ) samplerate = aubio_source_sndfile_get_samplerate(s); 31 43 32 44 do { 33 45 aubio_source_sndfile_do(s, vec, &read); 34 //fvec_print (vec);46 fvec_print (vec); 35 47 n_frames += read; 36 48 } while ( read == hop_size ); 37 49 50 PRINT_MSG("read %d frames at %dHz (%d blocks) from %s\n", n_frames, samplerate, 51 n_frames / hop_size, source_path); 52 53 del_fvec (vec); 38 54 del_aubio_source_sndfile (s); 39 55 beach: 40 del_fvec (vec);41 56 #else 42 57 err = 3; -
wscript
r9ec63a0 re8c4de2 57 57 add_option_enable_disable(ctx, 'sndfile', default = None, 58 58 help_str = 'compile with sndfile (auto)', help_disable_str = 'disable sndfile') 59 add_option_enable_disable(ctx, 'avcodec', default = None, 60 help_str = 'compile with libavcodec (auto)', help_disable_str = 'disable libavcodec') 59 61 add_option_enable_disable(ctx, 'samplerate', default = None, 60 62 help_str = 'compile with samplerate (auto)', help_disable_str = 'disable samplerate') … … 200 202 args = '--cflags --libs', uselib_store = 'LASH', mandatory = False) 201 203 204 if (ctx.options.enable_avcodec != False): 205 ctx.check_cfg(package = 'libavcodec', atleast_version = '54.35.0', 206 args = '--cflags --libs', uselib_store = 'AVCODEC', mandatory = False) 207 ctx.check_cfg(package = 'libavformat', atleast_version = '52.3.0', 208 args = '--cflags --libs', uselib_store = 'AVFORMAT', mandatory = False) 209 ctx.check_cfg(package = 'libavutil', atleast_version = '52.3.0', 210 args = '--cflags --libs', uselib_store = 'AVUTIL', mandatory = False) 211 ctx.check_cfg(package = 'libavresample', atleast_version = '1.0.1', 212 args = '--cflags --libs', uselib_store = 'AVRESAMPLE', mandatory = False) 213 202 214 # write configuration header 203 215 ctx.write_config_header('src/config.h')
Note: See TracChangeset
for help on using the changeset viewer.