필터 지우기
필터 지우기

How can I run a Low Pass Filter over a Digital Elevation Model to Reduce Noise?

조회 수: 6 (최근 30일)
I want to run an elevation profile tool over a Digital Elevation Model (DEM) in ArcGIS. The DEM is noisy so the profile returned is jagged. I am looking to run a Low Pass Filter over the DEM in order to "blur" it, reducing the noise, and smoothing the extracted profile.
The DEM is: 17997x8369 pixels 1 Band 32 bit floating point
The code I have been using to try and achieve this is:
I = imread('DEM.tif');
G = fspecial('gaussian',[5 5],2);
Ig = imfilter(I,G,'same');
I2 = im2double(Ig);
imwrite(I2, 'DEM_5_2.tif')
However this simply returns a black box. How would I go about running a low pass filter over this image correctly?
  댓글 수: 2
Shivam Raikundalia
Shivam Raikundalia 2017년 7월 28일
The script seems to work for me. Are you sure your original picture is correct?
Chad Greene
Chad Greene 2017년 7월 28일
If the issue is random noise, you may consider a moving median filter like medfilt2, which would remove outliers rather than spreading them out.

댓글을 달려면 로그인하십시오.

답변 (1개)

Chad Greene
Chad Greene 2017년 7월 28일
편집: Chad Greene 2017년 7월 28일
It looks like imwrite will not write double to tiff format. Try something like
I2 = im2uint16(Ig);
imwrite(I2, 'DEM_5_2.tif')

Community Treasure Hunt

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

Start Hunting!

Translated by