पायथन के साथ एआई - सुपरवाइज्ड लर्निंग: रिग्रेशन
प्रतिगमन सबसे महत्वपूर्ण सांख्यिकीय और मशीन लर्निंग टूल में से एक है। यह कहना गलत नहीं होगा कि मशीन लर्निंग की यात्रा प्रतिगमन से शुरू होती है। इसे पैरामीट्रिक तकनीक के रूप में परिभाषित किया जा सकता है जो हमें डेटा के आधार पर निर्णय लेने की अनुमति देता है या दूसरे शब्दों में हमें इनपुट और आउटपुट चर के बीच संबंध सीखकर डेटा के आधार पर भविष्यवाणियां करने की अनुमति देता है। यहां, इनपुट चर पर निर्भर आउटपुट चर, निरंतर-मूल्यवान वास्तविक संख्याएं हैं। प्रतिगमन में, इनपुट और आउटपुट चर के बीच संबंध मायने रखता है और यह समझने में हमारी मदद करता है कि इनपुट चर के परिवर्तन के साथ आउटपुट चर का मूल्य कैसे बदलता है। प्रतिगमन अक्सर कीमतों, अर्थशास्त्र, विविधताओं, और इसी तरह की भविष्यवाणी के लिए उपयोग किया जाता है।
पाइथन में बिल्डिंग रेजिस्टर
इस खंड में, हम सीखेंगे कि एकल और साथ ही बहुपरत प्रतिगामी कैसे बनाया जाए।
रैखिक रेजिस्टर / सिंगल वेरिएबल रेजिस्टर
आइए हम कुछ आवश्यक पैकेजों को महत्वपूर्ण करें -
import numpy as np
from sklearn import linear_model
import sklearn.metrics as sm
import matplotlib.pyplot as plt
अब, हमें इनपुट डेटा प्रदान करने की आवश्यकता है और हमने अपने डेटा को linear.txt नामक फ़ाइल में सहेजा है।
input = 'D:/ProgramData/linear.txt'
हमें इस डेटा का उपयोग करके लोड करना होगा np.loadtxt समारोह।
input_data = np.loadtxt(input, delimiter=',')
X, y = input_data[:, :-1], input_data[:, -1]
अगला कदम मॉडल को प्रशिक्षित करना होगा। आइए हम प्रशिक्षण और परीक्षण नमूने दें।
training_samples = int(0.6 * len(X))
testing_samples = len(X) - num_training
X_train, y_train = X[:training_samples], y[:training_samples]
X_test, y_test = X[training_samples:], y[training_samples:]
अब, हमें एक रैखिक प्रतिगामी वस्तु बनाने की आवश्यकता है।
reg_linear = linear_model.LinearRegression()
प्रशिक्षण नमूनों के साथ वस्तु को प्रशिक्षित करें।
reg_linear.fit(X_train, y_train)
हमें परीक्षण डेटा के साथ भविष्यवाणी करने की आवश्यकता है।
y_test_pred = reg_linear.predict(X_test)
अब डेटा की साजिश रचें और कल्पना करें।
plt.scatter(X_test, y_test, color = 'red')
plt.plot(X_test, y_test_pred, color = 'black', linewidth = 2)
plt.xticks(())
plt.yticks(())
plt.show()
उत्पादन
अब, हम अपने रैखिक प्रतिगमन के प्रदर्शन की गणना इस प्रकार कर सकते हैं -
print("Performance of Linear regressor:")
print("Mean absolute error =", round(sm.mean_absolute_error(y_test, y_test_pred), 2))
print("Mean squared error =", round(sm.mean_squared_error(y_test, y_test_pred), 2))
print("Median absolute error =", round(sm.median_absolute_error(y_test, y_test_pred), 2))
print("Explain variance score =", round(sm.explained_variance_score(y_test, y_test_pred),
2))
print("R2 score =", round(sm.r2_score(y_test, y_test_pred), 2))
उत्पादन
रैखिक रेजिस्टर का प्रदर्शन -
Mean absolute error = 1.78
Mean squared error = 3.89
Median absolute error = 2.01
Explain variance score = -0.09
R2 score = -0.09
उपरोक्त कोड में, हमने इस छोटे डेटा का उपयोग किया है। यदि आप कुछ बड़े डेटासेट चाहते हैं तो आप बड़े डेटासेट आयात करने के लिए sklearn.dataset का उपयोग कर सकते हैं।
2,4.82.9,4.72.5,53.2,5.56,57.6,43.2,0.92.9,1.92.4,
3.50.5,3.41,40.9,5.91.2,2.583.2,5.65.1,1.54.5,
1.22.3,6.32.1,2.8
बहुपरत प्रतिपालक
सबसे पहले, हम कुछ आवश्यक पैकेजों को आयात करते हैं -
import numpy as np
from sklearn import linear_model
import sklearn.metrics as sm
import matplotlib.pyplot as plt
from sklearn.preprocessing import PolynomialFeatures
अब, हमें इनपुट डेटा प्रदान करने की आवश्यकता है और हमने अपने डेटा को linear.txt नामक फ़ाइल में सहेजा है।
input = 'D:/ProgramData/Mul_linear.txt'
हम इस डेटा का उपयोग करके लोड करेंगे np.loadtxt समारोह।
input_data = np.loadtxt(input, delimiter=',')
X, y = input_data[:, :-1], input_data[:, -1]
अगला कदम मॉडल को प्रशिक्षित करना होगा; हम प्रशिक्षण और परीक्षण के नमूने देंगे।
training_samples = int(0.6 * len(X))
testing_samples = len(X) - num_training
X_train, y_train = X[:training_samples], y[:training_samples]
X_test, y_test = X[training_samples:], y[training_samples:]
अब, हमें एक रैखिक प्रतिगामी वस्तु बनाने की आवश्यकता है।
reg_linear_mul = linear_model.LinearRegression()
प्रशिक्षण नमूनों के साथ वस्तु को प्रशिक्षित करें।
reg_linear_mul.fit(X_train, y_train)
अब, अंत में हमें परीक्षण डेटा के साथ भविष्यवाणी करने की आवश्यकता है।
y_test_pred = reg_linear_mul.predict(X_test)
print("Performance of Linear regressor:")
print("Mean absolute error =", round(sm.mean_absolute_error(y_test, y_test_pred), 2))
print("Mean squared error =", round(sm.mean_squared_error(y_test, y_test_pred), 2))
print("Median absolute error =", round(sm.median_absolute_error(y_test, y_test_pred), 2))
print("Explain variance score =", round(sm.explained_variance_score(y_test, y_test_pred), 2))
print("R2 score =", round(sm.r2_score(y_test, y_test_pred), 2))
उत्पादन
रैखिक रेजिस्टर का प्रदर्शन -
Mean absolute error = 0.6
Mean squared error = 0.65
Median absolute error = 0.41
Explain variance score = 0.34
R2 score = 0.33
अब, हम डिग्री 10 का एक बहुपद बनायेंगे और रजिस्ट्रार को प्रशिक्षित करेंगे। हम नमूना डेटा बिंदु प्रदान करेंगे।
polynomial = PolynomialFeatures(degree = 10)
X_train_transformed = polynomial.fit_transform(X_train)
datapoint = [[2.23, 1.35, 1.12]]
poly_datapoint = polynomial.fit_transform(datapoint)
poly_linear_model = linear_model.LinearRegression()
poly_linear_model.fit(X_train_transformed, y_train)
print("\nLinear regression:\n", reg_linear_mul.predict(datapoint))
print("\nPolynomial regression:\n", poly_linear_model.predict(poly_datapoint))
उत्पादन
रैखिक प्रतिगमन -
[2.40170462]
बहुपद प्रतिगमन -
[1.8697225]
उपरोक्त कोड में, हमने इस छोटे डेटा का उपयोग किया है। यदि आप एक बड़ा डेटासेट चाहते हैं, तो आप बड़े डेटासेट आयात करने के लिए sklearn.dataset का उपयोग कर सकते हैं।
2,4.8,1.2,3.22.9,4.7,1.5,3.62.5,5,2.8,23.2,5.5,3.5,2.16,5,
2,3.27.6,4,1.2,3.23.2,0.9,2.3,1.42.9,1.9,2.3,1.22.4,3.5,
2.8,3.60.5,3.4,1.8,2.91,4,3,2.50.9,5.9,5.6,0.81.2,2.58,
3.45,1.233.2,5.6,2,3.25.1,1.5,1.2,1.34.5,1.2,4.1,2.32.3,
6.3,2.5,3.22.1,2.8,1.2,3.6