This file is indexed.

/usr/share/psychtoolbox-3/PsychProbability/Shuffle.m is in psychtoolbox-3-common 3.0.12.20160126.dfsg1-1ubuntu1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
function [Y,index] = Shuffle(X, bindDim)
% [Y,index] = Shuffle(X [, bindDim])
%
% Randomly sorts X.
%
% If X is a vector, sorts all of X, so Y = X(index).
% If X is an m-by-n matrix, sorts each column of X, so
%	for j=1:n, Y(:,j)=X(index(:,j),j).
%
% The optional 'bindDim' parameter allows this function to shuffle with the
% same order across the bindDim. It also work with higher dimension arrays.
% for example, if you have an n by m matrix X and hope shuffle each column
% with same random order (Shuffle the rows), rather than shuffle each
% column independently, you can run Shuffle(X, 2). This function also works
% on higher dimension arrays. say a 3-d array, If you bind the 2nd
% dimension, it will shuffle the rows on each page independently. If I bind
% the 2nd and 3rd dimension, then it will shuffle the layer of the 3-d
% array.
%
% Examples:
%
% create a 2-d array:
%   x = repmat((1:4)',1,5)
%
% Shuffle each column of x independently:
%   y1 = Shuffle(x)
%
% Shuffle columns of x with same order:
%   y2 = Shuffle(x,2)
%
% Create a 3-d array (4 by 5 by 3), each column contains a vector [1:4]'
%   x = reshape(repmat(reshape(kron([1,1,1],1:4),4,3),5,1),4,5,3)
%
% Shuffle each column independently on each page:
%   [y,ind]=Shuffle(x)
%
% Shuffle 1*5 rows independently on each page:
%   [y,ind]=Shuffle(x,[2])
%
% Shuffle 1*1*3 rows independently on each column:
%   [y,ind]=Shuffle(x,[3])
%
% Create a 3-d array (3 by 4 by 5), each row contains a vector [1:4]
%   x = reshape(repmat(reshape(kron(1:4,[1,1,1]),3,4),1,5),3,4,5)
%
% Shuffle 3*1*5 page along the 2nd dimension:
%   [y,ind]=Shuffle(x,[1,3])
%
% This is same as:
%   y2 = RandDim(x,2)
%   x = reshape(repmat(reshape(repmat(reshape(kron(1:4,[1,1,1]),3,4),1,5),3,4,5),1,2),3,4,5,2)
%   [y,ind]=Shuffle(x,[1,3])
%
% Also see SORT, Sample, Randi, RandDim, and RandSample.

% xx/xx/92  dhb  Wrote it.
% 10/25/93  dhb  Return index.
% 05/25/96  dgp  Made consistent with sort and "for i=Shuffle(1:10)"
% 06/29/96  dgp  Edited comments above.
% 05/18/02  dhb  Modified code to do what comments say, for matrices.
% 06/2/02   dhb  Fixed bug introduced 5/18.
% 9/10/15   niki Add bindDim. so that this function can shuffle with the same
%                order across the bindDim.

if nargin<2
    bindDim = [];
end

num_dim = ndims(X);
siz_unbind = size(X);
siz_unbind(bindDim) = 1;

sort_dim = find(siz_unbind>1,1);
permute_ind = [sort_dim, bindDim, setdiff(1:num_dim, [bindDim, sort_dim])];
X = permute(X, permute_ind); 

siz = size(X);
bind_ind = 2:(length(bindDim)+1);
unbind_ind = (length(bindDim)+2):num_dim;
num_bind = prod(siz(bind_ind));
num_unbind = prod(siz(unbind_ind));

rsp_siz = [siz(1), num_bind, num_unbind];
X = reshape(X, rsp_siz);
[~,index] = sort(rand([siz(1),1, num_unbind]));

index = repmat(index,1,num_bind) ...
    + repmat(0:siz(1):siz(1)*(num_bind-1), [siz(1),1,num_unbind])...
    + repmat(reshape(0:siz(1)*num_bind:siz(1)*num_bind*(num_unbind-1),1,1,num_unbind), siz(1), num_bind);

Y = X(index);
Y = permute(reshape(Y,siz), permute_ind);
index = permute(reshape(index,siz), permute_ind);