Interpolatie Versus Extrapolatie
In het vorige hoofdstuk merkten we op dat onze voorspellingen met verschillende modellen steeds meer uiteenlopen aan de randen.
Om preciezer te zijn, worden de voorspellingen vreemd zodra we buiten het bereik van waarden uit de trainingsset gaan. Het voorspellen van waarden buiten het bereik van de trainingsset wordt extrapolatie genoemd, en het voorspellen van waarden binnen het bereik heet interpolatie.
Regressie gaat niet goed om met extrapolatie. Het wordt gebruikt voor interpolatie en kan absurde voorspellingen opleveren wanneer nieuwe gevallen buiten het bereik van de trainingsset vallen.
Betrouwbaarheidsintervallen
Met behulp van de OLS
-klasse kun je ook de betrouwbaarheidsintervallen voor de regressielijn op elk punt verkrijgen. De syntaxis is echter enigszins ingewikkeld:
lower = regression_model.get_prediction(X_new_tilde).summary_frame(alpha)['mean_ci_lower']
upper = regression_model.get_prediction(X_new_tilde).summary_frame(alpha)['mean_ci_upper']
Hierbij is alpha
het betrouwbaarheidsniveau, meestal ingesteld op 0.05
.
Met bovenstaande code verkrijg je de onder- en bovengrenzen van het betrouwbaarheidsinterval van de regressielijn op het punt X_new_tilde
(of een array van onder- en bovengrenzen als X_new_tilde
een array is).
Hiermee kunnen we nu de regressielijn samen met het betrouwbaarheidsinterval plotten:
12345678910111213141516171819202122import pandas as pd import numpy as np import matplotlib.pyplot as plt import statsmodels.api as sm from sklearn.preprocessing import PolynomialFeatures # Import PolynomialFeatures class file_link = 'https://codefinity-content-media.s3.eu-west-1.amazonaws.com/b22d1166-efda-45e8-979e-6c3ecfc566fc/poly.csv' df = pd.read_csv(file_link) n = 4 # A degree of the polynomial regression X = df[['Feature']] # Assign X as a DataFrame y = df['Target'] # Assign y X_tilde = PolynomialFeatures(n).fit_transform(X) # Get X_tilde regression_model = sm.OLS(y, X_tilde).fit() # Initialize and train the model X_new = np.linspace(-0.1, 1.5, 80) # 1-d array of new feature values X_new_tilde = PolynomialFeatures(n).fit_transform(X_new.reshape(-1,1)) # Transform X_new for predict() method y_pred = regression_model.predict(X_new_tilde) lower = regression_model.get_prediction(X_new_tilde).summary_frame(0.05)['mean_ci_lower'] # Get lower bound for each point upper = regression_model.get_prediction(X_new_tilde).summary_frame(0.05)['mean_ci_upper'] # get upper bound for each point plt.scatter(X, y) # Build a scatterplot plt.plot(X_new, y_pred) # Build a Polynomial Regression graph plt.fill_between(X_new, lower, upper, alpha=0.4) plt.show()
Zonder kennis van de verdeling van een doelvariabele kunnen we de exacte regressielijn niet bepalen. We proberen deze slechts te benaderen op basis van onze data. Het betrouwbaarheidsinterval van de regressielijn is het interval waarin de exacte regressielijn zich bevindt met het betrouwbaarheidsniveau alpha
.
Het is zichtbaar dat het interval groter wordt naarmate het verder van het bereik van de trainingsset afligt.
De betrouwbaarheidsintervallen worden opgebouwd onder de aanname dat het juiste model is gekozen (bijvoorbeeld Eenvoudige Lineaire Regressie of Polynomiale Regressie van graad 4).
Als het model slecht is gekozen, is het betrouwbaarheidsinterval onbetrouwbaar, evenals de lijn zelf. In de volgende sectie leer je hoe je het beste model selecteert.
Bedankt voor je feedback!
Vraag AI
Vraag AI
Vraag wat u wilt of probeer een van de voorgestelde vragen om onze chat te starten.
What is the difference between interpolation and extrapolation?
Can you explain more about confidence intervals in regression?
Why does the confidence interval get wider outside the training set's range?
Awesome!
Completion rate improved to 5.26
Interpolatie Versus Extrapolatie
Veeg om het menu te tonen
In het vorige hoofdstuk merkten we op dat onze voorspellingen met verschillende modellen steeds meer uiteenlopen aan de randen.
Om preciezer te zijn, worden de voorspellingen vreemd zodra we buiten het bereik van waarden uit de trainingsset gaan. Het voorspellen van waarden buiten het bereik van de trainingsset wordt extrapolatie genoemd, en het voorspellen van waarden binnen het bereik heet interpolatie.
Regressie gaat niet goed om met extrapolatie. Het wordt gebruikt voor interpolatie en kan absurde voorspellingen opleveren wanneer nieuwe gevallen buiten het bereik van de trainingsset vallen.
Betrouwbaarheidsintervallen
Met behulp van de OLS
-klasse kun je ook de betrouwbaarheidsintervallen voor de regressielijn op elk punt verkrijgen. De syntaxis is echter enigszins ingewikkeld:
lower = regression_model.get_prediction(X_new_tilde).summary_frame(alpha)['mean_ci_lower']
upper = regression_model.get_prediction(X_new_tilde).summary_frame(alpha)['mean_ci_upper']
Hierbij is alpha
het betrouwbaarheidsniveau, meestal ingesteld op 0.05
.
Met bovenstaande code verkrijg je de onder- en bovengrenzen van het betrouwbaarheidsinterval van de regressielijn op het punt X_new_tilde
(of een array van onder- en bovengrenzen als X_new_tilde
een array is).
Hiermee kunnen we nu de regressielijn samen met het betrouwbaarheidsinterval plotten:
12345678910111213141516171819202122import pandas as pd import numpy as np import matplotlib.pyplot as plt import statsmodels.api as sm from sklearn.preprocessing import PolynomialFeatures # Import PolynomialFeatures class file_link = 'https://codefinity-content-media.s3.eu-west-1.amazonaws.com/b22d1166-efda-45e8-979e-6c3ecfc566fc/poly.csv' df = pd.read_csv(file_link) n = 4 # A degree of the polynomial regression X = df[['Feature']] # Assign X as a DataFrame y = df['Target'] # Assign y X_tilde = PolynomialFeatures(n).fit_transform(X) # Get X_tilde regression_model = sm.OLS(y, X_tilde).fit() # Initialize and train the model X_new = np.linspace(-0.1, 1.5, 80) # 1-d array of new feature values X_new_tilde = PolynomialFeatures(n).fit_transform(X_new.reshape(-1,1)) # Transform X_new for predict() method y_pred = regression_model.predict(X_new_tilde) lower = regression_model.get_prediction(X_new_tilde).summary_frame(0.05)['mean_ci_lower'] # Get lower bound for each point upper = regression_model.get_prediction(X_new_tilde).summary_frame(0.05)['mean_ci_upper'] # get upper bound for each point plt.scatter(X, y) # Build a scatterplot plt.plot(X_new, y_pred) # Build a Polynomial Regression graph plt.fill_between(X_new, lower, upper, alpha=0.4) plt.show()
Zonder kennis van de verdeling van een doelvariabele kunnen we de exacte regressielijn niet bepalen. We proberen deze slechts te benaderen op basis van onze data. Het betrouwbaarheidsinterval van de regressielijn is het interval waarin de exacte regressielijn zich bevindt met het betrouwbaarheidsniveau alpha
.
Het is zichtbaar dat het interval groter wordt naarmate het verder van het bereik van de trainingsset afligt.
De betrouwbaarheidsintervallen worden opgebouwd onder de aanname dat het juiste model is gekozen (bijvoorbeeld Eenvoudige Lineaire Regressie of Polynomiale Regressie van graad 4).
Als het model slecht is gekozen, is het betrouwbaarheidsinterval onbetrouwbaar, evenals de lijn zelf. In de volgende sectie leer je hoe je het beste model selecteert.
Bedankt voor je feedback!