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
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 fluent的在模拟压强时使用希望得到一些建议
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
  • ¥15 模糊pid与pid仿真结果几乎一样
  • ¥15 java的GUI的运用
  • ¥15 Web.config连不上数据库
  • ¥15 我想付费需要AKM公司DSP开发资料及相关开发。
  • ¥15 怎么配置广告联盟瀑布流
  • ¥15 Rstudio 保存代码闪退