how to bin data

3 次查看(过去 30 天)
ahmad Saad
ahmad Saad 2023-10-6
评论: ahmad Saad 2023-10-9
i have (attahed) dataset of 3 cols : (1st for lat. ,2nd for long., and the 3rd for datavalues).
i need to bin these data in a grid of lat(2.5) x long(5) degrees.
then plot the results with surf function over the coressponding map location ?
  5 个评论
Matt J
Matt J 2023-10-9
编辑:Matt J 2023-10-9
it seems that the two figures are not similar.
Which two figures? The figures in my 2 answers are different because they use different regridding algorithms. Both of them can be implemented using a for-loop, but how would that help you decide between them? It won't change the surfaces.
ahmad Saad
ahmad Saad 2023-10-9
@Matt J deep thanks for your explaination

请先登录,再进行评论。

采纳的回答

Matt J
Matt J 2023-10-6
编辑:Matt J 2023-10-6
[lat,lon,vals]=readvars('dataset.txt');
LAT=min(lat):2.5:max(lat);
LON=min(lon):5:max(lon);
VALS=griddata(lat,lon,vals, LAT',LON);
Warning: Duplicate data points have been detected and removed - corresponding values have been averaged.
surf(LAT,LON,VALS)

更多回答(1 个)

Matt J
Matt J 2023-10-6
Or perhaps,
[lat,lon,vals]=readvars('dataset.txt');
LAT=min(lat):2.5:max(lat);
LON=min(lon):5:max(lon);
G=findgroups(discretize(lat,LAT), discretize(lon,LON));
VALS=splitapply(@sum,vals,G)./splitapply(@numel,vals,G);
VALS=reshape(VALS, numel(LAT)-1,[]);
LAT=conv(LAT,[1,1]/2,'valid');
LON=conv(LON,[1,1]/2,'valid');
surf(LAT,LON,VALS);

类别

Help CenterFile Exchange 中查找有关 Annotations 的更多信息

标签

Community Treasure Hunt

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

Start Hunting!

Translated by