我尝试从头开始创建KNN算法。我的数据集是pandas DataFrame。该算法始终返回1.0(预测总是与实际结果完全匹配),我担心出现了问题,尽管我不知道是什么。非常感谢您提供任何帮助。
这是我的代码:
def get_neighbors(train,row,n):
distances=list()
for i in range(len(test)):
dist=euclidean_distance(row,train.iloc[i])
distances.append((row,dist))
distances.sort(key=lambda tup: tup[1])
neighbors=list()
for i in range(n):
neighbors.append(distances[i][0])
return neighbors
def predict_classification(train,row,n):
neighbors=get_neighbors(train,row, n)
output_values=[row.iloc[-1]for row in neighbors]
prediction=max(set(output_values),key=output_values.count)
return prediction
import math
def euclidean_distance(row1,row2):
distance = 0.0
for i in range((row1.shape[0])):
distance+=(row1[i] -row2[i]) ** 2
return math.sqrt(distance)
def k_nearest_neighbors(train,test,n):
predictions=list()
for i in range(len(test)):
output=predict_classification(train,test.iloc[i],n)
predictions.append(output)
return(predictions)
train=dataset.iloc[0:500]
test=dataset.iloc[500:600]
df=po.DataFrame()
df["Actual"]=test["Outcome"]
df["Predicted"]=k_nearest_neighbors(train,test,5)
答案 0 :(得分:0)
我没有彻底检查您的代码,但是您在这里遇到了几个问题。其中一些是:
dist=euclidean_distance(row,train.iloc[i])
distances.append((row,dist))
不是您想要的。附加训练集的行(虽然效率不高)output_values=[row.iloc[-1]for row in neighbors]
n
邻居的索引(而不是实际样本),并在投票后将其与您的真实情况进行比较。您不需要像实际一样将实际样本保存在某个地方。