annotate nonExposed/getSampleInfo.m @ 14:b1901e8d8f5f

initial commit
author Mathieu Lagrange <mathieu.lagrange@cnrs.fr>
date Tue, 17 Mar 2015 09:34:13 +0100
parents
children 69410ac2a50d
rev   line source
mathieu@14 1 function [o] = getSampleInfo(label,query,sampleType,inputData,trackLength)
mathieu@14 2
mathieu@14 3 % This program was written by Mathias Rossignol & Grégoire Lafay
mathieu@14 4 % is Copyright (C) 2015 IRCAM <http://www.ircam.fr>
mathieu@14 5 %
mathieu@14 6 % This program is free software: you can redistribute it and/or modify it
mathieu@14 7 % under the terms of the GNU General Public License as published by the Free
mathieu@14 8 % Software Foundation, either version 3 of the License, or (at your option)
mathieu@14 9 % any later version.
mathieu@14 10 %
mathieu@14 11 % This program is distributed in the hope that it will be useful, but
mathieu@14 12 % WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
mathieu@14 13 % or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
mathieu@14 14 % for more details.
mathieu@14 15 %
mathieu@14 16 % You should have received a copy of the GNU General Public License along
mathieu@14 17 % with this program. If not, see <http://www.gnu.org/licenses/>.
mathieu@14 18
mathieu@14 19 o.isBackground = strcmp(sampleType,'background');
mathieu@14 20 o.classLabel = label;
mathieu@14 21 o.startTimes = [];
mathieu@14 22 o.endTimes = [];
mathieu@14 23 o.query= query;
mathieu@14 24 o.trackLength=trackLength;
mathieu@14 25 path = [inputData sampleType '/'];
mathieu@14 26
mathieu@14 27 if ~exist(path, 'dir')
mathieu@14 28 error(['Could not find local dir ',path,'\n']);
mathieu@14 29 end
mathieu@14 30
mathieu@14 31 samples = dir([path '*wav']);
mathieu@14 32 samplesInd = find(cellfun('isempty',regexpi({samples.name},query,'match'))==0);
mathieu@14 33
mathieu@14 34 for ii=1:length(samplesInd)
mathieu@14 35 [sampleSize,sr]=wavread([path,'/',samples(samplesInd(ii)).name],'size');
mathieu@14 36 o.startTimes(end+1) = 0;
mathieu@14 37 o.endTimes(end+1) = sampleSize(1)/sr;
mathieu@14 38 end
mathieu@14 39