I want to divide one vector to two vectors that complement each other .. How can I obtain all possible combinations of these 2 vectors ?

1 view (last 30 days)
I want to divide this vector [7 3 3 3 3 3 2 1 1 2] into 2 vectors that complement each other, for example: divide it to : A = [4 2 1 2 1 1 1 1 1 0] and B = [3 1 2 1 2 2 1 0 0 2] .. How can I obtain the all combinations of these 2 vectors ?

Accepted Answer

James Tursa
James Tursa on 2 Jun 2017
Edited: James Tursa on 2 Jun 2017
You could use the FEX submission ALLCOMB by Jos for this. E.g.,
x = your original vector of non-negative integers
c = cellfun(@(y)0:y,num2cell(x),'uni',false);
A = allcomb(c{:});
B = bsxfun(@minus,x,A);
The rows of A and B contain all of the possibilities. The usual caveat applies here ... if you have too many numbers with values that are too high this will blow up your memory and you will need to solve your problem a different way.
ALLCOMB can be found here:
https://www.mathworks.com/matlabcentral/fileexchange/10064-allcomb-varargin-
  5 Comments
Mahmoud Ahmed
Mahmoud Ahmed on 3 Jun 2017
Ok .. Done :) I have another problem: There is variable in the workspace that I want to see its values, but matlab said: Cannot display summaries of variables with more than 524288 elements. What can I do ?
Walter Roberson
Walter Roberson on 3 Jun 2017
You could get a job with Mathworks and help them to change that limit of 2^19 elements.
Or you could call max() and min() and whatever on the arrays when you want to know the summary statistics, and you could disp() portions of it. Or you could assign a sub-portion of the large array to a variable and then look at the new variable in the workspace browser.

Sign in to comment.

More Answers (0)

Categories

Find more on Variables in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!