Mercurial > hg > octave-nkf
view scripts/audio/record.m @ 20818:9d2023d1a63c
binoinv.m: Implement binary search algorithm for 28X performance increase (bug #34363).
* binoinv.m: Call new functions scalar_binoinv or vector_binoinv to calculate
binoinv. If there are still uncalculated values then call bin_search_binoinv
to perform binary search for remaining values. Add more BIST tests.
* binoinv.m (scalar_binoinv): New subfunction to calculate binoinv for scalar x.
Stops when x > 1000.
* binoinv.m (vector_binoinv): New subfunction to calculate binoinv for scalar x.
Stops when x > 1000.
author | Lachlan Andrew <lachlanbis@gmail.com> |
---|---|
date | Sun, 11 Oct 2015 19:49:40 -0700 |
parents | 7503499a252b |
children |
line wrap: on
line source
## Copyright (C) 2015 Mike Miller ## Copyright (C) 1995-2015 John W. Eaton ## ## This file is part of Octave. ## ## Octave 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 3 of the License, or (at ## your option) any later version. ## ## Octave 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 Octave; see the file COPYING. If not, see ## <http://www.gnu.org/licenses/>. ## -*- texinfo -*- ## @deftypefn {Function File} {} record (@var{sec}) ## @deftypefnx {Function File} {} record (@var{sec}, @var{fs}) ## Record @var{sec} seconds of audio from the system's default audio input at ## a sampling rate of 8000 samples per second. ## ## If the optional argument @var{fs} is given, it specifies the sampling rate ## for recording. ## ## For more control over audio recording, use the @code{audiorecorder} class. ## @seealso{sound, soundsc} ## @end deftypefn function x = record (sec, fs) if (nargin == 1) fs = 8000; elseif (nargin != 2) print_usage (); endif if (! (isscalar (sec) && (sec >= 0))) error ("record: recording duration SEC must be a non-negative number"); endif if (! (isscalar (fs) && (fs > 0))) error ("record: sample rate FS must be a positive number"); endif x = []; if (sec > 0) rec = audiorecorder (fs, 16, 1); recordblocking (rec, sec); x = getaudiodata (rec); endif endfunction ## Tests of record must not actually record anything. %!assert (isempty (record (0))) ## Test input validation %!error record () %!error record (1,2,3) %!error record (-1) %!error record (1, -1)