Quite an easy question I am trying to combine data from two rows, row 3 and row 6 when creating my loop.
for v=1:10
if RT(3,6,v)>0.9
v
end
end
Putting a comma shows a error message and if i use a colon it'll show me from row 3 to row 6 which I dont want. So how can I create this loop with two different rows? Thanks!!

 Respuesta aceptada

Star Strider
Star Strider el 28 de Oct. de 2019

0 votos

The immediate solution is to use square brackets:
RT([3,6],v)
There needs to be some delimiter between the ‘3’ and the ‘6’, a space will do as well.
The larger problem is the logical comparison. The comparison is between two vectors, so it is necessary to be explicit with respect to the result you want.
Example —
A = randi(10,2,10);
C1 = A < 5
C2a = all(A < 5, 1) % Compare Rows
C2b = all(A < 5, 2) % Compare Columns
C3a = any(A < 5, 1) % Compare Rows
C3b = any(A < 5, 2) % Compare Columns
Choose the appropriate syntax to get the result you want from your comparison.

2 comentarios

ii
ii el 29 de Oct. de 2019
Thank you!!
Star Strider
Star Strider el 29 de Oct. de 2019
As always, my pleasure!

Iniciar sesión para comentar.

Más respuestas (1)

James Tursa
James Tursa el 28 de Oct. de 2019

0 votos

RT([3,6],v) is the syntax to use for the 3rd and 6th rows of the v'th column of RT. But this is of course going to be two elements, so I don't know what you intend the if-test to do with that. Do you want something to happen if both elements are greater than 0.9? If so, then
if( all( RT([3,6],v) > 0.9 ) )

Categorías

Etiquetas

Preguntada:

ii
el 28 de Oct. de 2019

Comentada:

el 29 de Oct. de 2019

Community Treasure Hunt

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

Start Hunting!

Translated by