Risk and profit analysis in sports betting
Manage your sports betting positions in real-time by using RisingWave to monitor exposure and risk.
Overview
Sports betting involves wagering money on the outcome of sports events. Bettors place bets on various aspects of the game, such as the winning team or the point spread. Bookmakers determine and provide details on the odds and payouts, which are continuously updated based on real-time game dynamics and market behavior.
By continuously monitoring and analyzing real-time market and betting positions data, bookmakers and bettors can make more informed decisions. Bettors can instantly calculate their profits and refine their betting strategies based on their current risk level. Bookmakers can adjust odds based on the market, maintaining profitability.
In this tutorial, you will learn how to analyze real-time betting and market data to dynamically evaluate the risk, profit, and loss of betting positions.
Prerequisites
- Ensure that the PostgreSQL interactive terminal,
psql
, is installed in your environment. For detailed instructions, see Download PostgreSQL. - Install and run RisingWave. For detailed instructions on how to quickly get started, see the Quick start guide.
- Ensure that a Python environment is set up and install the psycopg2 library.
Step 1: Set up the data source tables
Once RisingWave is installed and deployed, run the two SQL queries below to set up the tables. You will insert data into these tables to simulate live data streams.
-
The table
positions
tracks key details about each betting position within different sports league. It contains information such as the stake amount, expected return, fair value, and market odds, allowing us to assess the risk and performance of each position. -
The table
market_data
describes the market activity related to specific positions. You can track pricing and volume trends across different bookmakers, observing pricing changes over time.
Step 2: Run the data generator
To keep this demo simple, a Python script is used to generate and insert data into the tables created above.
Clone the awesome-stream-processing repository.
Navigate to the position_risk_management folder.
Run the data_generator.py
file. This Python script utilizes the psycopg2
library to establish a connection with RisingWave so you can generate and insert synthetic data into the tables positions
and market_data
.
If you are not running RisingWave locally or using default credentials, update the connection parameters accordingly:
Step 3: Create materialized views
In this demo, you will create three materialized views to gain insight on individual positions and the market risk.
Materialized views contain the results of a view expression and are stored in the RisingWave database. The results of a materialized view are computed incrementally and updated whenever new events arrive and do not require to be refreshed. When you query from a materialized view, it will return the most up-to-date computation results.
Track individual positions
The position_overview
materialized view provides key information on each position, such as the stake, max risk, market price, profit loss, and risk level. It joins the positions
table with the most recent market_price
from the market_data
table. This is done using ROW_NUMBER()
, which assigns a rank to each record based on position_id
, ordered by the timestamp in descending order.
profit_loss
is calculated as the difference between market_price
and fair_value
while risk_level
is based on profit_loss
relative to max_risk
.
You can query from position_overview
to see the results.
Monitor overall risk
The risk_summary
materialized view gives an overview on the number of positions that are considered “High”, “Medium”, or “Low” risk. Group by risk_level
from position_overview
and count the number of positions in each category.
This allows us to quickly understand overall risk exposure across all positions.
You can query from risk_summary
to see the results.
Retrieve latest market prices
The market_summary
materialized view shows the current market data for each betting from the positions
table. It joins positions
and market_data
to include the most recent market price for each bookmaker. Again, ROW_NUMBER()
is used to retrieve the most recent record for each bookmaker and position.
You can query from market_summary
to see the results.
When finished, press Ctrl+C
to close the connection between RisingWave and psycopg2
.
Summary
In this tutorial, you learn:
- How to connect to RisingWave from a Python application using
psycopg2
. - How to use
ROW_NUMBER()
to retrieve the most recent message based on the timestamp.