Polynomial Regression in R

It's Amit
9 min readDec 1, 2024

--

Have you ever heard the saying, “Not everything in life is linear”? Well, the same applies to data. While linear models work great for straight-line relationships, most real-world data doesn’t fit neatly into that category. This is where Polynomial Regression steps in. It’s like giving your linear model a makeover, allowing it to bend, twist, and follow the complex curves in your data.

What is Polynomial Regression?

At its core, polynomial regression is an extension of linear regression. But unlike linear regression, where the relationship between your independent variable (x) and dependent variable (y) is modeled as a straight line, polynomial regression models the relationship as a curved line—an nth-degree polynomial.

Here’s the deal: Instead of trying to force a straight line through data that clearly follows a curve, you can use polynomial regression to capture those non-linear patterns. Let’s break it down with a mathematical formula:

y = b0 + b1*x + b2*x^2 + ... + bn*x^n + ε

In this equation:

  • y is your dependent variable (what you want to predict).
  • x is your independent variable (your predictor).
  • b0, b1, ... bn are the coefficients that the model will estimate.
  • n is the degree of the polynomial.
  • ε is the error term (because let’s face it—no model is perfect).

This might surprise you, but simply by raising x to higher powers (like x^2, x^3, and so on), polynomial regression can follow the twists and turns of your data in a way that linear regression can’t.

Why Use Polynomial Regression?

So, you might be wondering: “Why go through all this trouble when I can just stick to linear regression?”

The truth is, linear regression is great, but it’s limited. It only works well when the relationship between x and y is linear—a straight line. But, let’s face it, most real-world data isn’t that simple.

Think about things like predicting stock prices, modeling population growth, or even estimating temperatures over time. These processes rarely follow a straight line.

Here’s where polynomial regression shines. It captures those non-linear relationships, allowing you to model curved patterns in your data. Picture this: You’re modeling the performance of a stock over time.

If you use linear regression, you’d get a straight line that may totally miss the peaks and valleys of the actual stock performance. But if you use polynomial regression, you can model the highs, the lows, and everything in between.

Now, does that mean you should always reach for polynomial regression? Not necessarily. While it’s powerful, it can easily lead to overfitting if the degree of the polynomial is too high. (Don’t worry, we’ll dive deeper into overfitting later in the blog.)

By understanding this, you can choose the right tool for the job — whether that’s sticking with a straight line or letting your model curve to fit the real-world data. And trust me, your data will thank you for it.

Mathematics Behind Polynomial Regression

They say, “Numbers don’t lie.” But if you’re only looking at data through the lens of linear regression, you might not be getting the whole story. The mathematics behind polynomial regression gives us the tools to see the curves and complexities that linear models simply miss.

Equation for Polynomial Regression

Here’s the deal: At its heart, polynomial regression is still a form of linear regression, but with a twist. Instead of just fitting a straight line to your data, polynomial regression allows the line to curve by introducing higher-degree terms.

The general equation for a polynomial regression model looks something like this:

y = b0 + b1*x + b2*x^2 + b3*x^3 + ... + bn*x^n + ε
  • y: The predicted output (your dependent variable).
  • x: Your independent variable (the input).
  • b0, b1, ..., bn: These are the coefficients the model will estimate.
  • x^n: The nth-degree polynomial term, where n can be any positive integer.
  • ε: The error term, which accounts for the small differences between the predicted and actual values (because no model is perfect, right?).

Now, let’s break it down. In a regular linear regression model, you’d stop at b1*x. That’s where you’re limited to a straight line. But by adding higher powers of x, like x^2, x^3, and so on, your model can flex and bend, fitting curves to your data.

Imagine you’re modeling the growth of a plant. In the beginning, the plant grows slowly, but then, with enough sunlight and water, its growth rate skyrockets. A linear model would just draw a straight line and miss that critical curve, but a polynomial model could capture that acceleration.

Difference Between Linear and Polynomial Regression

This might surprise you, but at their core, linear and polynomial regression are very similar. The key difference? The complexity of the relationship they’re trying to model.

  • Linear Regression: Think of it as the “straight-shooter.” It fits a straight line that minimizes the error between the predicted and actual values. The equation looks like this:
y = b0 + b1*x + ε

It’s great for data that follows a straight line, but if your data curves, linear regression falls short.

Polynomial Regression: On the other hand, polynomial regression doesn’t just settle for a straight line. It’s flexible and fits curves by introducing higher-degree terms of x. The more terms you add, the more complex the curve becomes.

The formula for a second-degree polynomial regression (a quadratic model) would look like this:

y = b0 + b1*x + b2*x^2 + ε

And for a third-degree polynomial (cubic model):

y = b0 + b1*x + b2*x^2 + b3*x^3 + ε

You might be wondering: “How do I decide whether to use linear or polynomial regression?” Well, it depends on your data. If a straight line doesn’t capture the pattern in your data, polynomial regression is a powerful tool that can help you model those non-linear relationships.

Overfitting and Degree of the Polynomial

Here’s the tricky part. With great power comes great responsibility — overfitting is the nemesis of polynomial regression.

The more terms (or degrees) you add to your polynomial, the more complex the model becomes. Sure, it will fit your training data beautifully, but it might be too good. If the model becomes too complex, it starts to capture the noise in your data rather than the underlying pattern. This is called overfitting, and it’s a classic problem in machine learning.

For example, if you use a 10th-degree polynomial to fit a small dataset, the model might zigzag wildly between data points, capturing every little fluctuation. It’ll look impressive at first glance, but when you try to make predictions on new data, the model will likely perform poorly. It’s like trying to memorize the answers for one specific test rather than understanding the subject — it doesn’t generalize well.

How do you avoid this? One approach is to use cross-validation to find the right degree of the polynomial. Start with a low degree (like 2 or 3) and gradually increase it, checking the model’s performance on unseen data. The goal is to strike a balance — fit the data well, but not too well.

So, the next time you’re working with data that doesn’t follow a simple line, remember: You have the power to add curves to your model with polynomial regression. But with that power comes the responsibility to avoid overfitting. By finding the right degree for your polynomial, you can model complex patterns without getting lost in the noise.

Steps to Implement Polynomial Regression in R

So, you’re ready to roll up your sleeves and dive into polynomial regression in R. It’s easier than you think! Let’s walk through the process from setting up your R environment to evaluating your model’s performance. You’ll see how polynomial regression can take your data analysis to the next level.

1. Setting Up the R Environment

Before we begin, you need to have the right tools in your toolbox. To work with polynomial regression, you’ll need some packages that will help you clean, visualize, and evaluate your data.

Here’s how to install them:

# Installing necessary packages
install.packages(c("ggplot2", "dplyr", "caret", "glmnet"))
library(ggplot2) # For data visualization
library(dplyr) # For data manipulation
library(caret) # For model training and cross-validation
library(glmnet) # For regularization methods (we'll discuss this later)

Once you’ve got these packages installed, you’re all set to start working with polynomial regression!

2. Loading and Preparing Data

You might be wondering: “What dataset should I use?” To keep things simple, let’s use a built-in dataset in R: mtcars. This dataset contains data about different car models, and we’ll use it to predict miles per gallon (mpg) based on horsepower (hp).

# Load the dataset
data(mtcars)
head(mtcars)
# Select the relevant variables
df <- mtcars %>% select(mpg, hp)
# Optional: Check for missing values
sum(is.na(df))
# No missing values in this dataset, so we can move forward

In real-world applications, you’d also need to handle missing data or scale features if necessary. For now, our data is clean, so let’s move on.

3. Creating Polynomial Features

This might surprise you, but creating polynomial features is as simple as calling one function. You can either manually create them or use the poly() function in R to automate the process.

Here’s how you do it:

# Creating polynomial features for horsepower (hp)
df$hp_poly <- poly(df$hp, 2, raw = TRUE) # Here, '2' represents a 2nd-degree polynomial

df$hp2 <- df$hp² # Creating a squared term manually

df$hp2 <- df$hp^2  # Creating a squared term manually

4. Fitting a Polynomial Regression Model

Now that we’ve created polynomial features, it’s time to fit the model. We’ll use the lm() function in R, which stands for “linear model.” But don’t be confused by the name—this function also handles polynomial regression.

# Fitting a 2nd-degree polynomial regression model
model <- lm(mpg ~ hp + I(hp^2), data = df)
# Checking model summary
summary(model)

Here’s what’s happening:

  • We’re predicting mpg (miles per gallon) based on hp (horsepower) and its square (I(hp^2)).
  • The I() function tells R to interpret hp^2 as the square of hp, rather than a separate variable.

This gives you a model that can capture the non-linear relationship between horsepower and miles per gallon.

Visualizing Polynomial Regression

You know the saying, “A picture is worth a thousand words”? Well, a visualization is worth even more when it comes to data analysis. Let’s plot the fitted polynomial curve on top of the actual data points.

# Create a sequence of horsepower values for prediction
hp_grid <- seq(min(df$hp), max(df$hp), length.out = 100)
# Predict mpg values using the polynomial model
predictions <- predict(model, newdata = data.frame(hp = hp_grid, hp2 = hp_grid^2))
# Plot the actual data points and the fitted polynomial curve
ggplot(df, aes(x = hp, y = mpg)) +
geom_point() +
geom_line(aes(x = hp_grid, y = predictions), color = 'blue', size = 1) +
labs(title = "Polynomial Regression: MPG vs Horsepower", x = "Horsepower", y = "Miles Per Gallon")

This plot shows how well your polynomial model fits the data. The blue line represents the fitted polynomial regression curve, while the points are your actual data.

Evaluating the Model Performance

Let’s talk numbers. Once you’ve fit a model, it’s crucial to evaluate how well it performs. The usual suspects here are R-squared, Adjusted R-squared, and Root Mean Squared Error (RMSE).

# Calculate R-squared and Adjusted R-squared
summary(model)$r.squared # R-squared
summary(model)$adj.r.squared # Adjusted R-squared
# Calculate RMSE
rmse <- sqrt(mean(model$residuals^2))
rmse
  • R-squared: Tells you how well the model explains the variability in the data. The closer to 1, the better.
  • Adjusted R-squared: Adjusts for the number of predictors in the model. It’s more reliable when comparing models with different numbers of predictors.
  • RMSE: Gives you an idea of how far off the model’s predictions are, on average.

Residual Plots and Assumptions

Polynomial regression is still a linear model at heart, so the same assumptions apply — namely, the residuals should be normally distributed and homoscedastic (constant variance).

# Plot residuals
par(mfrow = c(2, 2)) # Create a 2x2 grid for plots
plot(model)

Look at the residuals vs. fitted plot and the normal Q-Q plot. These will help you assess whether the assumptions are violated.

Cross-Validation for Model Selection

This is where things get interesting. To avoid overfitting, you can use cross-validation to find the best degree of the polynomial.

# Set up cross-validation
train_control <- trainControl(method = "cv", number = 10) # 10-fold cross-validation
# Fit a model with cross-validation
cv_model <- train(mpg ~ poly(hp, 2), data = df, method = "lm", trControl = train_control)
print(cv_model)

By using cross-validation, you can tune the degree of the polynomial and find the one that gives you the best performance on unseen data.

Dealing with Overfitting and Regularization

Detecting overfitting can be tricky, but one surefire way is to compare training and test performance. If your model does really well on the training data but poorly on new data, it’s probably overfitting.

You can combat overfitting using regularization techniques like Ridge and Lasso regression. Here’s how you can implement Lasso regression:

# Set up the data for glmnet
X <- model.matrix(mpg ~ poly(hp, 2), df)[, -1] # Predictor matrix
y <- df$mpg # Response vector
# Fit a Lasso model (alpha = 1 for Lasso)
lasso_model <- cv.glmnet(X, y, alpha = 1)
# Check the lambda that minimizes cross-validation error
lasso_model$lambda.min

By applying regularization, you can control the complexity of your polynomial model, ensuring that it generalizes well to new data.

Conclusion

Polynomial regression gives you the flexibility to model complex, non-linear relationships that linear regression can’t handle.

By now, you’ve learned how to implement it in R, create polynomial features, and evaluate your model’s performance.

However, with great power comes the risk of overfitting, and that’s where techniques like cross-validation and regularization (e.g., Lasso) come in handy.

The key takeaway? Polynomial regression is a powerful tool in your data science toolkit, but it’s all about balance. Use it wisely, and let your data guide the way.

Now, go ahead — apply what you’ve learned and start modeling those curves!

--

--

It's Amit
It's Amit

No responses yet