Есть ли в MATLAB foreach? Если да, то как он себя ведет, если базовые данные изменяются?

Есть ли в MATLAB структура foreach? Если да, то что произойдет, если базовые данные изменятся (т.е. Если объекты добавлены в набор)?

Ответ 1

Цикл MATLAB FOR статический по своей природе; вы не можете изменять переменную цикла между итерациями, в отличие от структуры цикла for (initialization; condition; increment) на других языках. Это означает, что следующий код всегда печатает 1, 2, 3, 4, 5 независимо от значения B.

A = 1:5;

for i = A
    A = B;
    disp(i);
end

Если вы хотите иметь возможность реагировать на изменения в структуре данных во время итераций, цикл WHILE может быть более уместным --- вы сможете протестировать условие цикла на каждой итерации и задать значение переменной цикла (s) по своему усмотрению:

n = 10;
f = n;
while n > 1
    n = n-1;
    f = f*n;
end
disp(['n! = ' num2str(f)])

Btw, цикл для каждого в Java (и, возможно, другие языки) создает неуказанное поведение, когда структура данных изменяется во время итерации. Если вам необходимо изменить структуру данных, вы должны использовать соответствующий экземпляр Iterator, который позволяет добавлять и удаление элементов в коллекции, которую вы итерируете. Хорошей новостью является то, что MATLAB поддерживает Java-объекты, поэтому вы можете сделать что-то вроде этого:

A = java.util.ArrayList();
A.add(1);
A.add(2);
A.add(3);
A.add(4);
A.add(5);

itr = A.listIterator();

while itr.hasNext()

    k = itr.next();
    disp(k);

    % modify data structure while iterating
    itr.remove();
    itr.add(k);

end

Ответ 2

Зак правильно говорит о прямом ответе на вопрос.

Интересным примечанием является то, что следующие две петли не выполняют одно и то же:

for i=1:10000
  % do something
end
for i=[1:10000]
  % do something
end

Первый цикл создает переменную i, которая является скаляром, и выполняет итерацию как цикл C. Обратите внимание, что если вы измените i в теле цикла, измененное значение будет проигнорировано, как говорит Зак. Во втором случае Matlab создает массив 10k-элементов, затем он просматривает все элементы массива.

Это означает, что

for i=1:inf
  % do something
end

работает, но

for i=[1:inf]
  % do something
end

нет (потому что для этого потребуется выделить бесконечную память). Подробнее см. Лорен-блог.

Также обратите внимание, что вы можете перебирать массивы ячеек.

Ответ 3

Если вы пытаетесь перебрать массив ячеек и применить что-то к каждому элементу ячейки, проверьте cellfun. Там также arrayfun, bsxfun и structfun, которые могут упростить вашу программу.

Ответ 4

ооо! аккуратный вопрос.

Matlab for loop принимает матрицу как входную и выполняет итерацию по ее столбцам. Matlab также обрабатывает практически все по значению (без передачи по ссылке), поэтому я ожидаю, что он сделает снимок входного потока for-loop, поэтому он будет неизменным.

вот пример, который может помочь проиллюстрировать:

>> A = zeros(4); A(:) = 1:16

A =

     1     5     9    13
     2     6    10    14
     3     7    11    15
     4     8    12    16

>> i = 1; for col = A; disp(col'); A(:,i) = i; i = i + 1; end;
     1     2     3     4

     5     6     7     8

     9    10    11    12

    13    14    15    16

>> A

A =

     1     2     3     4
     1     2     3     4
     1     2     3     4
     1     2     3     4

Ответ 5

Контур MATLAB for в основном обеспечивает большую гибкость, включая foreach. Вот несколько примеров:

1) Определить начальный, инкрементный и конечный индекс

for test = 1:3:9
   test
end

2) Петля над вектором

for test = [1, 3, 4]
   test
end

3) Переверните строку

for test = 'hello'
   test
end

4) Петля над массивом одномерных ячеек

for test = {'hello', 42, datestr(now) ,1:3}
   test
end

5) Петля над массивом двумерных ячеек

for test = {'hello',42,datestr(now) ; 'world',43,datestr(now+1)}
   test(1)   
   test(2)
   disp('---')
end

6) Использовать имена полей структурных массивов

s.a = 1:3 ; s.b = 10  ; 
for test = fieldnames(s)'
   s.(cell2mat(test))
end

Ответ 6

При повторении массивов ячеек строк переменная цикла (пусть ее вызывает f) становится одноэлементным массивом ячеек. Необходимость писать f{1} всюду становится утомительной, а изменение переменной цикла обеспечивает чистое обходное решение.

% This example transposes each field of a struct.
s.a = 1:3;
s.b = zeros(2,3);
s % a: [1 2 3]; b: [2x3 double]
for f = fieldnames(s)'
    s.(f{1}) = s.(f{1})';
end
s % a: [3x1 double]; b: [3x2 double]

% Redefining f simplifies the indexing.
for f = fieldnames(s)'
    f = f{1};
    s.(f) = s.(f)';
end
s % back to a: [1 2 3]; b: [2x3 double]

Ответ 7

Скажем, у вас есть массив данных:

n = [1    2   3   4   6   12  18  51  69  81  ]

то вы можете "вывести" его так:

for i = n, i, end

Это будет эхо каждого элемента в n (но замена я более интересным материалом также возможно, конечно!)

Ответ 8

Я думаю, что это то, чего действительно хочет OP:

array = -1:0.1:10

for i=1:numel(array)
    disp(array(i))
end