How do I create a for loop in MATLAB for this?
Mostrar comentarios más antiguos
Greeting everyone.
I have a these matrix: A is by the order of 10 by 3.
I want to do this calculation: B = (A-min(A))/[max(A)-min(A)]
After that I want B to be by the order of 10 by 3.
Is there a way where I can do a loop of this?
1 comentario
Walter Roberson
el 30 de Mzo. de 2020
Sure. You can deliberately create a loop or two to find the max and min, and you can deliberately create a loop or two to rescale. You do not need to do those things, but you can.
The trick for the vectorized form is that by default max and min work over only one dimension of a multidimensional array. See the documentation for how to change that to process all dimensions.
Respuestas (2)
James Tursa
el 30 de Mzo. de 2020
Editada: James Tursa
el 30 de Mzo. de 2020
If you want to use the overall min and max, then just use A(:) for the calculations. E.g.,
B = (A-min(A(:)))/[max(A(:))-min(A(:))];
A(:) is shorhand for reshaping the variable into a column vector.
6 comentarios
Chloe Sim
el 30 de Mzo. de 2020
James Tursa
el 30 de Mzo. de 2020
B will be the same size as A. Did you try the code?
Chloe Sim
el 28 de Abr. de 2020
Walter Roberson
el 28 de Abr. de 2020
Are you still required to do a loop for it? (If so, then go ahead and write a loop)
Chloe Sim
el 29 de Abr. de 2020
Walter Roberson
el 29 de Abr. de 2020
You can find the per-row min using min(A, [], 2) and you can find the per-row max using similar code. You can do the subtractions . But you should change the division from / to ./
The resulting expression should handle the entire matrix with no loops.
Steven Lord
el 30 de Mzo. de 2020
1 voto
Use the normalize function with the 'range' method. No for loop is required.
1 comentario
Walter Roberson
el 30 de Mzo. de 2020
Or use the older, confusingly-named, mat2gray()
Categorías
Más información sobre Loops and Conditional Statements en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!