interpolation for a matrix per row

3 ビュー (過去 30 日間)
Jake Bowd
Jake Bowd 2020 年 6 月 12 日
コメント済み: Jake Bowd 2020 年 6 月 14 日
Hi,
I have a 50x91 double in a structure for which I would like to interpolate each row and save as a 50 x 101.
My script works fine if I specify a specific row to interpolate, however I cannot solve to interpolate for each row.
My code is:
% Normalising walks to 101 data points
for j = 1:size(procfiles,1);
n1=size(RESULTS.Kinematics(j).data,2); %number of samples per walk
t0=linspace(1,n1,n1); %original time vector
t1=linspace(1,n1,101); %new time vector of 101 points
RESULTS.Kinematics(j).Resampled = interp1(t0,(RESULTS.Kinematics.data),t1,'linear');
end
Many thanks in advance.
Best wishes,

採用された回答

Stephen23
Stephen23 2020 年 6 月 12 日
You forgot the indexing here:
interp1(t0,(RESULTS.Kinematics(j).data),t1,'linear')
% ^^^ missing
  3 件のコメント
Stephen23
Stephen23 2020 年 6 月 14 日
編集済み: Stephen23 2020 年 6 月 14 日
Your code:
interp1(t0(RESULTS.Kinematics(j).data),t1,'linear');
% ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ why are you now indexing into t0 ?
Try this instead:
interp1(t0,RESULTS.Kinematics(j).data,t1,'linear');
Jake Bowd
Jake Bowd 2020 年 6 月 14 日
Hi Stephen,
Thank you so much. I now have a working code doing what I need it too :).
Best wishes,

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeInterpolation についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by