Diff of /functions/@mmo/subsref.m [000000] .. [422372]

Switch to unified view

a b/functions/@mmo/subsref.m
1
% SUBSREF - index eegdata class
2
%
3
% Author: Arnaud Delorme, SCCN, INC, UCSD, Nov. 2008
4
5
% Copyright (C) 2008 Arnaud Delorme, SCCN, INC, UCSD
6
%
7
% This file is part of EEGLAB, see http://www.eeglab.org
8
% for the documentation and details.
9
%
10
% Redistribution and use in source and binary forms, with or without
11
% modification, are permitted provided that the following conditions are met:
12
%
13
% 1. Redistributions of source code must retain the above copyright notice,
14
% this list of conditions and the following disclaimer.
15
%
16
% 2. Redistributions in binary form must reproduce the above copyright notice,
17
% this list of conditions and the following disclaimer in the documentation
18
% and/or other materials provided with the distribution.
19
%
20
% THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21
% AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22
% IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23
% ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
24
% LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25
% CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26
% SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27
% INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28
% CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29
% ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
30
% THE POSSIBILITY OF SUCH DAMAGE.
31
32
function res = subsref(obj,s)
33
34
    if strcmpi(s(1).type, '.')
35
        res = builtin('subsref', obj, s);
36
        return;
37
    end
38
    
39
    tmpMMO = memmapfile(obj.dataFile, 'writable', obj.writable, 'format', { 'single' obj.dimensions 'x' });
40
41
    subs = s(1).subs;
42
    finaldim = cellfun('length', subs);
43
    
44
    % one dimension input
45
    % -------------------
46
    if length(s) > 1 || ~strcmpi(s(1).type, '()')
47
        error('MMO can only map single array data files');
48
    end
49
    
50
    % deal with transposed data
51
    % -------------------------
52
    if obj.transposed, s = transposeindices(obj, s); end
53
54
    % convert : to real sizes
55
    % -----------------------
56
    lastdim = length(subs);
57
    if ischar(subs{end}) && ndims(obj) > lastdim
58
        for index = lastdim+1:ndims(obj)
59
            if index > length(obj.dimensions)
60
                subs{index} = 1;
61
            else
62
                subs{index} = [1:obj.dimensions(index)]; 
63
            end
64
        end
65
    end
66
    for index = 1:length(subs)
67
        if ischar(subs{index}) % can only be ":"
68
            if index > length(obj.dimensions)
69
                subs{index} = 1;
70
            else
71
                subs{index} = [1:obj.dimensions(index)]; 
72
            end
73
        end
74
    end
75
    finaldim = cellfun(@length, subs);
76
    finaldim(lastdim) = prod(finaldim(lastdim:end));
77
    finaldim(lastdim+1:end) = [];
78
79
    % non-transposed data
80
    % -------------------
81
    res = tmpMMO.data.x(subs{:});
82
    if length(finaldim) == 1, finaldim(2) = 1; end
83
    res = reshape(res, finaldim);
84
    if obj.transposed
85
        if finaldim(end) == 1, finaldim(end) = []; end
86
        if length(finaldim) <= 2, res = res';
87
        else
88
            res = reshape(res, [finaldim(1)*finaldim(2) finaldim(3)])';
89
            res = reshape(res, [finaldim(3) finaldim(1) finaldim(2)]);
90
        end
91
    end
92
    
93