Converting binary like table but using decimal values
조회 수: 10 (최근 30일)
이전 댓글 표시
I'm trying to create a table that will start at a negative value and increment by one in the right most column and each column to the left will only increment when there is a carry. This is similar to a binary table or any other base-n table, but I would like to keep the values in decimal format, not alpha-numeric.
I had this code which was working well, but fails if I make 'n' > 5 due to the alpha-numerics once the decimal value reaches '10'.
m = 3; %Number of signals
n = n+1; %Number of harmonics
%% Harmonic Basis Matrix
T = zeros((2*n-1)^m,m);
for k = 1:(2*n-1)^m
T(k,:) = dec2base(k-1,2*n-1,m)-num2str(n-1);
end
When I subtract num2str(n-1) from the string '00A', the result is double('00A') = 17 - double('0') = 5 ==> 17-5 = 12.
I thought about creating the matrix in alpha-numeric string form and just splitting the values into columns, but couldn't figure out how to do that effectively without using cells - which I need to avoid as this will be used in some matrix algebra.
Please note, that the variables 'm' and 'n' are part of a function input and could be completely arbitrary.
Thanks for the help!
댓글 수: 6
채택된 답변
Stephen23
2019년 5월 7일
편집: Stephen23
2025년 7월 27일
You can use comma-separated lists on the output of ndgrid:
m = 4;
C = cell(1,m);
[C{:}] = ndgrid(-2:2);
T = reshape(cat(m+1,C{:}),[],m)
댓글 수: 2
Stephen23
2019년 5월 7일
편집: Stephen23
2019년 5월 7일
"Great tutorial on comma separated lists..."
Thank you, you can vote for it too, if you liked it :) Comma-separated lists are certainly very handy and well worth learning about.
"I'll need to read up on the cellfun(@(a)...) line..."
All that does lines does is convert the content of each cell (i.e. the array output from ndgrid) into a column vector. An explicit loop would likely be a tad faster, in case speed is of major concern.
추가 답변 (2개)
Walter Roberson
2019년 5월 6일
ndgrid or meshgrid and reshape to column vectors and put the columns together.
댓글 수: 0
Jan
2019년 5월 7일
편집: Jan
2019년 5월 7일
With the fast C-Mex function https://www.mathworks.com/matlabcentral/fileexchange/26242-vchoosekro
R = VChooseKRO(-2:2, 2)
Or:
n = 2;
m = 2;
len = (2*n+1)^m; % Not: (2*n-1)^m !
T = zeros(len, m);
v = repmat(-n, 1, m);
for k = 1:len
T(k, :) = v;
for im = m:-1:1
if v(im) < n
v(im) = v(im) + 1;
break;
end
v(im) = -n;
end
end
Or:
len = (2*n+1)^m; % Not: (2*n-1)^m !
T = zeros(len, m);
v = (-n:n).';
nv = numel(v);
r1 = nv ^ (m - 1);
r2 = 1;
for k = 1:m
T(:, k) = repmat(repelem(v, r1, 1), r2, 1);
r1 = r1 / nv;
r2 = r2 * nv;
end
댓글 수: 0
참고 항목
카테고리
Help Center 및 File Exchange에서 Logical에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!