Azzera filtri
Azzera filtri

How to merge two arries with different elements?

1 visualizzazione (ultimi 30 giorni)
I am working on two series of observational data. Both of them are acquired at the same location at the same time only with two different sensors. Now due to the unstable observational environment, both of them would have some temporary failure in acquiring data. Now I would like to merge the observation data of these two sensors by time, so I could fill in the data blank over the whole observation period.
For example, the functional time of sensor one is [0,1,2,3,4,6,7,8,11,15,23] (hour of the day), while the sensor two are functional at [2,3,4,5,7,9,10,12,13,14,16,18,20,22]; How should I merge these two time record as one, with several commands?
the expectation on the merged array is [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,18,20,22,23];
I realize the algorithm is simple, but I would like to have some related function in matlab that I can apply on this issue.
Thanks in advance!
Jason
  4 Commenti
Adam
Adam il 15 Set 2016
Also what happens if neither sensor picked up a reading at a given time?
Shenjie Zhou
Shenjie Zhou il 15 Set 2016
Fill up the time record, but put the corresponding readings as NaN.

Accedi per commentare.

Risposta accettata

Adam
Adam il 15 Set 2016
Modificato: Adam il 15 Set 2016
t1 = [0,1,2,3,4,6,7,8,11,15,23];
r1 = rand( 1, 11 );
t2 = [2,3,4,5,7,9,10,12,13,14,16,18,20,22];
r2 = rand( 1, 14 ) * 100;
rNew = NaN( 2, 24 );
rNew( 1, t1 + 1 ) = r1;
rNew( 2, t2 + 1 ) = r2;
rNew = nanmean( rNew );
should do the job, obviously with your real data values instead of the random data I used.
You can also use
rNew = mean( rNew, 'omitnan' );
if you prefer.
Obviously the time array you can just create as:
tNew = 0:23;

Più risposte (1)

Steven Lord
Steven Lord il 15 Set 2016
If you're using the new timetable datatype introduced in release R2016b to store your data, take a look at the synchronize function. If not, use interp1 to interpolate both signals to a common time basis.
  1 Commento
Shenjie Zhou
Shenjie Zhou il 15 Set 2016
Hi Steven,
Interpolation is also a solution, but one of the sensor has missed records more than the other one, so the interpolation on this sensor readings may introduce some error. I am trying to keep the observational data as original as possible.
Thank you for you comment!

Accedi per commentare.

Community Treasure Hunt

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

Start Hunting!

Translated by