1
Мой Matlab является немного ржавый, и я не могу придумать с аккуратным раствором (эффективной),генерировать множество последовательностей -n: п
Желаемая выход для данного Nmax:
nMax = 3;
mn = cell2mat(arrayfun(@(n) [(-n:n) ;(-n:n)*0+n], 1:nMax, 'UniformOutput', false));
mn =
-1 0 1 -2 -1 0 1 2 -3 -2 -1 0 1 2 3
1 1 1 2 2 2 2 2 3 3 3 3 3 3 3
(или, в идеале, его транспонирование).
Edit: здесь это резюме прекрасного ускорения с предлагаемым решением,
tN = [5:100, 200:50:1000];
for ii=1:length(tN)
f1 = @() f_mn(tN(ii));
f2 = @() f_mn2(tN(ii));
gain(ii) = timeit(f1)/timeit(f2);
end