-
Notifications
You must be signed in to change notification settings - Fork 5
/
86_polynomial_regression_housings_3.py
71 lines (53 loc) · 1.66 KB
/
86_polynomial_regression_housings_3.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#
# (C) Copyright 2024 Pavel Tisnovsky
#
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Eclipse Public License v1.0
# which accompanies this distribution, and is available at
# http://www.eclipse.org/legal/epl-v10.html
#
# Contributors:
# Pavel Tisnovsky
#
import matplotlib.pyplot as plt
from sklearn import linear_model
from sklearn.preprocessing import PolynomialFeatures
from sklearn.datasets import fetch_california_housing
# nacteni datove sady
housings = fetch_california_housing()
# precteni dat z datove sady
# urcenych pro trenink, validaci atd.
data = housings["data"]
# serazeni dat (pro pekne grafy)
data = data[data[:,2].argsort()]
data = data[:-30]
FIRST_DIM = 2
SECOND_DIM = 3
x = data[:, FIRST_DIM]
y = data[:, SECOND_DIM]
for degree in range(1, 11):
# konstrukce modelu
pr = linear_model.LinearRegression()
poly = PolynomialFeatures(degree=degree)
poly_features = poly.fit_transform(x.reshape(-1, 1))
# trénink modelu
pr.fit(poly_features, y)
# predikce modelu
y_pred = pr.predict(poly_features)
# výpis vypočtených koeficientů modelu
print("Coefficients: \n", pr.coef_)
print("Intercept: \n", pr.intercept_)
# vykreslení výsledku
plt.scatter(x, y, color="black", s=1)
plt.plot(x, y_pred, color="blue", linewidth=2)
# titulek grafu
plt.title(f"Degree={degree}")
# osy
plt.xlabel(housings.feature_names[FIRST_DIM])
plt.ylabel(housings.feature_names[SECOND_DIM])
plt.xticks(())
plt.yticks(())
# ulozeni diagramu do souboru
plt.savefig(f"86_{degree}.png")
# zobrazeni diagramu
plt.show()