هوش مصنوعی با برنامه نویسی پایتون – یادگیری تحت نظارت: رگرسیون
هوش مصنوعی با برنامه نویسی پایتون – یادگیری تحت نظارت: رگرسیون
رگرسیون یکی از مهمترین ابزارهای آماری و یادگیری ماشین است. اشتباه نمی کنیم اگر بگوییم سفر یادگیری ماشینی از رگرسیون شروع می شود. این ممکن است به عنوان تکنیک پارامتری تعریف شود که به ما امکان تصمیم گیری بر اساس داده را می دهد یا به عبارت دیگر به ما امکان می دهد با یادگیری رابطه بین متغیرهای ورودی و خروجی بر اساس داده ها پیش بینی کنیم. در اینجا ، متغیرهای خروجی وابسته به متغیرهای ورودی، اعداد واقعی با ارزش پیوسته هستند. در رگرسیون، رابطه بین متغیرهای ورودی و خروجی مهم است و به ما کمک می کند تا درک کنیم که چگونه مقدار متغیر خروجی با تغییر متغیر ورودی تغییر می کند. رگرسیونها اغلب برای پیش بینی قیمت ها، اقتصاد، تغییرات و غیره استفاده می شود.
ساخت رگرسیون ها در پایتون
در این بخش، ما می آموزیم که چگونه یک رگرسیونهای واحد و همچنین چند متغیره بسازیم.
رگرسیون خطی / رگرسیون تک متغیر
بگذارید چند پکیج مورد نیاز برای ما مهم باشد –
1 2 3 4 |
import numpy as np from sklearn import linear_model import sklearn.metrics as sm import matplotlib.pyplot as plt |
اکنون، ما باید داده های ورودی را ارائه دهیم و داده های خود را در فایلی به نام linear.txt ذخیره کرده ایم.
1 |
input = 'D: /ProgramData/linear.txt' |
ما باید این داده ها را با استفاده از تابع np.loadtxt بارگیری کنیم.
1 2 |
input_data = np.loadtxt(input, delimiter=',') X, y = input_data[:, :-1], input_data[:, -1] |
قدم بعدی آموزش مدل است. اجازه دهید نمونه های آموزشی و تست را ارائه دهیم.
1 2 3 4 5 6 |
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:] |
اکنون، ما باید یک شی رگرسیون خطی ایجاد کنیم.
1 |
reg_linear = linear_model.LinearRegression () |
با نمونه های آموزشی شی را آموزش دهید.
1 |
reg_linear.fit (X_train ، y_train) |
ما باید پیش بینی را با داده های تست انجام دهیم.
1 |
y_test_pred = reg_linear.predict (X_test) |
اکنون داده ها را ترسیم و تجسم کنید.
1 2 3 4 5 |
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() |
خروجی
اکنون ، ما می توانیم عملکرد رگرسیون خطی خود را به شرح زیر محاسبه کنیم –
1 2 3 4 5 6 7 |
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)) |
خروجی
عملکرد رگرسیون خطی –
1 2 3 4 5 |
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 برای وارد کردن مجموعه داده بزرگتر استفاده کنید.
1 2 3 |
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 |
رگرسیون چند متغیره
ابتدا اجازه دهید چند پکیج مورد نیاز را وارد کنیم –
1 2 3 4 5 |
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 ذخیره کرده ایم.
1 |
input = 'D: /ProgramData/Mul_linear.txt' |
ما با استفاده از تابع np.loadtxt این داده ها را بارگیری خواهیم کرد.
1 2 |
input_data = np.loadtxt(input, delimiter=',') X, y = input_data[:, :-1], input_data[:, -1] |
قدم بعدی آموزش مدل است. ما نمونه های آموزشی و تست را ارائه خواهیم داد.
1 2 3 4 5 6 |
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:] |
اکنون، ما باید یک شی رگرسیون خطی ایجاد کنیم.
1 |
reg_linear_mul = linear_model.LinearRegression () |
با نمونه های آموزشی شی را آموزش دهید.
1 |
reg_linear_mul.fit (X_train ، y_train) |
اکنون، بالاخره ما باید پیش بینی را با داده های تست انجام دهیم.
1 2 3 4 5 6 7 8 |
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)) |
خروجی
عملکرد رگرسیون خطی –
1 2 3 4 5 |
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 ایجاد می کنیم و شخص کنترل کننده را آموزش می دهیم. ما نمونه داده ای را ارائه خواهیم داد.
1 2 3 4 5 6 7 |
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)) |
خروجی
رگرسیون خطی –
1 |
[2.40170462] |
رگرسیون چند جمله ای –
1 |
[1.8697225] |
در کد بالا، ما از این داده های کوچک استفاده کرده ایم. اگر یک مجموعه داده بزرگ می خواهید، می توانید از sklearn.dataset برای وارد کردن یک مجموعه داده بزرگتر استفاده کنید.
1 2 3 4 5 |
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 |
لیست جلسات قبل آموزش هوش مصنوعی با برنامه نویسی پایتون
- آموزش هوش مصنوعی با برنامه نویسی پایتون – مفهوم کلی
- شروع آموزش هوش مصنوعی با برنامه نویسی پایتون
- یادگیری ماشین در هوش مصنوعی با برنامه نویسی پایتون
- هوش مصنوعی با برنامه نویسی پایتون، آماده سازی داده ها
- هوش مصنوعی با پایتون، یادگیری نظارت شده و طبقه بندی
دیدگاه شما