top of page

A Comprehensive Guide to Quantifying, Visualizing, and Handling Unusual Values in Model Fitting



Quantifying Model Fit


Introduction to Model Fit


The quality of a statistical model's fit to the data is crucial for its predictive ability. It's like tailoring a suit; if it fits well, it looks good and functions effectively. On the other hand, a poorly fitting suit is unappealing and uncomfortable. In this section, we'll understand the metrics used to quantify how good a model fits.


Modeling Mass versus Length for Specific Species


Suppose you're observing the relationship between the length and mass of fish in different species. It's like comparing the height and weight of individuals; naturally, taller individuals tend to weigh more.

Observation of Scatter Plots

import matplotlib.pyplot as plt

mass = [50, 60, 70, 80, 90]
length = [30, 35, 40, 45, 50]

plt.scatter(mass, length)
plt.xlabel('Mass')
plt.ylabel('Length')
plt.title('Scatter plot of Mass vs Length')
plt.show()

The output will be a scatter plot illustrating the relationship between mass and length.


Assessing the Linear Relationship


If the points on the scatter plot resemble a straight line, we can say there's a linear relationship.


Coefficient of Determination (R-squared)


The R-squared value measures how well the model's predictions match the actual data. Imagine it as a scoring system for a game; the higher the score, the better you've played.

Definition and Notation of R-squared

import statsmodels.api as sm

X = sm.add_constant(length)
model = sm.OLS(mass, X).fit()

r_squared = model.rsquared
print(f'R-squared value is: {r_squared}')


This code snippet will return the R-squared value for the model.

Interpretation of Different R-squared Scores

An R-squared value close to 1 means a great fit, like finding a shoe that fits perfectly. A value closer to 0 means a poor fit.


Summary Method in Python


To get a detailed summary of the model's performance, use the .summary() method.

summary = model.summary()
print(summary)


Accessing R-squared Value

Extracting the R-squared value is simple with the .rsquared attribute.

r_squared = model.rsquared
print(f'R-squared value is: {r_squared}')


R-squared Interpretation


Think of R-squared as a percentage, where 100% means the model explains all variability, and 0% means none.


Residual Standard Error (RSE)


The RSE tells us the typical difference between the actual and predicted values. Imagine it as the average difference in height among different people in a town.

Definition and Interpretation of RSE

Calculating the RSE involves several steps, including understanding the Mean Squared Error (MSE).


Accessing Mean Squared Error

mse_resid = model.mse_resid
print(f'Mean Squared Error is: {mse_resid}')


Calculating RSE from MSE


RSE can be calculated as the square root of MSE.

import numpy as np

RSE = np.sqrt(mse_resid)
print(f'Residual Standard Error is: {RSE}')


Manual Calculation of RSE


To calculate the RSE manually, we need to understand the degrees of freedom, sum the squared residuals, and find the square root.

n = len(mass)
p = 1 # Number of predictors
RSS = sum((model.resid) ** 2)
RSE_manual = np.sqrt(RSS / (n - p - 1))
print(f'Manual calculation of RSE is: {RSE_manual}')


Interpreting RSE Value


The RSE value can be thought of as an average error. The lower it is, the more accurate the model is.


Root-Mean-Square Error (RMSE)


The RMSE is another way to quantify model fit and can be thought of as the standard deviation of the residuals.

RMSE = np.sqrt(model.mse_resid)
print(f'Root Mean Square Error is: {RMSE}')


The RMSE and RSE are similar but may differ depending on the context.

We've now covered the core concepts and techniques to quantify the model fit, along with practical Python examples. In the next part of this tutorial, we'll explore techniques to visualize the model fit, further deepening our understanding.


Visualizing Model Fit


Introduction to Model Performance Plots


Visualizing a model's performance is like looking at a painting; you can see the whole picture at once and quickly understand its structure. Various plots help us to quantify the model's performance and identify areas for improvement.


Residual Properties


Residuals are the differences between observed and predicted values. Understanding their distribution is key to a good fit.


Understanding the Distribution of Residuals


A well-fitted model should show residuals scattered randomly around zero, like evenly spaced stars in the night sky.

plt.scatter(model.fittedvalues, model.resid)
plt.xlabel('Fitted values')
plt.ylabel('Residuals')
plt.title('Residuals vs Fitted values')
plt.show()

The resulting plot will help you understand the spread of residuals.


Model Analysis of Specific Species


Let's consider an example where we assess the model fit using scatter plots for specific species of fish.


Assessing Model Fit Using Scatter Plots

import seaborn as sns

sns.lmplot(x="length", y="mass", data=data, hue="species")
plt.show()

This will display separate regression lines for different species, allowing you to visually assess the fit for each.


Residuals vs. Fitted Plot


This plot helps you understand how residuals are distributed around the regression line.


Creating and Interpreting This Plot

plt.scatter(model.fittedvalues, model.resid)
plt.xlabel('Fitted values')
plt.ylabel('Residuals')
plt.title('Residuals vs Fitted values')
plt.axhline(y=0, color='r', linestyle='-')
plt.show()

A random scatter around the horizontal red line indicates a good fit.


Q-Q Plot


The Q-Q plot compares the distribution of residuals to a normal distribution.


Definition and Application of Q-Q Plot

import statsmodels.api as sm

sm.qqplot(model.resid, line='s')
plt.show()

A straight line in the Q-Q plot indicates that the residuals are normally distributed.


Scale-Location Plot


This plot helps understand the spread and size of residuals.


Creating and Interpreting Scale-Location Plot

plt.scatter(model.fittedvalues, np.sqrt(abs(model.resid)))
plt.xlabel('Fitted values')
plt.ylabel('Sqrt of Residuals')
plt.title('Scale-Location Plot')
plt.show()

A random spread indicates homoscedasticity, meaning the residuals are evenly spread.


Plotting with residplot and qqplot Functions


Libraries like Seaborn and Statsmodels offer functions to create these plots easily.


Creating Plots Using Specific Functions

sns.residplot(x="length", y="mass", data=data)
sm.qqplot(model.resid, line='s')
plt.show()

These functions provide customized plots for easier interpretation.


Scale-Location Plot Creation in Python


You can also create the scale-location plot manually in Python, providing more control over its appearance.

plt.scatter(model.fittedvalues, np.sqrt(abs(model.resid)))
plt.xlabel('Fitted values')
plt.ylabel('Sqrt of Absolute Residuals')
plt.title('Scale-Location Plot')
plt.show()

We've explored various methods to visually assess the quality of a model's fit. These plots are vital tools in a data scientist's toolkit, offering valuable insights that might not be apparent from numerical metrics alone.


Outliers, Leverage, and Influence


Introduction to Unusual Values in Datasets


Data analysis often uncovers surprising insights, but not all surprises are pleasant. Outliers and influential points can dramatically affect your model's performance, like a rock in a shoe that affects your walking. Let's learn how to identify and deal with these pesky issues.


Analyzing a Specific Species Dataset


Examining specific examples will help you identify unusual data points.


Visualizing Outliers in a Given Dataset

import seaborn as sns

sns.boxplot(x=data['mass'])
plt.title('Boxplot for Mass')
plt.show()

Boxplots are handy for spotting outliers, as the points outside the "whiskers" represent potential outliers.


Types of Outliers


Outliers come in various forms, and understanding them is like knowing different types of pests that can infest a garden.


Understanding Extreme Explanatory Values

# Scatter plot to identify extreme x values
plt.scatter(data['length'], data['mass'])
plt.xlabel('Length')
plt.ylabel('Mass')
plt.title('Scatter Plot for Length vs Mass')
plt.show()

Here, any points lying far from the others in the X-axis are potential explanatory outliers.


Identifying Response Values Far from Regression Line


If you imagine the regression line as a highway, these outliers are like cars off the road.

plt.scatter(data['length'], data['mass'])
plt.plot(data['length'], model.predict(), color='red')
plt.xlabel('Length')
plt.ylabel('Mass')
plt.title('Identifying Outliers from Regression Line')
plt.show()


Look for points far from the red line (regression line).


Leverage and Influence


These concepts are like the rudder on a ship; a small part can have a significant impact.


Definitions and Understanding of Leverage and Influence


Leverage measures how far an independent variable is from its mean, while influence is a combination of leverage and outlier effect.


Retrieving Leverage and Influence Metrics


Finding these values is essential to know which points are affecting your model.

Using .get_influence() and .summary_frame() Methods

influence = model.get_influence()
summary_frame = influence.summary_frame()

You can then access the leverage values with summary_frame['hat_diag'].


Cook's Distance


This distance measures the effect of deleting a particular observation.


Definition and Usage in Understanding Influence

# Cook's distance plot
plt.stem(summary_frame['cooks_d'], markerfmt=",")
plt.title("Cook's Distance Plot")
plt.show()

Higher Cook's distance indicates more influential points.


Identifying Most Influential Data Points


Like finding the key players in a game, identifying the most influential points helps you understand your model's dynamics.


Sorting and Identifying Influential Points


influential_points = summary_frame.sort_values('cooks_d', ascending=False).head()


Impact of Removing Influential Data


Removing an influential point can change the game, like removing a star player from a team.


Analyzing the Change in Regression by Removing an Influential Data Point

# Removing influential data
new_data = data.drop(influential_points.index)
new_model = sm.OLS(new_data['mass'], sm.add_constant(new_data['length'])).fit()

# Comparing old and new models
plt.plot(data['length'], model.predict(), color='red', label='Original Model')
plt.plot(new_data['length'], new_model.predict(), color='blue', label='New Model')
plt.legend()
plt.show()


You will see how the regression line changes, illustrating the impact of the influential points.


Understanding and handling outliers, leverage, and influence are key skills in data science. They enable you to detect and deal with hidden factors that can skew your analysis. Like a detective, you have the tools to uncover these hidden influences and make more informed decisions.

bottom of page