Я написал код для логарифмической регрессии, используя Python и Sklearn.Я скачал набор данных из Интернета * (http://archive.ics.uci.edu/ml/machine-learning-databases/concrete/compressive/). Моя программа работает хорошо, но она дает мне работу, которая выглядит следующим образом:
Warning (from warnings module):
File "C:\Users\Pc\AppData\Local\Programs\Python\Python36-32\lib\site-packages\sklearn\preprocessing\_function_transformer.py", line 98
"validate=False in 0.22.", FutureWarning)
FutureWarning: The default validate=True will be replaced by validate=False in 0.22.
Я его погуглил и ничего не нашел. Я вижучто он показывает мне line 98
, но в моем коде нет 98 строк. Кто-нибудь знает, в чем проблема?
Это код:
import numpy as np
import pandas as pd
import math
from sklearn import linear_model
from sklearn.preprocessing import PolynomialFeatures
from sklearn.preprocessing import FunctionTransformer
#Reading data from excel and rounding values on 2 decimal places
data = pd.read_excel("DataSet.xls").round(2)
data_size = data.shape[0]
#some values are 0, so I need to eliminate them because I cant do log 0 function
my_data = data[(data["Superpl"] == 0) &
(data["FlyAsh"] == 0) &
(data["BlastFurSlag"] == 0)].drop(columns=["Superpl","FlyAsh","BlastFurSlag"])
def logarithmic_regression(input_data, cement, water, coarse_aggr, fine_aggr, days):
variables = input_data.iloc[:,:-1]
results = input_data.iloc[:,-1]
n = results.shape[0]
results = results.values.reshape(n,1) #reshaping the values so that variables and results have the same shape
#transforming x data to logarithmic fucntion
log_regression = FunctionTransformer(np.log)
log_variables = log_regression.fit_transform(variables)
#making linear model and fitting the logarithmic data into linear model
regression = linear_model.LinearRegression()
model = regression.fit(log_variables, results)
input_values = [cement, water, coarse_aggr, fine_aggr, days]
#transforming input data for prediction in logarithmic function
input_values = log_regression.transform([input_values])
#predicting the outcome based on the input_values
predicted_strength = regression.predict(input_values) #adding values for prediction
predicted_strength = round(predicted_strength[0,0], 2)
return "Logarithmic prediction: " + str(predicted_strength)
print(logarithmic_regression(my_data, 339.0, 197.0, 968.0, 781.0, 14))