Точность высока каждый раз, но полученный прогноз неверен - PullRequest
0 голосов
/ 31 января 2020

Я пытаюсь предсказать название культуры, введя температуру, влажность почвы, pH и среднее количество осадков. И процент точности всегда высокий, то есть каждый раз от 88% до 94%. Но конечный результат после прогноза всегда неверен. Это код:

#importing the required libraries
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
from sklearn.model_selection import train_test_split

#Reading the csv file
data=pd.read_csv('cpdata.csv')

#Creating dummy variable for target i.e label
label= pd.get_dummies(data.label).iloc[: , 1:]
data= pd.concat([data,label],axis=1)
data.drop('label', axis=1,inplace=True)
print('The data present in one row of the dataset is')
print(data.head(1))
train=data.iloc[:, 0:4].values
test=data.iloc[: ,4:].values

#Dividing the data into training and test set
X_train,X_test,y_train,y_test=train_test_split(train,test,test_size=0.3)

from sklearn.preprocessing import StandardScaler
sc = StandardScaler()
X_train = sc.fit_transform(X_train)
X_test = sc.transform(X_test)

#Importing Decision Tree classifier
from sklearn.tree import DecisionTreeRegressor
clf=DecisionTreeRegressor()

#Fitting the classifier into training set
clf.fit(X_train,y_train)
pred=clf.predict(X_test)


from sklearn.metrics import accuracy_score
# Finding the accuracy of the model
a=accuracy_score(y_test,pred)
print("The accuracy of this model is: ", a*100)

ah=89.41
atemp=26.98
shum=28
pH=6.26
rain=58.54


l=[]
l.append(atemp)
l.append(ah)
l.append(pH)
l.append(rain)
predictcrop=[l]

# Putting the names of crop in a single list
crops=['rice','wheat','mungbean','Tea','millet','maize','lentil','jute','cofee','cotton','ground nut','peas','rubber','sugarcane','tobacco','kidney beans','moth beans','coconut','blackgram','adzuki beans','pigeon peas','chick peas','banana','grapes','apple','mango','muskmelon','orange','papaya','pomegranate','watermelon']
cr='rice'

#Predicting the crop
predictions = clf.predict(predictcrop)
count=0
for i in range(0,31):
    if(predictions[0][i]==1):
        c=crops[i]
        count=count+1
        break;
    i=i+1
if(count==0):
    print('The predicted crop is %s'%cr)
else:
    print('The predicted crop is %s'%c)

Вывод, который я получаю, -

The accuracy of this model is:  90.43010752688173
The predicted crop is apple

Даже если я ввожу точные значения для любой другой культуры, я получаю яблоко или человека go каждый раз.

Пожалуйста, помогите.

1 Ответ

1 голос
/ 31 января 2020

Примените масштабатор также к вашим новым данным для прогнозирования. Я не могу проверить его без ваших данных, но он должен выглядеть примерно так:

datascaled = sc.transform(predictcrop)
predictions = clf.predict(datascaled)

Чтобы позже применить скалер также к новым данным, вам необходимо сохранить его:

from sklearn.externals.joblib import dump, load
dump(sc, 'scaler.bin', compress=True)

и позже:

sc=load('scaler.bin')
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...