How to extract data only along a path consisting of multiple longitude and latitude pair points using MATLAB
    8 views (last 30 days)
  
       Show older comments
    
Dear all, 
I have gridded extinction coefficient data (model output) and I want to extract the data only along the CALIPSO swath so that I can validate the model extinction coefficient with the CALIPSO-retrieved extinction coefficient (Just like the attached screenshot which is taken from Kumar et al. (2014)). Now, I have read the longitude, latitude, and altitdue (pressure) from CALIPSO aerosol profile data and the size of both longitude and latitude vectors is 1*781 and size of altitude vector is 399*1. However, the model extinction coefficient is a matrix with size of 901*501*12 (lon*lat*plev). So, I want to extract the extinction coefficient value from the gridded model output (901*501*12) along only the 1*781 latitude-longitude pair points. How to do that in MATLAB? I tried the following code but it didn't work:
% Find the indices of the nearest grid points
lon_indices = arrayfun(@(lon) find(abs(longitude - lon) == min(abs(longitude - lon))), CALIPSO_lon);
lat_indices = arrayfun(@(lat) find(abs(latitude - lat) == min(abs(latitude - lat))), CALIPSO_lat);
% Extract data along the given latitude and longitude points
EXTCOFF_alongpoints = EXTCOFF(lon_indices, lat_indices, :);
where, 'longitude' and  'latitude' are the extracted longitude and latitude from model output, 'CALIPSO_lon' and 'CALIPSO_lat' are the longitudes and latitudes of CALIPSO aerosol profile data, and EXTCOFF is the model extinction coefficient matrix.

So, can anyone please guide me to solve this issue? That will be very helpful for me. Thank you for your time and consideration.
With regards,
Ankan
3 Comments
  Mathieu NOE
      
 on 14 Feb 2024
				I think I need one more info : what lat and lon range do we have in the EXTCOFF_model data 
Accepted Answer
  Mathieu NOE
      
 on 14 Feb 2024
        ok, this is just to expose the principle... still I need from you the correct lon, lat range for the EXTCOFF_model
basically , the main task is realized with interp2
also note I played a bit with some data so the CALIPSO swath (line) would cross some interesting portion of the EXTCOFF_model data
also note I displayed the z data in log scale so the trace appears more clearly above the data 
EXTCOFF_alongpoints data points appear as this line , which I slightly shifted (+0.15 in log10 base) towards higher Z values so the line appears better vs the background. 
see the color (amplitude) along the line matches the EXTCOFF_model data at the corresponding lon , lat values
.

% load lon, lat data CALIPSO
load('lat_lon_alt_CALIPSO.mat')
%   alt          399x1                 3192  double              
%   lat            1x781               6248  double              
%   lon            1x781               6248  double      
r = 5;
CALIPSO_lon = lon(1:r:numel(lon))-3; % shifted this coordinate to make the line goes where I wanted 
CALIPSO_lat = lat(1:r:numel(lat))+0; % shifted this coordinate to make the line goes where I wanted 
% CALIPSO_alt = alt; % not used yet
clear lat lon alt
% load lon, lat data EXTCOFF (901*501*12 (lon*lat*plev) )
load('EXTCOFF_model.mat')
[m,n] = size(EXTCOFF);
% here it's the mean accross all altitudes so dim is (901*501*1 (lon*lat*plev) )
EXTCOFF_lon = linspace(63,73,m); % need to double check that !!
EXTCOFF_lat = linspace(0,40,n); % need to double check that !!
[X_EXTCOFF,Y_EXTCOFF] = meshgrid(EXTCOFF_lat,EXTCOFF_lon);
% Extract data along the given latitude and longitude points
 EXTCOFF_alongpoints = interp2(X_EXTCOFF,Y_EXTCOFF,EXTCOFF,CALIPSO_lat,CALIPSO_lon);
 % plot the data
figure(1),
imagesc(EXTCOFF_lat,EXTCOFF_lon,log10(EXTCOFF)); % NB log scale on z data for better rendering
colormap('jet');
hold on 
scatter3(CALIPSO_lat,CALIPSO_lon,EXTCOFF_alongpoints,50,log10(EXTCOFF_alongpoints)+0.15,'filled') % NB log scale on z data for better rendering
colorbar('vert');
hold off
figure(2),
plot(CALIPSO_lon,EXTCOFF_alongpoints)
5 Comments
  Mathieu NOE
      
 on 15 Feb 2024
				hello 
this is what I can now offer including the 3rd dimension , NB that the output is only a short segment because we have only 3 values of alt to use in the 3D interpolation (size of EXTCOFF array)
% load lon, lat data CALIPSO
load('lat_lon_alt_CALIPSO.mat')
%   alt          399x1                 3192  double              
%   lat            1x781               6248  double              
%   lon            1x781               6248  double     
% resample "alt" so it has the same number of elements as "lat" and "lon"
alt2 = interp1(1:numel(alt),alt,linspace(1,numel(alt),numel(lon)));
r = 8; % decimate so we go faster
CALIPSO_lon = lon(1:r:numel(lon));
CALIPSO_lat = lat(1:r:numel(lat));
CALIPSO_alt = alt2(1:r:numel(alt2)); 
CALIPSO_lon = CALIPSO_lon(:);
CALIPSO_lat = CALIPSO_lat(:);
CALIPSO_alt = CALIPSO_alt(:); % not used yet
clear lat lon alt alt2
% load lon, lat data EXTCOFF (901*501*12 (lon*lat*plev) )
load('EXTCOFF_model2.mat')
[m,n,l] = size(EXTCOFF);
load('lat_lon_alt_Model.mat')
%   Name              Size            Bytes  Class     Attributes
%   lat_Model       501x1              4008  double              
%   lon_Model       901x1              7208  double              
%   plev_Model       12x1                96  double  
EXTCOFF_lon = lon_Model; % 
EXTCOFF_lat = lat_Model; % 
EXTCOFF_alt = plev_Model(1:3); % first three pressure levels only to be consistent with 3rd dimension of EXTCOFF
[X_EXTCOFF,Y_EXTCOFF,Z_EXTCOFF] = meshgrid(EXTCOFF_lat,EXTCOFF_lon,EXTCOFF_alt);
% Extract data along the given latitude and longitude points
 EXTCOFF_alongpoints = interp3(X_EXTCOFF,Y_EXTCOFF,Z_EXTCOFF,EXTCOFF,CALIPSO_lat,CALIPSO_lon,CALIPSO_alt);
 % plot the data
figure(1),
EXTCOFF_mean = mean(EXTCOFF,3);
imagesc(EXTCOFF_lat,EXTCOFF_lon,log10(EXTCOFF_mean));
xlabel('Latitude');
ylabel('Longitude');
colormap('jet');
hold on 
scatter3(CALIPSO_lat,CALIPSO_lon,EXTCOFF_alongpoints,50,log10(EXTCOFF_alongpoints)+1,'filled')
colorbar('vert');
hold off
figure(2),
plot(CALIPSO_lon,EXTCOFF_alongpoints)
More Answers (0)
See Also
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!
