Poradniki
Poradniki · 10 min czytania · 25 czerwca 2026

Jak zbudować model regresji w Scikit-learn - 4 praktyczne metody

Grafika ilustrująca: Jak zbudować model regresji w Scikit-learn - 4 praktyczne metody

Źródło: Link

Kurs AI Evolution - od zera do eksperta

118 lekcji bez kodowania. ChatGPT, Claude, Gemini, automatyzacje. Notatnik AI i AI Coach w cenie.

Zacznij od zera →
  • Regresja ML przewiduje wartości liczbowe (np. ceny, temperatury) na podstawie danych historycznych
  • Scikit-learn oferuje cztery główne metody regresji: liniową, wielomianową, Ridge i Lasso
  • Każda metoda ma swoje zastosowania - od prostych zależności po złożone, nieliniowe wzorce
  • Przygotowanie danych i walidacja modelu są równie ważne jak wybór algorytmu

Słyszałeś, że AI potrafi przewidywać przyszłość? Nie potrafi. Potrafi za to analizować wzorce z przeszłości i na ich podstawie szacować, co się stanie dalej. To właśnie robi regresja ML - jeden z najczęściej używanych narzędzi w machine learning. Nie musisz być programistą, żeby zrozumieć jak to działa.

Czym jest regresja ML i dlaczego warto ją znać

Regresja to metoda przewidywania wartości liczbowych. Nie kategorii ("to jest pies" albo "to jest kot"), ale konkretnych liczb. Ile będzie kosztować mieszkanie o powierzchni 50 m²? Jaka będzie temperatura jutro o 14:00? Ile sprzedaży wygeneruje kampania reklamowa z budżetem 10 000 zł?

W praktyce regresja analizuje dane historyczne, szuka zależności między zmiennymi (np. "powierzchnia mieszkania" a "cena") i buduje model matematyczny tej zależności. Potem używasz tego modelu do przewidywania wartości dla nowych danych.

Scikit-learn to biblioteka Pythona, która robi większość ciężkiej pracy za Ciebie. Zamiast pisać równania od zera, importujesz gotowy algorytm, wrzucasz dane i dostajesz działający model. Brzmi prosto? Bo jest - pod warunkiem, że rozumiesz podstawy.

Cztery metody regresji w Scikit-learn - każda radzi sobie inaczej z tymi samymi danymi
Cztery metody regresji w Scikit-learn - każda radzi sobie inaczej z tymi samymi danymi

Zanim zaczniesz - co musisz mieć

Żeby budować modele regresji w Scikit-learn, potrzebujesz:

  • Python 3.8 lub nowszy - zainstalowany na komputerze (sprawdź w terminalu: python --version)
  • Biblioteki: scikit-learn, pandas, numpy, matplotlib - instalujesz jedną komendą: pip install scikit-learn pandas numpy matplotlib
  • Dane treningowe - zbiór danych z wartościami wejściowymi (np. powierzchnia mieszkania) i wyjściowymi (np. cena)
  • Edytor kodu - VS Code, PyCharm albo nawet Jupyter Notebook

Jeśli nie masz własnych danych, Scikit-learn ma wbudowane zestawy testowe (np. load_boston dla cen mieszkań). Możesz też pobrać dane z Kaggle - tam znajdziesz tysiące gotowych zbiorów.

Metoda 1: Regresja liniowa - prosta i skuteczna

Regresja liniowa zakłada, że zależność między zmiennymi jest... liniowa. Jeśli powierzchnia mieszkania rośnie, cena rośnie proporcjonalnie. Prosta linia na wykresie.

Kiedy używać regresji liniowej

Sprawdza się, gdy zależność między danymi jest prosta i przewidywalna. Przykłady: przewidywanie zużycia energii na podstawie temperatury, szacowanie czasu dostawy na podstawie odległości, prognozowanie sprzedaży na podstawie wydatków na reklamę.

NIE sprawdza się, gdy zależność jest nieliniowa (np. wzrost bakterii - najpierw powolny, potem eksploduje, potem znów zwalnia).

Jak zbudować model krok po kroku

  1. Załaduj dane - otwórz plik CSV z pandas: import pandas as pd; data = pd.read_csv('dane.csv')
  2. Podziel na zmienne X (wejściowe) i y (wyjściowe) - np. X = data[['powierzchnia', 'liczba_pokoi']]; y = data['cena']
  3. Podziel dane na treningowe i testowe - from sklearn.model_selection import train_test_split; X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2)
  4. Zaimportuj i wytrenuj model - from sklearn.linear_model import LinearRegression; model = LinearRegression(); model.fit(X_train, y_train)
  5. Przetestuj model - predictions = model.predict(X_test); print(predictions)
  6. Oceń jakość - from sklearn.metrics import mean_squared_error; mse = mean_squared_error(y_test, predictions); print(f'Błąd: {mse}')

Mean Squared Error (MSE) to średni kwadrat błędu przewidywań. Im niższy, tym lepiej. Jeśli MSE wynosi 10 000, a przewidujesz ceny mieszkań w tysiącach złotych - model jest OK. Jeśli przewidujesz temperatury w stopniach Celsjusza - coś poszło nie tak.

Kod regresji liniowej w Scikit-learn - 6 kroków od danych do przewidywań
Kod regresji liniowej w Scikit-learn - 6 kroków od danych do przewidywań

Metoda 2: Regresja wielomianowa - gdy linia nie wystarcza

Czasem zależność nie jest prostą linią. Przykład: zależność między wiekiem samochodu a jego wartością. Pierwszy rok - duży spadek ceny. Potem wolniejszy. Po 10 latach - prawie płasko. To krzywa, nie linia.

Regresja wielomianowa dopasowuje krzywą (wielomian stopnia 2, 3 lub wyższego) zamiast prostej linii.

Jak to zrobić

  1. Przygotuj dane - tak samo jak w metodzie 1
  2. Przekształć zmienne - from sklearn.preprocessing import PolynomialFeatures; poly = PolynomialFeatures(degree=2); X_poly = poly.fit_transform(X_train)
  3. Wytrenuj model - model = LinearRegression(); model.fit(X_poly, y_train)
  4. Przetestuj - X_test_poly = poly.transform(X_test); predictions = model.predict(X_test_poly)
  5. Oceń jakość - tak samo jak wcześniej

Parametr degree to stopień wielomianu. degree=2 to parabola (krzywa w kształcie U). degree=3 to bardziej skomplikowana krzywa. Nie przesadzaj - degree=10 dopasuje się idealnie do danych treningowych, ale będzie beznadziejny na nowych danych (overfitting).

Pułapka: overfitting

Jeśli model ma za dużo stopni swobody (np. wielomian stopnia 10), zacznie "zapamiętywać" dane treningowe zamiast uczyć się wzorców. Na danych testowych wyniki będą fatalne. Sprawdzaj MSE na danych testowych - jeśli rośnie, zmniejsz degree.

Metoda 3: Ridge Regression - gdy masz za dużo zmiennych

Ridge to regresja liniowa z "hamulcem". Dodaje karę za zbyt duże współczynniki w modelu. Po co? Żeby zapobiec overfittingowi, gdy masz dużo zmiennych wejściowych.

Przykład: przewidujesz cenę mieszkania na podstawie 50 cech (powierzchnia, liczba pokoi, piętro, odległość od metra, rok budowy, stan, balkon, winda...). Część z nich to szum. Ridge "tłumi" mniej ważne zmienne, żeby nie zakłócały modelu.

Jak użyć Ridge

  1. Przygotuj dane - standardowo
  2. Zaimportuj Ridge - from sklearn.linear_model import Ridge
  3. Wytrenuj z parametrem alpha - model = Ridge(alpha=1.0); model.fit(X_train, y_train)
  4. Przetestuj i oceń - jak wcześniej

Parametr alpha to siła "hamulca". alpha=0 to zwykła regresja liniowa. alpha=1.0 to umiarkowana kara. alpha=10.0 to mocna kara (model będzie prostszy, ale może stracić dokładność). Testuj różne wartości i sprawdzaj MSE.

Jeśli chcesz systematycznie nauczyć się pracy z modelami regresji i innymi narzędziami AI, sprawdź nasz przewodnik po nauce machine learning od podstaw - tam znajdziesz ścieżkę rozwoju od zera do zaawansowanego poziomu.

Metoda 4: Lasso Regression - automatyczna selekcja cech

Lasso to Ridge na sterydach. Nie tylko tłumi mniej ważne zmienne - zeruje je całkowicie. Jeśli zmienna nie wnosi wartości, Lasso ją wyrzuca.

Po co? Żeby uprościć model i zwiększyć jego interpretowalność. Zamiast 50 zmiennych dostajesz 10 naprawdę ważnych. Łatwiej zrozumieć, co wpływa na wynik.

Jak użyć Lasso

  1. Przygotuj dane - standardowo
  2. Zaimportuj Lasso - from sklearn.linear_model import Lasso
  3. Wytrenuj z parametrem alpha - model = Lasso(alpha=0.1); model.fit(X_train, y_train)
  4. Sprawdź, które zmienne zostały - print(model.coef_) (współczynniki równe 0 = zmienne wyrzucone)
  5. Przetestuj i oceń - jak wcześniej

Parametr alpha działa podobnie jak w Ridge, ale efekt jest silniejszy. Zacznij od małych wartości (np. 0.01) i zwiększaj, aż model zacznie wyrzucać zmienne.

Ridge tłumi wszystkie zmienne równomiernie, Lasso wyrzuca te najmniej ważne
Ridge tłumi wszystkie zmienne równomiernie, Lasso wyrzuca te najmniej ważne

Jak wybrać właściwą metodę dla swoich danych

Nie ma jednej uniwersalnej odpowiedzi. Zależy od danych, problemu i tego, co chcesz osiągnąć. Kilka wskazówek:

  • Regresja liniowa - zacznij od niej. Jeśli działa dobrze (niski MSE na danych testowych), nie komplikuj.
  • Regresja wielomianowa - gdy widzisz na wykresie krzywą zależność, nie prostą linię.
  • Ridge - gdy masz dużo zmiennych (>10) i podejrzewasz, że część to szum.
  • Lasso - gdy chcesz automatycznie wybrać najważniejsze zmienne i uprościć model.

Najlepszy sposób: przetestuj wszystkie cztery metody na swoich danych i porównaj MSE. Wygrywa ta z najniższym błędem na danych testowych (nie treningowych!).

Walidacja modelu - czy naprawdę działa?

Nie wystarczy sprawdzić MSE raz. Dane testowe mogły być "łatwe" albo "trudne" przez przypadek. Użyj walidacji krzyżowej (cross-validation):

  1. Podziel dane na 5 części
  2. Wytrenuj model na 4 częściach, przetestuj na 5.
  3. Powtórz 5 razy (za każdym razem inna część jest testowa)
  4. Uśrednij wyniki

W Scikit-learn to jedna linia kodu: from sklearn.model_selection import cross_val_score; scores = cross_val_score(model, X, y, cv=5, scoring='neg_mean_squared_error'); print(scores.mean())

Jeśli średni wynik jest stabilny (niewielkie różnice między iteracjami), model jest solidny. Jeśli skacze chaotycznie - masz problem (za mało danych, overfitting, albo zły wybór zmiennych).

Chcesz głębiej zrozumieć, jak AI przetwarza dane i uczy się wzorców? Zobacz nasz przewodnik po transformerach AI - to fundament nowoczesnych modeli językowych i nie tylko.

Najczęstsze błędy i jak ich unikać

Nie normalizujesz danych

Jeśli jedna zmienna ma wartości 0-1, a druga 0-10000, model będzie faworyzować tę drugą (bo ma większy wpływ numeryczny). Rozwiązanie: znormalizuj dane przed treningiem.

from sklearn.preprocessing import StandardScaler; scaler = StandardScaler(); X_train_scaled = scaler.fit_transform(X_train); X_test_scaled = scaler.transform(X_test)

Testujesz na danych treningowych

Jeśli sprawdzasz MSE na tych samych danych, na których trenowałeś model, wynik będzie sztucznie zawyżony. Model "widział" te dane, więc oczywiście radzi sobie dobrze. Zawsze dziel dane na treningowe i testowe PRZED treningiem.

Ignorujesz braki w danych

Jeśli w zbiorze są puste wartości (NaN), Scikit-learn zwróci błąd. Musisz je uzupełnić (np. średnią z kolumny) albo usunąć wiersze z brakami.

data = data.fillna(data.mean()) - uzupełnia braki średnią

data = data.dropna() - usuwa wiersze z brakami

Najczęstsze pytania

Czy mogę używać regresji bez znajomości Pythona?

Teoretycznie tak - są narzędzia no-code jak Orange, KNIME czy AutoML w Google Cloud. Żeby naprawdę rozumieć, co robisz i mieć kontrolę nad modelem, podstawy Pythona są niezbędne. Nie musisz być ekspertem - wystarczy umieć uruchomić skrypt i zrozumieć podstawową składnię. Jeśli dopiero zaczynasz, zacznij od podstaw machine learning - tam znajdziesz ścieżkę rozwoju dostosowaną do początkujących.

Która metoda regresji jest najlepsza dla małych zbiorów danych?

Regresja liniowa albo Ridge. Lasso i wielomianowa potrzebują więcej danych, żeby nie przeuczyć się (overfitting). Jeśli masz mniej niż 100 próbek, trzymaj się prostych metod i niskich wartości parametrów regularyzacji.

Jak interpretować współczynniki modelu regresji?

W regresji liniowej współczynnik przy zmiennej mówi, o ile zmieni się wynik, gdy zmienna wzrośnie o 1. Przykład: współczynnik 5000 przy zmiennej "powierzchnia" oznacza, że każdy dodatkowy m² zwiększa cenę mieszkania o 5000 zł. Sprawdzasz to przez model.coef_ po wytrenowaniu modelu.

Czy regresja ML działa dla danych kategorycznych?

Nie bezpośrednio. Musisz przekształcić kategorie (np. "dzielnica: Śródmieście, Mokotów, Praga") na liczby. Najczęściej używa się one-hot encoding: każda kategoria staje się osobną kolumną z wartościami 0/1. W Scikit-learn: from sklearn.preprocessing import OneHotEncoder; encoder = OneHotEncoder(); X_encoded = encoder.fit_transform(X).

Jak często powinienem aktualizować model regresji?

Zależy od tego, jak szybko zmieniają się dane. Jeśli przewidujesz ceny mieszkań - raz na kwartał wystarczy. Jeśli przewidujesz ceny akcji - codziennie albo częściej. Zasada: jeśli MSE na nowych danych zaczyna rosnąć, czas na ponowny trening z nowszymi danymi.

Chcesz opanować AI od podstaw?

Ten poradnik to dopiero początek. W naszym kursie "Praktyczna AI" nauczysz się korzystać z ChatGPT, Claude i innych narzędzi AI w sposób systematyczny - od zera do zaawansowanego poziomu.

Sprawdź kurs →

Podsumowanie: od teorii do praktyki

Regresja ML to narzędzie, które przewiduje wartości liczbowe na podstawie danych historycznych. Scikit-learn daje Ci cztery sprawdzone metody: liniową (prosta, szybka), wielomianową (dla krzywych zależności), Ridge (tłumi szum) i Lasso (automatycznie wybiera zmienne). Każda ma swoje miejsce - testuj, porównuj MSE i wybieraj tę, która działa najlepiej na Twoich danych.

Nie komplikuj na siłę. Zacznij od regresji liniowej. Jeśli nie wystarcza, przejdź do wielomianowej. Jeśli masz dużo zmiennych, spróbuj Ridge albo Lasso. Zawsze dziel dane na treningowe i testowe. Zawsze waliduj krzyżowo. Zawsze normalizuj dane przed treningiem.

Jeden krok na start: Pobierz dowolny zbiór danych z Kaggle (np. "House Prices"), załaduj go do pandas i zbuduj prosty model regresji liniowej według kroków z tego artykułu. Nie czytaj więcej tutoriali - otwórz edytor i napisz te 10 linii kodu. To jedyny sposób, żeby naprawdę zrozumieć, jak to działa.

Na podstawie: materiałów kursu AI Evolution (sukcesai.com)

Informacje o artykule

Podoba Ci się ten artykuł?

Co piątek wysyłam podsumowanie najlepszych artykułów tygodnia. Zapisz się!

Ten temat omawiam szerzej na webinarze

90 minut praktycznej wiedzy o AI. Pokaze Ci krok po kroku, jak zaczac oszczedzac 10 godzin tygodniowo dzieki sztucznej inteligencji.

Zapisz sie na webinar
Udostępnij:
Jan Gajos

Ekspert AI & Founder, AI Evolution

Pasjonat sztucznej inteligencji, który od 18 lat działa z sukcesem biznesowo i szkoleniowo. Wprowadzam AI do swoich firm oraz codziennego życia. Fascynują mnie nowe technologie, gry wideo i składanie klocków Lego - tam też widzę logikę i kreatywność, które AI potrafi wzmacniać. Wierzę, że dobrze użyta sztuczna inteligencja to nie ogłupiające ułatwienie, lecz prawdziwy przełom w sposobie, w jaki myślimy, tworzymy i pracujemy.