![]() |
各位高手帮我看一下这个程序~sobel算子垂直梯度的计算~
下面是我编写的计算图像的垂直梯度,然后显示这个梯度图像,可是结果很不理想,请各位大侠帮忙补充一下:
clear clc InputImage=imread('11.png'); %读入要处理的图像 GrayImage=rgb2gray(InputImage);% 将图像转换为灰度图像 [m n]=size(GrayImage); %图像的大小(长和宽) g=zeros(m,n); %定义一个大小为S的空矩阵 for i=2:m-1 for j=2:n-1 g(i,j)=GrayImage(i-1,j-1)+2*GrayImage(i-1,j)+GrayImage(i-1,j+1)-GrayImage(i+1,j-1)-2*GrayImage(i+1,j)- GrayImage(i+1,j+1); %Sobel算子的垂直梯度 end end %边缘像素的操作 g(1,:)=0; g(:,1)=0; g(m,:)=0; g(:,n)=0; imshow(g) 要想显示这个垂直梯度图像应该怎么做呢?~请大侠们帮帮忙~谢谢!~ |
回复: 各位高手帮我看一下这个程序~sobel算子垂直梯度的计算~
lz 仅说说个人的意见吧
你可以考虑使用double( )数据类型进行操作 然后 再讲double转化为uint8型显示 直接进行计算 可能需要进行归一化 即将结果映射到图像灰度范围内 say 8bit 则灰度范围为0-255 Thx for reading. PS:若还算满意,直接点击“Thanks”,再次登陆时亦便于查看回答是否真的帮到你了。 通过点击本人帖子旁边的ID 可以使用“发送悄悄话给silas_xue”与我进行联系 个人观点 仅供参考 多多交流 相互学习 |
所有时间均为北京时间。现在的时间是 06:20。 |
Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.