How to interpolate a different ranges of data in one array of a cell?

2 vues (au cours des 30 derniers jours)
Thao Linh Tran
Thao Linh Tran le 10 Sep 2018
Commenté : Thao Linh Tran le 13 Sep 2018
I have one cell of storm data including different column arrays such as year, sid, time, name, lat, lon (look at the attachment for more detail), I would like interpolate from 3 hours interval at present to 1 hour interval for lat, lon arrays of each storm using "cubic" method. I can do for one storm as below.
t1= 0:3:lines % lines is the number of intervals of that storm
t2= 0:1:((lines-1)*3)
lat2= interp1(t1,lat1,t2,'cubic');
lon2= interp1(t1,lonw1,t2,'cubic');
How can I count the number of intervals of each storm (different storms are defined by sid) then interpolate values of lat, lon for each of them? Thanks in advance!

Réponse acceptée

ADragon
ADragon le 10 Sep 2018
Hi Thao, you can auto generate a script to import your data as a table and index into it using the column names. See attached for an example script. Then you can do something like the following to get only storm '1988219N27175'.
idx = find(data.sid == '1988219N27175');
lines = numel(idx);
lat1 = data.lat(idx);
lon1 = data.lon(idx);
AD
  1 commentaire
Thao Linh Tran
Thao Linh Tran le 13 Sep 2018

Thank you for your help. I also found another way to solve this using unique function to count the number of timesteps of each storm and then do interpolation.

[TC, ~, J]=unique(sid); 
interval = histc(J,1:numel(TC));

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Interpolation dans Help Center et File Exchange

Produits


Version

R2016b

Community Treasure Hunt

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

Start Hunting!

Translated by