Python Tutorial : Skewness and Kurtosis

DataCamp · Beginner ·🔢 Mathematical Foundations ·6y ago

Key Takeaways

This video tutorial covers the concepts of skewness and kurtosis in Python, using libraries such as SciPy, to analyze and understand risk in financial returns. It demonstrates how to calculate skewness and kurtosis, interpret their values, and use them to identify non-normal distributions.

Full Transcript

daily volatility and mean give you a good indication of daily risk in return but skewness kurtosis and scaled volatility will help you build a more holistic view of risk the third moment skewness can be thought of as a measure of how much a distribution leans to the left or the right negative skew is a right leaning curve while positive skew is a left leaning curve in finance you would tend to want positive skewness with a higher probability of significantly good returns on the right-hand side of the distribution and the compressed predictable left-hand distribution of negative returns to calculate the skewness of a return distribution simply call the skew function after importing skew from scipy dot stats be sure to drop any n/a values using the drop and a method skewness above zero indicates possible non normality which once again you can expect to find in financial returns kurtosis is a measure of the thickness of the tails of a distribution which can be used as a proxy for the probability of outliers if you recall normal distributions tend to have a kurtosis near 3 most financial returns are leptokurtic which simply means that they tend to have a positive excess kurtosis or kurtosis greater than 3 since kurtosis is so often compared to a normal distribution many functions in Python will automatically return excess kurtosis which is essentially the sample kurtosis minus 3 which helps demonstrate whether the probability of outliers is higher or lower than a normal distribution if excess kurtosis is higher than 0 the kurtosis is higher than a normal distribution inside pi for example the kurtosis function is actually computing excess kurtosis if you wanted to calculate the true sample kurtosis you would actually need to add 3 to the result but for most cases you're going to be interested in excess kurtosis anyways so this functionality is fine as long as you are aware of it in hi excess kurtosis is an indication of high risk when large movements in returns happen often this can be a very bad thing for your portfolio if it moves in the wrong direction high kurtosis distributions are said to have thick tails which means that outliers such as extreme negative and positive returns are more common before we move on let me briefly add one final tool to your arsenal if the kurtosis of a distribution is greater than 3 and the skewness is nonzero the data is most likely non normal but what if the values are close to but not quite normal you can use the Shapiro well Casta tist achill test to estimate the probability that the data is normally distributed the null hypothesis of the Shapiro will test is that the data are normally distributed and when the p-value returned is less than or equal to 0.05 that means you can safely reject the null hypothesis and assume that the data are non normal now it's your turn

Original Description

Want to learn more? Take the full course at https://learn.datacamp.com/courses/introduction-to-portfolio-risk-management-in-python at your own pace. More than a video, you'll learn hands-on coding & quickly apply skills to your daily work. --- Daily volatility and mean give you a good indication of daily risk and return, but skewness, kurtosis, and scaled volatility will help you build a more wholistic view of risk. The third moment, skewness, can be thought of as a measure of how much a distribution leans to the left or right. Negative skew is a right-leaning curve, while positive skew is a left leaning curve. In finance, you would tend to want positive skewness, with a higher probability of significantly good returns on the right hand side of the distribution, and a compressed, predictable left-hand distribution of negative returns. To calculate the skewness of a return distribution, simply call the skew() function after importing skew from scipy dot stats. Be sure to drop any NA values using the dropna() method. Skewness above 0 indicates possible non-normality, which once again you can expect to find in financial returns. Kurtosis is a measure of the thickness of the tails of a distribution, which can be used a proxy for the probability of outliers. If you recall, normal distributions tend to have a kurtosis near 3. Most financial returns are leptokurtic, which simply means that they tend to have positive excess kurtosis, or kurtosis greater than 3. Since kurtosis is so often compared to a normal distribution, many functions in Python will automatically return excess kurtosis, which is essentially the sample kurtosis minus 3, which helps demonstrate whether the probability of outliers is higher or lower than a normal distribution. If excess kurtosis is higher than 0, the kurtosis is higher than a normal distribution. In SciPy, for example, the kurtosis function is actually computing excess kurtosis. If you wanted to calculate the true sample kurtosis,
Watch on YouTube ↗ (saves to browser)
Sign in to unlock AI tutor explanation · ⚡30

Playlist

Uploads from DataCamp · DataCamp · 0 of 60

← Previous Next →
1 SQL Server Tutorial: Date manipulation
SQL Server Tutorial: Date manipulation
DataCamp
2 R Tutorial: Intermediate Interactive Data Visualization with plotly in R
R Tutorial: Intermediate Interactive Data Visualization with plotly in R
DataCamp
3 R Tutorial: Adding aesthetics to represent a variable
R Tutorial: Adding aesthetics to represent a variable
DataCamp
4 R Tutorial: Moving Beyond Simple Interactivity
R Tutorial: Moving Beyond Simple Interactivity
DataCamp
5 Python Tutorial: Why use ML for marketing? Strategies and use cases
Python Tutorial: Why use ML for marketing? Strategies and use cases
DataCamp
6 Python Tutorial: Preparation for modeling
Python Tutorial: Preparation for modeling
DataCamp
7 Python Tutorial: Machine Learning modeling steps
Python Tutorial: Machine Learning modeling steps
DataCamp
8 R Tutorial: The prior model
R Tutorial: The prior model
DataCamp
9 R Tutorial: Data & the likelihood
R Tutorial: Data & the likelihood
DataCamp
10 R Tutorial: The posterior model
R Tutorial: The posterior model
DataCamp
11 R Tutorial: An Introduction to plotly
R Tutorial: An Introduction to plotly
DataCamp
12 R Tutorial: Plotting a single variable
R Tutorial: Plotting a single variable
DataCamp
13 R Tutorial: Bivariate graphics
R Tutorial: Bivariate graphics
DataCamp
14 Python Tutorial: Customer Segmentation in Python
Python Tutorial: Customer Segmentation in Python
DataCamp
15 Python Tutorial: Time cohorts
Python Tutorial: Time cohorts
DataCamp
16 Python Tutorial: Calculate cohort metrics
Python Tutorial: Calculate cohort metrics
DataCamp
17 Python Tutorial: Cohort analysis visualization
Python Tutorial: Cohort analysis visualization
DataCamp
18 R Tutorial: Building Dashboards with flexdashboard
R Tutorial: Building Dashboards with flexdashboard
DataCamp
19 R Tutorial: Anatomy of a flexdashboard
R Tutorial: Anatomy of a flexdashboard
DataCamp
20 R Tutorial: Layout basics
R Tutorial: Layout basics
DataCamp
21 R Tutorial: Advanced layouts
R Tutorial: Advanced layouts
DataCamp
22 Python Tutorial: Time Series Analysis in Python
Python Tutorial: Time Series Analysis in Python
DataCamp
23 Python Tutorial: Correlation of Two Time Series
Python Tutorial: Correlation of Two Time Series
DataCamp
24 Python Tutorial: Simple Linear Regressions
Python Tutorial: Simple Linear Regressions
DataCamp
25 Python Tutorial: Autocorrelation
Python Tutorial: Autocorrelation
DataCamp
26 R Tutorial: The gapminder dataset
R Tutorial: The gapminder dataset
DataCamp
27 R Tutorial: The filter verb
R Tutorial: The filter verb
DataCamp
28 R Tutorial: The arrange verb
R Tutorial: The arrange verb
DataCamp
29 R Tutorial: The mutate verb
R Tutorial: The mutate verb
DataCamp
30 R Tutorial: What is cluster analysis?
R Tutorial: What is cluster analysis?
DataCamp
31 R Tutorial: Distance between two observations
R Tutorial: Distance between two observations
DataCamp
32 R Tutorial: The importance of scale
R Tutorial: The importance of scale
DataCamp
33 R Tutorial: Measuring distance for categorical data
R Tutorial: Measuring distance for categorical data
DataCamp
34 Python Tutorial: Plotting multiple graphs
Python Tutorial: Plotting multiple graphs
DataCamp
35 Python Tutorial: Customizing axes
Python Tutorial: Customizing axes
DataCamp
36 Python Tutorial: Legends, annotations, & styles
Python Tutorial: Legends, annotations, & styles
DataCamp
37 Python Tutorial: Introduction to iterators
Python Tutorial: Introduction to iterators
DataCamp
38 Python Tutorial: Playing with iterators
Python Tutorial: Playing with iterators
DataCamp
39 Python Tutorial: Using iterators to load large files into memory
Python Tutorial: Using iterators to load large files into memory
DataCamp
40 SQL Tutorial: Introduction to Relational Databases in SQL
SQL Tutorial: Introduction to Relational Databases in SQL
DataCamp
41 SQL Tutorial: Tables: At the core of every database
SQL Tutorial: Tables: At the core of every database
DataCamp
42 SQL Tutorial: Update your database as the structure changes
SQL Tutorial: Update your database as the structure changes
DataCamp
43 Python Tutorial: Classification-Tree Learning
Python Tutorial: Classification-Tree Learning
DataCamp
44 Python Tutorial: Decision-Tree for Classification
Python Tutorial: Decision-Tree for Classification
DataCamp
45 Python Tutorial: Decision-Tree for Regression
Python Tutorial: Decision-Tree for Regression
DataCamp
46 Python Tutorial: Census Subject Tables
Python Tutorial: Census Subject Tables
DataCamp
47 Python Tutorial: Census Geography
Python Tutorial: Census Geography
DataCamp
48 Python Tutorial: Using the Census API
Python Tutorial: Using the Census API
DataCamp
49 R Tutorial: A/B Testing in R
R Tutorial: A/B Testing in R
DataCamp
50 R Tutorial: Baseline Conversion Rates
R Tutorial: Baseline Conversion Rates
DataCamp
51 R Tutorial: Designing an Experiment - Power Analysis
R Tutorial: Designing an Experiment - Power Analysis
DataCamp
52 R Tutorial: Introduction to qualitative data
R Tutorial: Introduction to qualitative data
DataCamp
53 R Tutorial: Understanding your qualitative variables
R Tutorial: Understanding your qualitative variables
DataCamp
54 R Tutorial: Making Better Plots
R Tutorial: Making Better Plots
DataCamp
55 SQL Tutorial: OLTP and OLAP
SQL Tutorial: OLTP and OLAP
DataCamp
56 SQL Tutorial: Storing data
SQL Tutorial: Storing data
DataCamp
57 SQL Tutorial: Database design
SQL Tutorial: Database design
DataCamp
58 Python Tutorial: Introduction to spaCy
Python Tutorial: Introduction to spaCy
DataCamp
59 Python Tutorial: Statistical Models
Python Tutorial: Statistical Models
DataCamp
60 Python Tutorial: Rule-based Matching
Python Tutorial: Rule-based Matching
DataCamp

This video tutorial teaches you how to calculate and interpret skewness and kurtosis in Python, and how to use these metrics to analyze financial returns and identify non-normal distributions. By the end of this lesson, you'll be able to apply these concepts to real-world data analysis tasks.

Key Takeaways
  1. Import the necessary libraries, including SciPy
  2. Calculate the skewness of a return distribution using the skew function
  3. Calculate the kurtosis of a return distribution using the kurtosis function
  4. Interpret the values of skewness and kurtosis
  5. Use the Shapiro-Wilk test to estimate the probability that the data is normally distributed
💡 Skewness and kurtosis are important metrics for understanding risk in financial returns, and can be used to identify non-normal distributions.

Related AI Lessons

Up next
How to Open OSM Files (OpenStreetMap Data)
File Extension Geeks
Watch →