source: prdatasets/pr_loadmatfile.m @ 141

Last change on this file since 141 was 137, checked in by bduin, 5 years ago
File size: 1.4 KB
RevLine 
[137]1%PR_LOADMATFILE  Load matfile for this mfile, if it exist
2%
3%    A = PR_LOADMATFILE(MATFILE)
4%
5% Loads the dataset stored in the matfile. Default matfile is the name of
6% the calling routine. The output A is empty if MATFILE does not exist.
7%
8%    [A1,A2,..] = PR_LOADMATFILE(MATFILE,NARGOUTCOUNT)
9%
10% In case multiple matfiles are stored for the calling routine, it is
11% assumed they all contain a dataset: train set, test set, validation set,
12% etcetera. In case NARGOUTCOUNT (NARGOUT of the calling routine) equals 1,
13% the combined dataset is loaded and returned in A (A1).
14% In case NARGOUTCOUNT > 1, the subsets are are loaded into A1, A2, ...
15%
16% SEE ALSO
17% DATASETS, PRDATASETS, PR_SAVEMATFILE, PR_DOWNLOAD_UCI
18
19function varargout = pr_loadmatfile(name)
20
21varargout = cell(1,nargout);
22
23if nargin < 1 || isempty(name)
24  name = pr_callername;
25end
26matfile = fullfile(fullfile(fileparts(which(name)),'data'),name);
27
28if nargout == 1
29  varargout{1} = loadmatf([matfile '.mat']);
30else
31  for i=1:nargout
32    varargout{i} = loadmatf([matfile '_' num2str(i) '.mat']);
33  end
34end
35
36return
37 
38function a = loadmatf(matfile)
39  if exist(matfile,'file') == 2
40    warning('OFF','MATLAB:indeterminateFields');
41    s = prload(matfile);
42    warning('ON','MATLAB:indeterminateFields');
43    fields = fieldnames(s);
44    a = s.(fields{1});
45    a = pr_dataset(a); % take care of prtools4 and prtools5 datasets
46  else
47    a = [];
48  end
49return
Note: See TracBrowser for help on using the repository browser.