hdf for loop
8 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Hello! I'm trying to loop over a series of hdf files inside a folder. I get the map for the first iteration but fail to continue. Can somebody let me know what is the error that is causing the loop to stop in the second iteration? Thank you
clear all
close all
clc
cd('E:\MOD05_Jan2008')
files = dir('*.hdf');
for k = 1:numel(files)
lat=double(hdfread(files(k).name, '/mod05/Geolocation Fields/Latitude', 'Index', {[1 1],[1 1],[406 270]}));
lon=double(hdfread(files(k).name, '/mod05/Geolocation Fields/Longitude', 'Index', {[1 1],[1 1],[406 270]}));
WV=double(hdfread(files(k).name, '/mod05/Data Fields/Water_Vapor_Infrared', 'Index', {[1 1],[1 1],[406 270]}))*0.001;
latlim = [min(min(lat)) max(max(lat))];
lonlim = [min(min(lon)) max(max(lon))];
fir = find(WV<0);
WV(fir) = NaN;
cd('C:\Users\Guest\Desktop')
figure(1)
axesm('mercator','MapLatLimit',latlim,'MapLonLimit',lonlim,'MeridianLabel','on', ... 'ParallelLabel','on');
surfm(lat,lon,WV)
colorbar
title('Total Precipitable Water Distribution Over Southwest Africa (cm)')
xlabel('Longitude')
ylabel('Latitude')
end
1 commentaire
Sean de Wolski
le 31 Mai 2012
-Are you sure you don't just get the map from the last one?
-If there is an error, what is it?
Réponses (1)
Oleg Komarov
le 31 Mai 2012
You are switching to another directory
cd('C:\Users\Guest\Desktop')
it means that it cannot find the files with name files(k).name in 'C:\Users\Guest\Desktop'
Use:
hdfread(fullfile('path to hdf files', files(k).name),...)
2 commentaires
Voir également
Catégories
En savoir plus sur HDF5 dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!