how to bin data

4 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);

Categories

Find more on Interactive Control and Callbacks in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!