Fne 2016-12-12 07:51 采纳率: 50%
浏览 1325

Python实现PLA算法,出现判断错误

import numpy as np

ITERATION = 100 # 迭代次数为100
W = 0

f = open("C:\Users\Administrator\PycharmProjects\PLA算法实现\PLA_train.txt")

f.readline() # skip the header

data = np.loadtxt(f)

X = data[:, :4] # select columns 1 through end

y = data[:, 4] # select column 0, the stock price

def sign(W, i): # 符号函数
sum = W * X[i]
if sum > 0: return 1
else:
return -1

def trainw(W,i): #更新W
multiply = sign(W, i)
if multiply == y[i]:
return W
else:
W = W + X[i] * y[i]
return W

for i in range(ITERATION):
W = trainw(W,i)

print(W) # 只写到求出 Wpla 为止

错误:
Traceback (most recent call last):
File "C:/Users/Administrator/PycharmProjects/PLA算法实现/test.py", line 33, in
W = trainw(W,i)
File "C:/Users/Administrator/PycharmProjects/PLA算法实现/test.py", line 25, in trainw
multiply = sign(W, i)
File "C:/Users/Administrator/PycharmProjects/PLA算法实现/test.py", line 19, in sign
if sum > 0: return 1
ValueError: The truth value of an array with more than one element is ambiguous. Use a.any() or a.all()

  • 写回答

1条回答 默认 最新

  • zqbnqsdsmd 2016-12-17 04:57
    关注
    评论

报告相同问题?

悬赏问题

  • ¥50 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?