This documentation page applies to an outdated major AMT version. We show it for archival purposes only.
Click here for the documentation menu and here to download the latest AMT (1.6.0).
function varargout=amt_load(model,data,variable)
%amt_load Load auxiliary data of a model
% Usage: amt_load(MODEL, DATA);
%
% AMT_LOAD(model, data) loads the auxiliary data from the file data. The data will loaded
% from the directory model located in the local auxdata directory given by
% amt_auxdatapath.
%
% If the file is not in the local auxdata directory, it will be downloaded from
% the web address given by amt_auxdataurl.
%
% The following file types are supported:
% .wav: output will be as that from audioread
% .mat: output as that as from load
% others: output is the absolute filename
%
% AMT_LOAD(model, data, variable) loads just a particular variable
% from the file.
%
% See also: amt_auxdatapath amt_auxdataurl
%
%
% Url: http://amtoolbox.sourceforge.net/amt-0.9.8/doc/amt_load.php
% Copyright (C) 2009-2015 Piotr Majdak and Peter L. Søndergaard.
% This file is part of AMToolbox version 0.9.8
%
% 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 3 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. If not, see <http://www.gnu.org/licenses/>.
% Author: Piotr Majdak, 2015
localfn=fullfile(amt_auxdatapath,model,data);
% file not found? create directories, and download!
if ~exist(localfn,'file')
% create dir if not existing
if ~exist(fullfile(amt_auxdatapath,model),'dir'),
[success,msg]=mkdir(fullfile(amt_auxdatapath,model));
if success~=1
error(msg);
end
end
% download
amt_disp(['Model: ' model '. Downloading auxiliary data: ' data],'progress');
webfn=[amt_auxdataurl '/' model '/' data];
webfn(strfind(webfn,'\'))='/';
webfn=regexprep(webfn,' ','%20');
[~,stat]=urlwrite(webfn,localfn);
if ~stat
error(['Unable to download file: ' webfn]);
end
end
% load the content
[~,~,ext] = fileparts(localfn);
switch lower(ext)
case '.wav'
[y,fs]=audioread(localfn);
varargout{1}=y;
varargout{2}=fs;
case '.mat'
if exist('variable','var'),
varargout{1}=load(localfn,variable);
else
varargout{1}=load(localfn);
end
otherwise
varargout{1}=localfn;
end