06 Density Curves
06 Density Curves#
%%html
<iframe width="700" height="400" src="https://www.youtube.com/embed/PUvUQMQ7xQk/" frameborder="0" allowfullscreen></iframe>
import numpy as np
import pandas as pd
from pandas import Series, DataFrame
import matplotlib.pyplot as plt
import seaborn as sns
from scipy import stats
Towards Data Science - Histograms and Density Plots in Python
x = Series([0.5, 0.7, 2.1, 2.2, 2.9, 3.2, 3.2, 3.3, 3.7, 4.5, 4.6, 4.8, 5.2, 5.3, 6.7, 8.1])
x.plot(kind='hist')
<AxesSubplot:ylabel='Frequency'>
data:image/s3,"s3://crabby-images/d013b/d013bf67ab0aaaabd774c4631c68c85ba2201340" alt="../_images/06 Density Curves_7_1.png"
x.plot(kind='density')
<AxesSubplot:ylabel='Density'>
data:image/s3,"s3://crabby-images/5acde/5acde63b4ef6166594f97a0f5388d49d4fc0198a" alt="../_images/06 Density Curves_8_1.png"
sns.distplot(x)
/opt/hostedtoolcache/Python/3.9.13/x64/lib/python3.9/site-packages/seaborn/distributions.py:2619: FutureWarning: `distplot` is a deprecated function and will be removed in a future version. Please adapt your code to use either `displot` (a figure-level function with similar flexibility) or `histplot` (an axes-level function for histograms).
warnings.warn(msg, FutureWarning)
<AxesSubplot:ylabel='Density'>
data:image/s3,"s3://crabby-images/818ef/818ef1048581c51e468be61bfef8de69e6debd2b" alt="../_images/06 Density Curves_9_2.png"
# https://stackoverflow.com/questions/4150171/how-to-create-a-density-plot-in-matplotlib
density = stats.gaussian_kde(x)
xs = np.arange(0., 8, .1)
density.covariance_factor = lambda : .25 # to remove
density._compute_covariance() # to remove
plt.plot(xs,density(xs))
plt.show()
data:image/s3,"s3://crabby-images/8ba56/8ba563f1dce7a1bed43cd586927ef666bdf03dc0" alt="../_images/06 Density Curves_10_0.png"