A little helper to help automatically find key drivers of KPIs through time.
Project description
Key Drivers
A Python library for helping making sense of business data
Introduction
Key Driver Analysis is a statistical technique used to identify the key drivers of a target variable. In the context of KPI analysis within a dimensional model, a key driver is a dimension (or combination of dimensions) that has an outsied influence on the change in target KPI. For example, in a sales dataset, the key drivers of sales might be the store location, the product category, or the type of store.
Features
This repository contains some Python helper code to help you perform Key Driver Analysis on your data. It does this through 3 main steps:
- Metric Decomposition: Decompose the change in the metric into the change in the factors that make up the metric. These factors will be denominated in the value of the top-level metric, and are additive (and thus can be grouped via summation without fear).
- Category Merging: To clean up many similar-behaving small dimensional categories into a larger, more meaningful category, we apply a clustering procedure to the raw dimensions based on the metric decomposition behaviour. This makes for more meaningful notions of "key drivers".
- Key Driver Identification: Finally, we apply a process to identify the largest contributors to the change in the target metric. This is done by calculating the change in the target metric for each combination of dimensions, and flagging those with a small membership but large change in the target.
At all stages, the data can be re-sliced, allowing drilldown into specific aspects of data, or summarised into top-level KPIs. The code is designed to be used in conjunction with pandas DataFrames, and can be used within a Jupyter notebook or other Python environment.
Metric Decomposition
We can typically represent any value flow in a company as a series of steps in a funnel; for example, a sales funnel might be represented as:
- Leads become conversions
- Conversions become orders
- Conversions have some average value
- Total of orders gives sales
In many cases, the funnel represents a series of "drop-off" steps, but we can also add in steps beyond conversion to denominate the total value to the organisation. Thinking in this way, as a series of bottlenecks before recording a profit, we can often decompose any value stream into a series of multiplication operation. For example, We can represent the above steps as a formula:
sales = leads * conversion_rate * average_value
Sometimes, we can also add in additional factors that are not directly related to the funnel, but still contribute to the final value. For example, we might add in a factor for promotions discounting listed sales values, or operating expenses. These factors can be added in as additional terms in the formula, and can be decomposed in the same way (even though the analogy of a funnel is stretching at this point). The key thing is that the target KPI can be expressed as the product of factors, and that these factors are generally consistent in sign. (This condition is mainly for sanity rather than mathematical necessity - even a 0 makes sense so long as not all values are 0.) Similarly, changes in the target KPI can be decomposed into changes in the factors that make up the KPI.
There is one issue with the above example; the units of each of the factors. In the above example, the conversion rate is a percentage, the average value is a currency, and the leads are a count. If we want to go beyond basic trends and make decisions to improve our KPI, we would like to be able to compare the relative importance of each of these factors. To do this, we need to normalise the factors to a common unit. Ideally, we'd like to be able to talk in the unit of the KPI, so that the factors can be compared as a sum rather than a product. This is the purpose of the metric decomposition.
The metric decomposition is a process that takes the change in the target KPI and decomposes it into the change in the factors that make up the KPI. The details are a little arcane, but have a solid geometric argument to support it. Please see the articles listed in the Further Reading
section, or the attached examples, for more details. The key takeaway is this process can be applied to any KPI that can be represented as a product of factors, and that the factors can be decomposed into a sum in the unit of the target KPI.
Assumptions
For the metric decomposition to be successful, we make a few assumptions about the data to be treated:
- The target variable is a continuous variable
- The target variable is a product of the independent variables, and thus can be represented as a funnel
- The independent variables are generally consistent in sign
- The dimensions for analysis are categorical, and can be treated as exchangeable.
In general, the second step can generally be achieved, though you may need to rethink additive relationships (such as losses due to discounts) in order to satisfy this condition.
Further Reading
Work on general decomposition was motivated by the following posts:
Example Code
Before you can run the code below, you need to install the required packages. If you're using PDM you can do this by running pdm install
in the root of the repository. Otherwise, you can install the dev dependencies listed in pyproject.toml
. You'll also need to have a local copy of the Store Sales - Time Series Forecasting
dataset. You can download this from the Kaggle page. If you unpack these files directly into the examples folder, the notebooks should run fine.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file key_drivers-0.1.6.tar.gz
.
File metadata
- Download URL: key_drivers-0.1.6.tar.gz
- Upload date:
- Size: 15.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.19.0a0 CPython/3.10.12 Linux/6.8.0-1014-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1c3685b9490339b1b828afc8685150453653fb5415b5523e3bc6dc66d65baf0e |
|
MD5 | b6831028211d29f221d80280a8477273 |
|
BLAKE2b-256 | 7b9dd38e1b1dc0495216be3c1812a51e65af77094f9c55a2665cd038ed503096 |
File details
Details for the file key_drivers-0.1.6-py3-none-any.whl
.
File metadata
- Download URL: key_drivers-0.1.6-py3-none-any.whl
- Upload date:
- Size: 14.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.19.0a0 CPython/3.10.12 Linux/6.8.0-1014-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5ac60f2ab6215500063d3e008112b8a002162cf99aad7d3574c0fff9bb2c3aac |
|
MD5 | 76a7ad22a19dce706634edd76f279463 |
|
BLAKE2b-256 | 2f208bbc242e7db600332685ad4dec7a29e0b7d270b88d36dda6995f6e295b81 |