Home > Backend Development > Python Tutorial > Demonstrating the 68-95-99.7 rule in statistics using Python

Demonstrating the 68-95-99.7 rule in statistics using Python

WBOY
Release: 2023-09-05 13:33:10
forward
777 people have browsed it

Demonstrating the 68-95-99.7 rule in statistics using Python

Statistics provides us with powerful tools to analyze and understand data. One of the fundamental concepts in statistics is the 68-95-99.7 rule, also known as the rule of thumb or the three sigma rule. This rule allows us to make important inferences about the distribution of data based on its standard deviation. In this blog post, we will explore the 68-95-99.7 rule and demonstrate how to apply it using Python.

68-95-99.7 Rule Overview

The

68-95-99.7 rule provides a way to estimate the percentage of data in a normal distribution that is within a certain standard deviation from the mean. According to this rule -

  • Approximately 68% of the data falls within one standard deviation of the mean.

  • Approximately 95% of the data falls within two standard deviations of the mean.

  • Approximately 99.7% of the data falls within three standard deviations of the mean.

These percentages are for data sets that follow a normal distribution (also called a bell curve). Understanding this rule allows us to quickly assess the spread of data and identify outliers or unusual observations.

Implementing the 68-95-99.7 rule in Python

To demonstrate the 68-95-99.7 rule in action, we will use Python and its popular data analysis library NumPy. NumPy provides efficient numerical operations and statistical functions to help us calculate necessary values. Let’s first import the required libraries

import numpy as np
import matplotlib.pyplot as plt
Copy after login

Next, we will use the numpy.random.normal() function to generate a random data set that follows a normal distribution. We will use mean 0 and standard deviation 1

np.random.seed(42)  # Set the random seed for reproducibility
data = np.random.normal(0, 1, 10000)
Copy after login

Now, we can calculate the mean and standard deviation of the data set

mean = np.mean(data)
std = np.std(data)
Copy after login

To visualize the data and the area covered by the 68-95-99.7 rule, we can create a histogram using the matplotlib.pyplot.hist() function

plt.hist(data, bins=30, density=True, alpha=0.7)

# Plot the mean and standard deviations
plt.axvline(mean, color='r', linestyle='dashed', linewidth=1, label='Mean')
plt.axvline(mean - std, color='g', linestyle='dashed', linewidth=1, label='1 STD')
plt.axvline(mean + std, color='g', linestyle='dashed', linewidth=1)
plt.axvline(mean - 2*std, color='b', linestyle='dashed', linewidth=1, label='2 STD')
plt.axvline(mean + 2*std, color='b', linestyle='dashed', linewidth=1)
plt.axvline(mean - 3*std, color='m', linestyle='dashed', linewidth=1, label='3 STD')
plt.axvline(mean + 3*std, color='m', linestyle='dashed', linewidth=1)

plt.legend()
plt.xlabel('Value')
plt.ylabel('Density')
plt.title('Histogram of the Dataset')
plt.show()
Copy after login

The resulting histogram will show the distribution of the data with the mean and standard deviation marked with dashed lines.

To calculate the percentage coverage of each range, we can use the cumulative distribution function (CDF) of the normal distribution. The NumPy function numpy.random.normal() generates normally distributed data, but NumPy also provides numpy.random.normal() to calculate CDF

# Calculate the percentage within one standard deviation
pct_within_1_std = np.sum(np.logical_and(data >= mean - std, data 7lt;= mean + std)) / len(data)

# Calculate the percentage within two standard deviations
pct_within_2_std = np.sum(np.logical_and(data >= mean - 2*std, data <= mean + 2*std)) / len(data)

# Calculate the percentage within three standard deviations
pct_within_3_std = np.sum(np.logical_and(data >= mean - 3*std, data <= mean + 3*std)) / len(data)

print("Percentage within one standard deviation: {:.2%}".format(pct_within_1_std))
print("Percentage within two standard deviations: {:.2%}".format(pct_within_2_std))
print("Percentage within three standard deviations: {:.2%}".format(pct_within_3_std))
Copy after login

When you run this code, you will see the percentage of your data that falls within 1, 2, and 3 standard deviations of the mean.

Percentage within one standard deviation: 68.27%
Percentage within two standard deviations: 95.61%
Percentage within three standard deviations: 99.70%
Copy after login

These results are very consistent with the expected percentages for the 68-95-99.7 rule.

68-95-99.7 Explanation of rules

The percentage covered by each range has a specific interpretation. Data that fall within one standard deviation of the mean are relatively common, while data that fall outside three standard deviations of the mean are considered rare. Understanding these explanations helps make meaningful inferences about the data.

68-95-99.7 Rule Limitations

While the 68-95-99.7 rule is a valuable guideline, it may not apply accurately to data sets that deviate significantly from the normal distribution. When working with such data sets, it is crucial to consider other statistical techniques and conduct further analysis.

Outliers and the 68-95-99.7 Rule

Outliers can greatly affect the accuracy of the percentage covered by each range. These extreme values ​​may distort the distribution and affect the effectiveness of the rules. Proper identification and handling of outliers is important to ensure accurate statistical analysis.

Real life examples

68-95-99.7 Rules apply in all areas. For example, it is critical in identifying defective products in quality control processes, in assessing risk and return on investment in financial analysis, in understanding patient characteristics in healthcare research, and in understanding data distributions in many other areas.

As you dig deeper into the statistics, consider exploring other concepts that supplement the 68-95-99.7 rule. Skewness, kurtosis, confidence intervals, hypothesis testing, and regression analysis are just a few examples of statistical tools that can further enhance your understanding and analysis of your data.

in conclusion

68-95-99.7 Rules are a powerful concept in statistics that allow us to understand the distribution of data based on its standard deviation. By applying this rule, we can estimate the proportion of data that falls within a specific range around the mean. In this blog, we use Python and the NumPy library to generate a random dataset, visualize it, and calculate the percentage coverage of each range. Understanding this rule allows us to make meaningful inferences about the data and identify potential outliers or unusual observations.

The above is the detailed content of Demonstrating the 68-95-99.7 rule in statistics using Python. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:tutorialspoint.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template