annotate src/libsndfile-1.0.25/Octave/sndfile_load.m @ 85:545efbb81310

Import initial set of sources
author Chris Cannam <cannam@all-day-breakfast.com>
date Mon, 18 Mar 2013 14:12:14 +0000
parents
children
rev   line source
cannam@85 1 ## Copyright (C) 2002-2011 Erik de Castro Lopo
cannam@85 2 ##
cannam@85 3 ## This program is free software; you can redistribute it and/or modify
cannam@85 4 ## it under the terms of the GNU General Public License as published by
cannam@85 5 ## the Free Software Foundation; either version 2, or (at your option)
cannam@85 6 ## any later version.
cannam@85 7 ##
cannam@85 8 ## This program is distributed in the hope that it will be useful, but
cannam@85 9 ## WITHOUT ANY WARRANTY; without even the implied warranty of
cannam@85 10 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
cannam@85 11 ## General Public License for more details.
cannam@85 12 ##
cannam@85 13 ## You should have received a copy of the GNU General Public License
cannam@85 14 ## along with this file. If not, write to the Free Software Foundation,
cannam@85 15 ## 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
cannam@85 16
cannam@85 17 ## -*- texinfo -*-
cannam@85 18 ## @deftypefn {Function File} {} sndfile_load (@var{filename})
cannam@85 19 ## Load data from the file given by @var{filename}.
cannam@85 20 ## @end deftypefn
cannam@85 21
cannam@85 22 ## Author: Erik de Castro Lopo <erikd@mega-nerd.com>
cannam@85 23 ## Description: Load the sound data from the given file name
cannam@85 24
cannam@85 25 function [data fs] = sndfile_load (filename)
cannam@85 26
cannam@85 27 if (nargin != 1),
cannam@85 28 error ("Need an input filename") ;
cannam@85 29 endif
cannam@85 30
cannam@85 31 samplerate = -1 ;
cannam@85 32 samplingrate = -1 ;
cannam@85 33 wavedata = -1 ;
cannam@85 34
cannam@85 35
cannam@85 36 eval (sprintf ('load -f %s', filename)) ;
cannam@85 37
cannam@85 38 if (samplerate > 0),
cannam@85 39 fs = samplerate ;
cannam@85 40 elseif (samplingrate > 0),
cannam@85 41 fs = samplingrate ;
cannam@85 42 else
cannam@85 43 error ("Not able to find sample rate.") ;
cannam@85 44 endif
cannam@85 45
cannam@85 46 if (max (size (wavedata)) > 1),
cannam@85 47 data = wavedata ;
cannam@85 48 else
cannam@85 49 error ("Not able to find waveform data.") ;
cannam@85 50 endif
cannam@85 51
cannam@85 52 endfunction