how to bin data

3 views (last 30 days)
ahmad Saad
ahmad Saad on 6 Oct 2023
Commented: ahmad Saad on 9 Oct 2023
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 Comments
Matt J
Matt J on 9 Oct 2023
Edited: Matt J on 9 Oct 2023
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 on 9 Oct 2023
@Matt J deep thanks for your explaination

Sign in to comment.

Accepted Answer

Matt J
Matt J on 6 Oct 2023
Edited: Matt J on 6 Oct 2023
[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)

More Answers (1)

Matt J
Matt J on 6 Oct 2023
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);

Tags

Community Treasure Hunt

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

Start Hunting!