2020-01-14 15:49:41 +01:00
|
|
|
% By Bruno Luong
|
2019-12-20 00:40:00 +01:00
|
|
|
function p = uperm(a)
|
|
|
|
[u, ~, J] = unique(a);
|
|
|
|
p = u(up(J, length(a)));
|
|
|
|
|
|
|
|
|
|
|
|
function p = up(J, n)
|
2020-01-14 15:49:41 +01:00
|
|
|
ktab = histc(J,1:max(J));
|
2019-12-20 00:40:00 +01:00
|
|
|
l = n;
|
|
|
|
p = zeros(1, n);
|
|
|
|
s = 1;
|
|
|
|
for i=1:length(ktab)
|
|
|
|
k = ktab(i);
|
|
|
|
c = nchoosek(1:l, k);
|
|
|
|
m = size(c,1);
|
|
|
|
[t, ~] = find(~p.');
|
|
|
|
t = reshape(t, [], s);
|
|
|
|
c = t(c,:)';
|
|
|
|
s = s*m;
|
|
|
|
r = repmat((1:s)',[1 k]);
|
|
|
|
q = accumarray([r(:) c(:)], i, [s n]);
|
|
|
|
p = repmat(p, [m 1]) + q;
|
|
|
|
l = l - k;
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end % uperm
|