Borrar filtros
Borrar filtros

simplyfing computations in arrays

1 visualización (últimos 30 días)
Sara
Sara el 4 de Jul. de 2012
int = zeros(1,length(x));
for n = 3:length(x)
y1 = x(2:n) ;
t1 = n*dt - (2*dt:dt:n*dt) ;
y2 = x(1:n-1) ;
t2 = n*dt - (dt:dt:(n-1)*dt) ;
int(n) = sum (t1.^(k-1)/factorial(k-1).*y1 ...
+ t2.^(k-1)/factorial(k-1).*y2)*dt/2 ;
end
I want to write t1= ((n-2)*dt:dt:0dt) is it okay? and also t2=((n-1)dt:dt:dt).
Is it possible? I sew also some errors...

Respuesta aceptada

Walter Roberson
Walter Roberson el 4 de Jul. de 2012
Editada: Walter Roberson el 4 de Jul. de 2012
Is t1= ((n-2)*dt:dt:0dt) intended to go to 0 ? If so then because n-2 is positive so you are going backwards from positive towards 0, you will need
(n-2)*dt: -dt : 0
  2 comentarios
Sara
Sara el 4 de Jul. de 2012
Walter, Do you have any suggestion, how can I replace 'for' loop in this code to another data type e.g. vector? (New to MATLAB) Thanks in Advance
Walter Roberson
Walter Roberson el 5 de Jul. de 2012
You cannot replace the "for" loop with a different data structure. Your loop index, "n", is used as the endpoint for a colon index, so you are using expressions with different numbers of terms for different values of "n", and expressions with differing numbers of terms depending on the loop variable, cannot be vectorized.
To have any hope of vectorization, you will need to figure out the symbolic difference between the results for adjacent values of "n", and hope that that difference consists only of constants and individual array elements.

Iniciar sesión para comentar.

Más respuestas (1)

F.
F. el 4 de Jul. de 2012
Hello,
t1 = ( (n-2):-1:0 ) *dt ;
t2 = t1 + dt ;
no ???
  1 comentario
Sara
Sara el 4 de Jul. de 2012
Editada: Sara el 5 de Jul. de 2012
for both lines , your replacements for t1 and t2 are fine

Iniciar sesión para comentar.

Categorías

Más información sobre Creating and Concatenating Matrices 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