Precision_score和accuracy_score显示值错误

时间:2017-02-25 08:46:36

标签: python machine-learning scikit-learn linear-regression

我是这台机器的新手学习并使用这个波士顿数据集进行预测。除了precision_score和accuracy_score的结果之外的所有东西都运行正常。这就是我所做的:

import pandas as pd 
import sklearn 
from sklearn.linear_model import LinearRegression
from sklearn import preprocessing,cross_validation, svm
from sklearn.datasets import load_boston
import numpy as np
from sklearn.metrics import accuracy_score, f1_score, precision_score, recall_score, classification_report, confusion_matrix

boston = load_boston()
df = pd.DataFrame(boston.data)
df.columns= boston.feature_names
df['Price']= boston.target

X = np.array(df.drop(['Price'],axis=1), dtype=np.float64)
X = preprocessing.scale(X)

y = np.array(df['Price'], dtype=np.float64)

print (len(X[:,6:7]),len(y))

X_train,X_test,y_train,y_test=cross_validation.train_test_split(X,y,test_size=0.30)

clf =LinearRegression()
clf.fit(X_train,y_train)
y_predict = clf.predict(X_test)

print(y_predict,len(y_predict))
print (accuracy_score(y_test, y_predict))
print(precision_score(y_test, y_predict,average = 'macro'))

现在我收到以下错误:

  

文件" LinearRegression.py",第33行,

 accuracy = accuracy_score(y_test, y_predict)    File "/usr/local/lib/python2.7/dist-packages/sklearn/metrics/classification.py",
     

第172行,在accuracy_score

 y_type, y_true, y_pred = _check_targets(y_true, y_pred)
     

文件   " /usr/local/lib/python2.7/dist-packages/sklearn/metrics/classification.py" ;,   第89行,在_check_targets

 raise ValueError("{0} is not supported".format(y_type))

 ValueError: continuous is not supported

1 个答案:

答案 0 :(得分:1)

您正在使用线性回归模型

clf = LinearRegression()

预测连续值。例如:1.2,1.3

accuracy_score(y_test, y_predict)期望布尔值。 1或0(真或假)或分类值,如1,2,3,4等。数字作为类别。

这就是你收到错误的原因。

如何解决这个问题?

因为您正在尝试预测波士顿数据上的Price,这是一个连续值。我建议您将错误度量从准确度更改为RMSE或here it is

替换:

print(accuracy_score(y_test, y_predict))

使用:

from sklearn.metrics import mean_squared_error
print(mean_squared_error(y_test, y_predict))

这将解决您的问题。