how to add combinatorics function in matlab with n different objects divided into r groups and each group get at least 1 object

1 view (last 30 days)
I have 7 machines which I want to group in 3 cells such that each cell contain atleast 1 machine the numeric formula for this is
3^732^7+3=21873(128)+3=1806
I want to generate a matrix with each combination and run loop over that. is there any way I can code this? for example the 1st array is 1 1 1 1 2 3 1 and running the 2nd time loop give another value for example 1 1 1 2 1 1 3

Accepted Answer

Roger Stafford
Roger Stafford on 11 Jan 2017
C = zeros(r^n,n);
t = 0;
for k = 0:(r^n)-1
s = dec2base(k,r,n);
if length(unique(s))==r
t = t+1;
C(t,:) = s-0+1;
end
end
C = C(1:t,:);
  3 Comments
Roger Stafford
Roger Stafford on 11 Jan 2017
Edited: Roger Stafford on 11 Jan 2017
Using your values r = 3 and n = 7, the range of k = 0:(3^7)-1 is exactly the range of numbers that in base 3 can be represented as a 7-digit number:
0000000
0000001
0000002
0000010
....
2222222
There are 3^7 such base 3 numbers, and they are created by Matlab’s ‘dec2base’ function. See:
https://www.mathworks.com/help/matlab/ref/dec2base.html
The requirement “length(unique(s))==r” forces each of the three groups to have at least one digit representing it. (Actually the digits will be one below the corresponding group number.) Hence, for example, '0010121' is accepted but '0010111' is not.

Sign in to comment.

More Answers (0)

Categories

Find more on Loops and Conditional Statements in Help Center and File Exchange

Products

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!