修改下面的代码使得它可以输出结果的的直线方程data=[1 0 1;1 1 1 ;0 2 1; 2 1 -1 ; 2 2 -1;1 3 -1 ]; X = data(:, [1, 2]); y = data(:, 3); m = size(X,1); plotData2(X,y); X = [ones(m,1) X]; error = 1; W=[1;1;1]; first = 1; tim=0; alph=0.1; hold on axis([-3 3 -3 3]); x1=-2:0.2:2; while error>0 error=0; for i = 1:m if ( ((W'*(X(i,:)'))*y(i) <= 0 )|| (first == 1) ) first=0; error=error+1; tim=tim+1; W = W + alph*(X(i,:))'*y(i); fprintf('%dn',tim); if W(3)~=0 && W(2)~=0 y1=-(W(1)/W(3)+W(2)*x1/W(3)); plot(x1,y1,'-b'); end; end; end; end; if W(3)~=0 && W(2)~=0 y1=-(W(1)/W(3)+W(2)*x1/W(3)); plot(x1,y1,'r'); end; hold off
时间: 2023-09-07 16:13:35 浏览: 85
下面是修改后的代码:
```matlab
data=[1 0 1;1 1 1;0 2 1;2 1 -1;2 2 -1;1 3 -1];
X = data(:, [1, 2]);
y = data(:, 3);
m = size(X, 1);
plotData2(X, y);
X = [ones(m, 1) X];
error = 1;
W = [1;1;1];
first = 1;
tim = 0;
alph = 0.1;
hold on
axis([-3 3 -3 3]);
x1 = -2:0.2:2;
while error > 0
error = 0;
for i = 1:m
if ((W'*(X(i,:)'))*y(i) <= 0) || (first == 1)
first = 0;
error = error + 1;
tim = tim + 1;
W = W + alph*(X(i,:)')*y(i);
fprintf('%dn', tim);
if W(3) ~= 0 && W(2) ~= 0
y1 = -(W(1)/W(3) + W(2)*x1/W(3));
plot(x1, y1, '-b');
end
end
end
end
if W(3) ~= 0 && W(2) ~= 0
y1 = -(W(1)/W(3) + W(2)*x1/W(3));
plot(x1, y1, 'r');
end
hold off
```
这段代码实现了感知机算法,找到了数据集中的分割直线。其中 `plotData2` 函数绘制了数据点,`W` 是分割直线的参数,`error` 表示分类错误的点的数量,`alph` 是学习率,`tim` 是迭代次数。
阅读全文