Sequence within a sequence

Hi I want to be able to create a sequence as such
j=1111,2222,3333,4444
It is for use in a loop where j will jump up by 1 for every forth value of i.
thanks

 Respuesta aceptada

Wayne King
Wayne King el 28 de Mzo. de 2012

1 voto

Another way (you need Signal Processing Toolbox)
x = 1:4;
y = upsample(x,4);
h = ones(4,1);
y = filter(h,1,y);

3 comentarios

Daniel Shub
Daniel Shub el 28 de Mzo. de 2012
Hey for once my solution is faster ...
n = 1e7;
m = 10;
tic
x = 1:n;
y = upsample(x,m);
h = ones(m,1);
y = filter(h,1,y);
toc
tic
z = reshape(repmat(1:n, m, 1), n*m, 1);
toc
Elapsed time is 5.215208 seconds.
Elapsed time is 3.261213 seconds.
Daniel Shub
Daniel Shub el 28 de Mzo. de 2012
Despite my answer being faster (and I think simpler), I like your answer better from a theoretical vantage.
Wayne King
Wayne King el 28 de Mzo. de 2012
:) I don't doubt that at all!

Iniciar sesión para comentar.

Más respuestas (3)

Daniel Shub
Daniel Shub el 28 de Mzo. de 2012

1 voto

n = 5;
m = 3;
reshape(repmat(1:n, m, 1), n*m, 1)
Dr. Seis
Dr. Seis el 28 de Mzo. de 2012

1 voto

To beat a dead horse...
I thought I remembered a version by Walter using cumsum, but I couldn't find the link. Here's my attempt to recreate:
n = 5;
m = 3;
a = zeros(m,n);
a(1,:) = 1;
b = cumsum(reshape(a,1,numel(a)));
Running Daniel's test, I got ~0.65 seconds and ~1.05 seconds for the reshape&cumsum and repmat&reshape versions, respectively. However, what you save in compute time is eaten up by doing extra typing.

1 comentario

Daniel Shub
Daniel Shub el 28 de Mzo. de 2012
+1 I knew my answer wouldn't be the fastest. Not only do you have a faster answer, but you also have a faster computer (your answer is faster on my computer also).

Iniciar sesión para comentar.

Scott
Scott el 28 de Mzo. de 2012

0 votos

excellent that did answer my question however I am trying to use this as a simultaneous loop. My guess is using the parfor command:
function [x]= displacementsi(i,z,nx,ny) m=5 n=3
parfor
j=reshape(repmat(1:n, m, 1), n*m, 1)
x(1:4)=z((2*i)-(j-2):(2*i)+(j+1))
end end
I get this error
??? Error: File: displacementsi.m Line: 5 Column: 8 Expression or statement is incomplete or incorrect.
Error in ==> fe_test at 112 [x] = displacementsi(i,displacements,nx,ny);

2 comentarios

Daniel Shub
Daniel Shub el 28 de Mzo. de 2012
This is a new question and should be asked as such.
Scott
Scott el 28 de Mzo. de 2012
ok sorry

Iniciar sesión para comentar.

Categorías

Más información sobre Loops and Conditional Statements en Centro de ayuda y File Exchange.

Etiquetas

Preguntada:

el 28 de Mzo. de 2012

Community Treasure Hunt

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

Start Hunting!

Translated by