changing time step of data or resample the data

27 次查看(过去 30 天)
I have a motion data with different time step as shown in figure. 1st column represent time step and 2nd to 4th column represent motion. Now, My problem is I want to change the time step of motion data in to uniform time step, say 0.02 sec. How can I change my time step to 0.02 sec time step in matlab? Any answer are highly appreciated. Thank you.
  5 个评论
sam moor
sam moor 2016-11-12
Hi Jan, Here is my data. Is there any solution for this type of data we can change time step of 0.02. I have omitted repeated value but still giving me error that it is non-monotonic
sam moor
sam moor 2016-11-12
This is my new file data after I delete repeated values but still showing error when using interp1. Please help on this problem...your answer are highly appreciated.. thank you

请先登录,再进行评论。

回答(2 个)

Jan
Jan 2016-11-10
编辑:Jan 2016-11-10
Sort the rows at first to get an ascending order. Then call interp1:
xx = 0.001:0.02:1.0;
yy = interp1(x, y, xx)
  5 个评论
sam moor
sam moor 2016-11-10
I mean my 1st column data should be 0.02,0.04,0.06....i.e difference of 0.02
Guillaume
Guillaume 2016-11-11
The problem is not with what it should be, it's not difficult to create that, the problem is with what it is now. Your input is not monotonous, so you need to decide what you want to do about it.

请先登录,再进行评论。


Guillaume
Guillaume 2016-11-10
If you're on R2016b, you could convert your matrix into a timetable, with for example
t = array2table(yourmatrix(:, 2:end), 'rowTimes', ...
datetime(0, 0, 0, 0, 0, yourmatrix(:, 1), 'Format', 'ss.SSS'));
The retime function has then plenty of options to resample your data over the interval and step you want, e.g.:
newtimes = datetime(0, 0, 0, 0, 0, 0) : duration(0, 0, 0.02) : datetime(0, 0, 0, 0, 0, 60);
newtimes.Format = 'ss.SS';
newt = retime(t, newtimes, 'linear');
However, the times in your original array need to be stricly monotonically increasing for any interpolation to work, so you will encounter the same issues as with Jan's answer.
The advantage of a timetable is that there are plenty of built-in function to resample values / aggregate them by period, etc.
  3 个评论
Guillaume
Guillaume 2016-11-11
Well, you need to decide what you want to do about your input and these duplicated values. Matlab can't do that for you.
You can indeed only keep one set with unique (but which one, the duplicates are vastly different) but really you need to work out why you have duplicates in the first place and what it means. You could also aggregate the values (average / median / etc.), again only can decide what is appropriate
Once you've worked out what to do, then it is trivial to use interp1 or retime.
sam moor
sam moor 2016-11-12
I have solved the repeated values data, nut still giving me the error when using interp1. I have attached my data file. please give me a solution to solve this.

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Characters and Strings 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by