fill missing values inside a dataset that contains nan
1 次查看(过去 30 天)
显示 更早的评论
Hi all,
I have a dataset of some weather variables such as rainfall and solar radiation. But there are some missing values in the database. I am clueless on how to fill the missing values using interpolation method.
I cannot delete the entire row with Nans since it will affect the overall results.
I have tried to refer to some examples but still not working my dataset is called mersing which contains 1029 rows and 8 columns. The weather data start from column 5 up to column 8.
the dataset looks like this( station no, year, day, rainfall, windspeed, solarradiation, evaporation)
Here are sample of my code that I am currently working on which based on answer provided by Sven but still not working.
load mersing_data fulldata_mersing = mersing; for c = 5:size(mersing,2) % start loop from column 5 until all column nanRows = isnan(mersing(:,c)); nanRows = fullData_mersing(nanRows,c) == interp1(mersing(~nanRows,1), mersing(~nanRows,c), mersing(nanRows,1)); fulldata_mersing(nanRows,c) = interp1(mersing(~nanRows,1), mersing(~nanRows,c), mersing(nanRows,1), 'nearest','extrap'); end
0 个评论
采纳的回答
Image Analyst
2013-5-29
Give John D'Errico's inpaint_nans a try: http://www.mathworks.com/matlabcentral/fileexchange/4551-inpaintnans
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Weather and Atmospheric Science 的更多信息
产品
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!