Loop for extracting a matrix

1 Ansicht (letzte 30 Tage)
Meddour Aissam riad
Meddour Aissam riad am 14 Jun. 2019
Bearbeitet: dpb am 14 Jun. 2019
Hi everyone,
I have an array/matrix of two column : acceleration (speed) , it contain 150 values. for each 10 valuies I want my program to calculates the average speed and acceleration of all 10 values ​​(from 0 to 10, then from 10 to 20 ...)
can you help me with a program
  1 Kommentar
dpb
dpb am 14 Jun. 2019
"...calculates the average speed and acceleration of all 10 values ​​(from 0 to 10, then from 10 to 20 ...)"
NB: each of those ranges is acutally 11 elements, not 10...

Melden Sie sich an, um zu kommentieren.

Antworten (2)

Guillaume
Guillaume am 14 Jun. 2019
Reshape your array into a 3D array with rows of 10 elements, columns of 150/10 = 15 elements, and 2 pages. Take the mean across the rows to get a 1x15x2 array which is the mean across ten consecutive values. Squeeze that back into a 15x2 array:
squeeze(mean(reshape(yourarray, 10, [], 2), 1)) %will error if the number of rows is not a multiple of 10

dpb
dpb am 14 Jun. 2019
Bearbeitet: dpb am 14 Jun. 2019
nAvg=10;
mnAV=reshape(mean(reshape(av,nAvg,[])),[],2);
Same caveat w/ Guillaume; errors if not divisible by nAvg and the final reshape is based on the input array being specifically two columns. That limitation can be removed by using size(av,2) in place of the hardcoded '2', of course.

Kategorien

Mehr zu Creating and Concatenating Matrices finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by