a function with increasing number of its arguments in a loop

1 visualización (últimos 30 días)
mehdi J
mehdi J el 27 de Oct. de 2018
Editada: Stephen23 el 27 de Oct. de 2018
hi dears,
I'm using a function for generating Cartesian products of two or more vectors and I want the number of its arguments increases in each iteration of a loop (the vectors as its arguments are same). For instance in the first iteration of the loop the function calculates the Cartesian(A,A), in the second iteration calculates Cartesian(A,A,A), in the next iteration calculates Cartesian(A,A,A,A), and so on. How could I do it? Thanks
  2 comentarios
Kevin Chng
Kevin Chng el 27 de Oct. de 2018
Have you tried out any code? Do you mind to share to us?
mehdi J
mehdi J el 27 de Oct. de 2018
a code has been shared on this link and it is as below. I want to use it in a loop and increase its size in each iteration of the loop
------
function C = cartesian(varargin)
args = varargin;
n = nargin;
[F{1:n}] = ndgrid(args{:});
for i=n:-1:1
G(:,i) = F{i}(:);
end
C = unique(G , 'rows');
end

Iniciar sesión para comentar.

Respuestas (1)

Stephen23
Stephen23 el 27 de Oct. de 2018
Editada: Stephen23 el 27 de Oct. de 2018
  2 comentarios
mehdi J
mehdi J el 27 de Oct. de 2018
Thanks, but how could I put all of them (all of the cells) in one matrix (below each other)?
Stephen23
Stephen23 el 27 de Oct. de 2018
Editada: Stephen23 el 27 de Oct. de 2018
@Mhedi J: each of the Cartesian products has a different number of rows and columns: this means there is no simple way to concatenate them into one matrix. The simplest solution is to leave them in a cell array, otherwise you would have to pad them with NaN or some other value/s and then concatenate them into one matrix.
Here is a simple example of how to use a cell array:
A = 1:3;
N = 4;
C = cell(1,N);
for k = 1:N;
T = repmat({A},1,1+k);
[T{:}] = ndgrid(T{:});
T = cellfun(@(v)v(:),T,'uni',0);
C{k} = [T{:}];
end

Iniciar sesión para comentar.

Categorías

Más información sobre Matrices and Arrays en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by