Matlab 错误:'y1' 无法识别 - 亚像素边缘检测代码
在 Matlab 代码中,出现了 '函数或变量 'y1' 无法识别' 的错误,发生在 'subpixel_edge' 函数的第 23 行。该错误是由于变量 y1 和 y2 在 edgeStrength(y, x) 的赋值语句中被使用,但之前没有定义或赋值。
要解决这个问题,我们需要在赋值语句之前定义并赋值给 y1 和 y2。根据代码逻辑,y1 和 y2 应该是 subpixelY 的邻近像素位置,可以通过 floor 和 ceil 函数计算这些值。
修改后的代码如下:
function [subpixelEdgeImg, edgeStrength] = subpixel_edge(edgeImg)
% 获取边缘图像的尺寸
[height, width] = size(edgeImg);
% 初始化亚像素边缘图像和边缘强度矩阵
subpixelEdgeImg = zeros(height, width);
edgeStrength = zeros(height, width);
% 对于每个像素点
for y = 2:height-1
for x = 2:width-1
% 如果当前像素是边缘点
if edgeImg(y, x) == 1
% 计算亚像素边缘位置和边缘强度
% 计算x方向和y方向的梯度
dx = (edgeImg(y, x+1) - edgeImg(y, x-1)) / 2;
dy = (edgeImg(y+1, x) - edgeImg(y-1, x)) / 2;
% 计算亚像素边缘位置
subpixelX = x - dx / (2*dx - dx);
subpixelY = y - dy / (2*dy - dy);
% 四舍五入为最接近的整数值
subpixelX = round(subpixelX);
subpixelY = round(subpixelY);
% 使用双线性插值计算亚像素边缘强度
y1 = floor(subpixelY);
y2 = ceil(subpixelY);
edgeStrength(y, x) = bilinear_interpolation(subpixelX, subpixelY, edgeImg(y1:y2, x1:x2));
% 设置亚像素边缘图像的像素值
subpixelEdgeImg(y, x) = 1;
end
end
end
end
function value = bilinear_interpolation(x, y, pixelValues)
% 获取邻近像素的位置
x1 = floor(x);
x2 = ceil(x);
y1 = floor(y);
y2 = ceil(y);
% 获取邻近像素的值
q11 = pixelValues(1, 1);
q12 = pixelValues(1, 2);
q21 = pixelValues(2, 1);
q22 = pixelValues(2, 2);
% 计算插值结果
value = (1/(x2-x1)/(y2-y1)) * (q11*(x2-x)*(y2-y) + q21*(x-x1)*(y2-y) + q12*(x2-x)*(y-y1) + q22*(x-x1)*(y-y1));
end
通过添加这两行代码,你将为 y1 和 y2 赋予了正确的值,从而解决了问题。
原文地址: https://www.cveoy.top/t/topic/f39l 著作权归作者所有。请勿转载和采集!