Fair Bets for Blockchain
Summary
Here I share my thoughts on blockchain betting technology, its comparison to bookmaker betting, overview of currently existing schemes of blockchain bets and their disadvantages.
I also propose a new kind of blockchain bets, aimed to solve some problems.
Introduction
When two friends make a bet, they don’t need a bookmaker to count results and pay the revenue. But when many unfamiliar people want to make bets the problems arise:
- How to collect money for bets and later distribute revenues?
- How to solve trust issues, as you don’t know what bets other people have made, and you may not believe your revenue is calculated correctly?
Typically, a bookmaker – a third party – is called to solve both problems. People make bets and give a bookmaker their money; it computes results and distributes incomes, taking only a small percent for his work.
However, according to the Game Theory, a bookmaker would have a desire to cheat. Indeed, it can earn more money if it decides to compute revenue incorrectly. Simply because its clients don’t have all the information required to check its computation. Shortly – the more money a gamer loses – the more money bookmaker wins. That is why the problem of trust remains.
Blockchain technology was invented to solve both problems, thought it was aimed initially for another target – for cryptocurrency transfers. In general, Blockchain allows many people which are unfamiliar and don’t trust each other to safely utilize a common public database of some records.
Features of Blockchain make it ideally suited for betting and solve both problems at once. Now any person can see all the bets of other persons, and revenues are computed automatically, so nobody can cheat.
Different Schemes of Blockchain Bets
However, betting in Blockchain is different from bookmaker’s betting. Currently, there are following kinds of bets possible:
- Pool bets
- Peer-to-peer bets
- Multi-peer bets
Pool Bets
Players bet on their desired outcomes and all stakes go into a single pool. Winners share the pool. The odds are dynamic and depend on the number of participants and the amounts they wagered.
This means you do not know what odds will be when you place a bet. To increase your part of stake you need to place a greater amount in pool.
This may lead to a situation, that you’ve placed a bet on team A at the beginning of a game, when nobody believed in it. But at the end of the game team A gained leadership, and many more people also placed their bets on team A. Thus making your part of revenue stake smaller.
Peer-to-peer Bets
The purest form of peer-to-peer betting. One player opens the bet and defines the odds and the size he wants for the bet, and another player matches the bet.
This also means that you may fail to find another player to match your bet! Some platforms offer solution to this problem by establishing “Houses”, which can provide liquidity for some fixed fee.
Example: There will be a game between team A and team B. You don’t know which team has more chances to win, but you like the team A. Your probability for the team A to win is 50%. Hence, your odds for team A is 2.0, and the same value for team B. You place a bet (A: 2.0, B: 2.0) and wait for some other user, who thinks that team B will win, to join your bet.
Multi-peer Bets
If you want to bet for a large amount, you may end up failing to find a peer for your bet. The solution for this case: your bet can be partially matched by multiple players. Similar to peer-to-peer bets, the odds are defined by the player who opens the bet.
Empirical Study
Establishing criteria
In order to design a better blockchain betting scheme, we first need to select the evaluation criteria.
I believe that a good betting scheme:
- makes it easy and quick to place a bet.
- provides for a fair distribution of winnings.
Let’s try to find some criteria for easiness and fairness.
Kinds of Betting Players
A beginner or an experienced one. These two kinds of players may have different expectation of easiness of placing bets.
Manual Odds
When you want to make a bet do you need to specify odds? Or you can simply bet on team A or team B?
I believe, that beginners prefer to make simple bets. Whereas more experienced players may prefer to specify odds manually, as this way they can precisely manage their risk.
Adjustable Bet Size
Of course, a good betting scheme is one, where you can freely choose the amount to bet. So you can manage your risk.
But this condition can contradict the previous condition, where you can specify odds manually.
Quick Bets
The quicker you can make a bet - the better the technology is. I believe, in a good betting scheme you do NOT have to wait or look for another player to join your bet.
But this condition depends on two previous conditions: can you choose the odds and the size of the bet.
When Loser Wins
First we should separate experience a player gets betting on different matches:
- When one team is stronger than other, and soon after the start of the match it gains leadership. These matches become not interesting, as soon as you recognize the leader. But, of course, surprises are still possible, albeit rare.
- When competing teams are almost equal, and leadership during the match shifts from one team to another several times. These matches are the most interesting, because until the end of match, no one knows which team will win.
I believe, in a fair betting scheme when you bet on an obvious loser, and it suddenly wins - you should get more revenue.
Information Depended Revenue
Next we should distinguish when the player made a bet:
- before the match or shortly after the start
- during the match
- almost the end of the match
This is important: The earlier you place a bet - the less information you have to choose a team for the bet. Conversely, the closer to the end of the match you place your bet, the more confident you are in the most likely winner.
I believe, in a fair betting scheme the earlier you make a bet - the more revenue you should get.
Table of Criteria
Criteria | Value | Score for beginners | Score for matures |
---|---|---|---|
Can player specify odds manually? | Yes/No | 0..1 | 0..1 |
Can player freely choose the amount to bet? | Yes/No | 0..1 | 0..1 |
You do NOT have to wait or look for another player? | Yes/No | 0..1 | 0..1 |
Do you get more revenue if you bet on obvious loser, and it suddenly wins? | Yes/No | 0..1 | 0..1 |
Do you get more revenue if place your bet earlier? | Yes/No | 0..1 | 0..1 |
Results: | 0..5 | 0..5 |
Now that we specified the criteria, we can evaluate existing blockchain betting schemes.
Evaluating existing schemes
Pool bets
In pool bets the best strategy is to place one big bet towards the end of a match, when it becomes clear which team is leading. Also putting a lot of money increases your chance to get major part a winning stake.
A naive better will soon realize that placing bets on his favorite team at the beginning of a match - is a bad strategy, and over time he may switch to the strategy, described above.
If many betters follow this best strategy then winning pool will be almost empty, because towards the end of a match nobody will place bet on a team which is likely to lose.
Criteria | Value | Score for beginners | Score for matures |
---|---|---|---|
Can player specify odds manually? | No | 1 | 0 |
Can player freely choose the amount to bet? | Yes | 1 | 1 |
You do NOT have to wait or look for another player? | Yes | 1 | 1 |
Do you get more revenue if you bet on obvious loser, and it suddenly wins? | Yes | 1 | 1 |
Do you get more revenue if place your bet earlier? | No | 0 | 0 |
Results: | 4 | 3 |
This betting scheme has its advantages for beginner players. But I believe, over time, interest in this kind of bets will fade away.
Peer-to-peer Bets
Criteria | Value | Score for beginners | Score for matures |
---|---|---|---|
Can player specify odds manually? | Yes | 0 | 0.5 |
Can player freely choose the amount to bet? | Yes | 0.5 | 0.5 |
You do NOT have to wait or look for another player? | No | 0 | 0 |
Do you get more revenue if you bet on obvious loser, and it suddenly wins? | Yes | 1 | 1 |
Do you get more revenue if place your bet earlier? | No | 0 | 0 |
Results: | 1.5 | 2 |
The main disadvantage of this betting scheme is the fact that player needs to search or wait for other player to place a bet.
Also, you can, of course, freely choose the odds and the amount to bet. But in fact you may fail to find a peer player who will agree to accept your numbers.
That is why I put values of 0.5 for some criteria.
Multi-peer Bets
Criteria | Value | Score for beginners | Score for matures |
---|---|---|---|
Can player specify odds manually? | Yes | 0 | 0.8 |
Can player freely choose the amount to bet? | Yes | 0.8 | 0.8 |
You do NOT have to wait or look for another player? | No | 0 | 0 |
Do you get more revenue if you bet on obvious loser, and it suddenly wins? | Yes | 1 | 1 |
Do you get more revenue if place your bet earlier? | No | 0 | 0 |
Results: | 1.8 | 2.6 |
The main disadvantage of this betting scheme is the same as with previous, that player needs to search or wait for other player to place a bet.
In this scheme you may also freely choose the odds and the amount to bet, but fail to find a peer player who will agree to accept your numbers. Nevertheless, here you have more chances to make a bet than in a previous scheme.
That is why I put values of 0.8 for some criteria.
Scores of Betting Schemes
Betting Scheme | Score for beginners | Score for matures |
---|---|---|
Pool Bets | 4 | 3 |
Peer-to-peer Bets | 1.5 | 2 |
Multi-peer Bets | 1.8 | 2.6 |
New Proposed Blockchain Betting Scheme
Definition
In fact, Multi-peer Bets, which is an evolution of Peer-to-peer Bets, seems to be good enough for mature players. But the biggest scores belong to the Pool bets scheme. We need to change it somehow so that player will get more revenue if he placed a bet earlier.
This could be easily achieved if we change the algorithm of computing the revenue as follows:
Each player, whose bet is won, receives a part of the winning pie from the amounts of those players who made a bet AFTER him and lost.
Next this scheme is described in details.
Input data
Let’s study proposed scheme on some synthetic example. Imagine a group of people make pool bets on either teamA or teamB.
The input data for proposed blockchain betting scheme is the list of bets. Note, that the order in which bets are placed is important!
09:55 Ezra bets on teamB, 50$. 10:00 John bets on teamA, 20$. 10:05 Nika bets on teamB, 10$. 10:10 Jade bets on teamB, 10$. 10:15 Liam bets on teamA, 20$. 10:20 Noah bets on teamA, 30$. 10:25 Owen bets on teamB, 100$. 10:30 Luke bets on teamB, 20$. 10:35 Jack bets on teamA, 50$. 10:40 Levi bets on teamA, 100$. 10:45 Ryan bets on teamB, 70$. 10:50 Jose bets on teamB, 20$. 10:55 Adam bets on teamA, 20$.
Total sum of bets for teamA is: 240$. Total sum of bets for teamB is: 280$.
Revenue Distribution Coefficients
Imagine: teamA wins the match. It means that John, Liam, Noah, Jack, Levi and Adam win, and others lose. Now let’s compute the coefficients of revenue for each winner, starting from the end:
-
Adam gets nothing, since no player placed bet on teamB after him.
-
Levi shares the winning pie with John, Liam, Noah and Jack - those, who placed bets on teamA before him.
For Levi the winning pie is formed from amounts of Ryan and Jose. Levi’s part of a pie is computed as:
100$ / (20$ + 20$ + 30$ + 50$ + 100$) = 0.454
.We keep the following coefficients:
Rian -> Levi: 0.454
andJose -> Levi: 0.454
. -
Jack shares the winning pie with John, Liam and Noah - those, who placed bets on teamA before him.
The winning pie is formed from amounts of Ryan and Jose. Jack’s part of a pie is computed as:
50$ / (20$ + 20$ + 30$ + 50$) = 0.417
.We keep the following coefficients:
Rian -> Jack: 0.417
andJose -> Jack: 0.417
. -
Noah shares the winning pie with John and Liam - those, who placed bets on teamA before him.
The winning pie is formed from amounts of Owen, Luke, Ryan and Jose. Noah’s part of a pie is computed as:
30$ / (20$ + 20$ + 30$) = 0.429
.We keep the following coefficients:
Owen -> Noah: 0.429
,Luke -> Noah: 0.429
,Rian -> Noah: 0.429
andJose -> Noah: 0.429
. -
Liam shares the winning pie with John - the one, who placed bets on teamA before him.
The winning pie is formed from amounts of Owen, Luke, Ryan and Jose. Liam’s part of a pie is computed as:
20$ / (20$ + 20$) = 0.5
.We keep the following coefficients:
Owen -> Liam: 0.5
,Luke -> Liam: 0.5
,Rian -> Liam: 0.5
andJose -> Liam: 0.5
. -
John ‘does not’ share the winning pie, because no one placed bets on teamA before him.
The winning pie is formed from amounts of Nika, Jade, Owen, Luke, Ryan and Jose.
John’s part of a pie is computed as:
20$ / 20$ = 1
.We keep the following coefficients:
Nika -> John: 1
,Jade -> John: 1
,Owen -> John: 1
,Luke -> John: 1
,Rian -> John: 1
andJose -> John: 1
.
Now that we have computed coefficients of revenue we can write them in the table form:
Losers: | Ezra | Nika | Jade | Owen | Luke | Ryan | Jose | Revenue | |
---|---|---|---|---|---|---|---|---|---|
Winners: | Amount | 50$ | 10$ | 10$ | 100$ | 20$ | 70$ | 20$ | 280$ |
John | 20$ | 0.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | |
Liam | 20$ | 0.0 | 0.0 | 0.0 | 0.5 | 0.5 | 0.5 | 0.5 | |
Noah | 30$ | 0.0 | 0.0 | 0.0 | 0.429 | 0.429 | 0.429 | 0.429 | |
Jack | 50$ | 0.0 | 0.0 | 0.0 | 0.0 | 0.0 | 0.417 | 0.417 | |
Levi | 100$ | 0.0 | 0.0 | 0.0 | 0.0 | 0.0 | 0.454 | 0.454 | |
Adam | 20$ | 0.0 | 0.0 | 0.0 | 0.0 | 0.0 | 0.0 | 0.0 | |
SUM | 240$ | 0.0 | 1.0 | 1.0 | 1.929 | 1.929 | 2.8 | 2.8 |
The rows correspond to winner players, and the columns - to losers.
Each column defines the coefficients to distribute the money of a particular loser to all the winners. Note: the sum of coefficients must be 1.0, which it is not right now. This will be fixed at the next step.
Note, that Adam has all zeroes in his row. It means, he will receive nothing.
Also note that Ezra column is all zeroes. This is because there is no bet on teamA before Ezra. There are several ways to manage her money:
- we can return it back to Ezra
- we can share it among all winners in proportion to the size of their bet.
Let’s choose the second option and compute coefficients for spreading Ezra’s money:
Losers: | Ezra | Nika | Jade | Owen | Luke | Ryan | Jose | Revenue | |
---|---|---|---|---|---|---|---|---|---|
Winners: | Amount | 50$ | 10$ | 10$ | 100$ | 20$ | 70$ | 20$ | 280$ |
John | 20$ | 0.083 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | |
Liam | 20$ | 0.083 | 0.0 | 0.0 | 0.5 | 0.5 | 0.5 | 0.5 | |
Noah | 30$ | 0.125 | 0.0 | 0.0 | 0.429 | 0.429 | 0.429 | 0.429 | |
Jack | 50$ | 0.208 | 0.0 | 0.0 | 0.0 | 0.0 | 0.417 | 0.417 | |
Levi | 100$ | 0.417 | 0.0 | 0.0 | 0.0 | 0.0 | 0.454 | 0.454 | |
Adam | 20$ | 0.083 | 0.0 | 0.0 | 0.0 | 0.0 | 0.0 | 0.0 | |
SUM | 240$ | 1.0 | 1.0 | 1.0 | 1.929 | 1.929 | 2.8 | 2.8 |
Note, that Adam now has non-zero coefficient, so he will also receive some revenue from Ezra.
Coefficients Normalization
Now we need to normalize each column, so that the sum of the coefficients does not exceed 1.0. After all, the total amount of revenue cannot exceed the amount of bets of the losers.
There are many ways to normalize coefficients. We will examine two of them: division by sum and softmax.
Normalization by Dividing by Sum
The simplest method is to divide each coefficient in a column by the sum of coefficients in this column. If we apply this method for our example, we get:
Losers: | Ezra | Nika | Jade | Owen | Luke | Ryan | Jose | Revenue | |
---|---|---|---|---|---|---|---|---|---|
Winners: | Amount | 50$ | 10$ | 10$ | 100$ | 20$ | 70$ | 20$ | 280$ |
John | 20$ | 0.083 | 1.0 | 1.0 | 0.518 | 0.518 | 0.357 | 0.357 | 118.46$ |
Liam | 20$ | 0.083 | 0.0 | 0.0 | 0.259 | 0.259 | 0.179 | 0.179 | 51.36$ |
Noah | 30$ | 0.125 | 0.0 | 0.0 | 0.223 | 0.223 | 0.153 | 0.153 | 46.78$ |
Jack | 50$ | 0.208 | 0.0 | 0.0 | 0.0 | 0.0 | 0.148 | 0.148 | 23.74$ |
Levi | 100$ | 0.417 | 0.0 | 0.0 | 0.0 | 0.0 | 0.163 | 0.163 | 35.50$ |
Adam | 20$ | 0.083 | 0.0 | 0.0 | 0.0 | 0.0 | 0.0 | 0.0 | 4.17$ |
SUM | 240$ | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 280$ |
For example, here is how the revenue is computed for John:
0.083*50 + 1*10 + 1*10 + 0.518*100 + 0.518*20 + 0.357*70 + 0.357*20 = 118.46$
Note: in this article I do not include the sum player put in a bet into the revenue. It is assumed, that if bet wins, the player automatically receives back the amount of his bet. And the revenue comes additionally.
With this normalization method, John receives too much of total revenue!
Softmax Normalization
I believe, it would be better to use the softmax function, or any of its variations.
For softmax we first need to compute the: Exp(k * coefficient)
for each coefficient in the table.
The meaning of additional multiplier k
will be explained later. For now set k=1
.
Next we should divide each value by the sum of values of the column.
For example: the coefficients vector for distributing the Ryan’s money is:
[1.000, 0.500, 0.429, 0.417, 0.454, 0.000]
After applying softmax to it, we get:
[0.272, 0.165, 0.154, 0.152, 0.158, 0.100]
The whole table after applying softmax looks like this:
Losers: | Ezra | Nika | Jade | Owen | Luke | Ryan | Jose | Revenue | |
---|---|---|---|---|---|---|---|---|---|
Winners: | Amount | 50$ | 10$ | 10$ | 100$ | 20$ | 70$ | 20$ | 280$ |
John | 20$ | 0.083 | 0.352 | 0.352 | 0.305 | 0.305 | 0.272 | 0.272 | 72.33$ |
Liam | 20$ | 0.083 | 0.130 | 0.130 | 0.185 | 0.185 | 0.165 | 0.165 | 43.83$ |
Noah | 30$ | 0.125 | 0.130 | 0.130 | 0.173 | 0.173 | 0.154 | 0.154 | 43.37$ |
Jack | 50$ | 0.208 | 0.130 | 0.130 | 0.112 | 0.112 | 0.152 | 0.152 | 40.15$ |
Levi | 100$ | 0.417 | 0.130 | 0.130 | 0.112 | 0.112 | 0.158 | 0.158 | 51.08$ |
Adam | 20$ | 0.083 | 0.130 | 0.130 | 0.112 | 0.112 | 0.100 | 0.100 | 29.24$ |
SUM | 240$ | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 280$ |
Advantages:
- New coefficients are distributed more evenly.
- John’s revenue is lesser in comparison with previous normalization method: 72$ < 118.46$.
- Zero coefficients of Adam become nonzero. Adam receives more revenue: 29.24$ > 4.17$.
- Still we achieve our goal, and those who place bets earlier receive more revenue.
Adjustable Softmax Normalization
If we change the value of additional multiplier k
, we can adjust distribution of revenues,
making it sharper (John receives more), or smoother (Adam receives more).
For example, let’s see how the distribution of revenue changes if we set k=0.5
.
The resulting table then becomes as follows:
Losers: | Ezra | Nika | Jade | Owen | Luke | Ryan | Jose | Revenue | |
---|---|---|---|---|---|---|---|---|---|
Winners: | Amount | 50$ | 10$ | 10$ | 100$ | 20$ | 70$ | 20$ | 280$ |
John | 20$ | 0.083 | 0.248 | 0.248 | 0.230 | 0.230 | 0.215 | 0.215 | 56.09$ |
Liam | 20$ | 0.083 | 0.150 | 0.150 | 0.179 | 0.179 | 0.168 | 0.168 | 43.75$ |
Noah | 30$ | 0.125 | 0.150 | 0.150 | 0.173 | 0.173 | 0.162 | 0.162 | 44.56$ |
Jack | 50$ | 0.208 | 0.150 | 0.150 | 0.139 | 0.139 | 0.161 | 0.161 | 44.63$ |
Levi | 100$ | 0.417 | 0.150 | 0.150 | 0.139 | 0.139 | 0.164 | 0.164 | 55.32$ |
Adam | 20$ | 0.083 | 0.150 | 0.150 | 0.139 | 0.139 | 0.131 | 0.131 | 36.66$ |
SUM | 240$ | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 280$ |
Note: by changing k=0.5
we made distribution smoother.
John now receives even less, while Adam gets more.
This adjustment seems reasonable, though, the exact formula of how to choose the value of k
should be studied additionally.
Comparison with Pool Bets
Let’s compare results with original Pool Bets scheme. The table of coefficients for Pool Bets is very simple:
Losers: | Ezra | Nika | Jade | Owen | Luke | Ryan | Jose | Revenue | |
---|---|---|---|---|---|---|---|---|---|
Winners: | Amount | 50$ | 10$ | 10$ | 100$ | 20$ | 70$ | 20$ | 280$ |
John | 20$ | 0.083 | 0.083 | 0.083 | 0.083 | 0.083 | 0.083 | 0.083 | 23.33$ |
Liam | 20$ | 0.083 | 0.083 | 0.083 | 0.083 | 0.083 | 0.083 | 0.083 | 23.33$ |
Noah | 30$ | 0.125 | 0.125 | 0.125 | 0.125 | 0.125 | 0.125 | 0.125 | 35.00$ |
Jack | 50$ | 0.208 | 0.208 | 0.208 | 0.208 | 0.208 | 0.208 | 0.208 | 58.33$ |
Levi | 100$ | 0.417 | 0.417 | 0.417 | 0.417 | 0.417 | 0.417 | 0.417 | 116.67$ |
Adam | 20$ | 0.083 | 0.083 | 0.083 | 0.083 | 0.083 | 0.083 | 0.083 | 23.33$ |
SUM | 240$ | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | 280$ |
The coefficients for each winner are computed as the amount of his bet divided by the total sum of
the amounts of all winners. For example, coefficient for Levi is: 100$ / 240$ = 0.417
.
Notice, how much revenue receives Levi: 116.67$.
Imagine that teamA showed clear leadership during the match. And at the end of the match Levy decided to make a big bet, taking most of the total revenue. I believe, this is not fair, as Levi at the end of the match had more information than John, for example.
Meanwhile, in the proposed betting scheme, Levi’s revenue is only 51.08$ .. 55.32$
(depending on the k
value).
Conclusion
In this article I proposed the idea of new blockchain betting scheme, which I called: Blockchain Fair Bets.
It is an evolution of a Pool Bets scheme, which solves at least one problem: players do not get more revenue even when place their bets earlier.
The proposed scheme solves this problem by introducing new algorithm for computing revenue distributing coefficients. This algorithm provides that players get more revenue when place their bet earlier.
Also proposed scheme has built-in mechanism to adjust the smoothness of revenue distribution.
If we evaluate proposed Blockchain Fair Bets according to the selected criteria, we get the following result:
Criteria | Value | Score for beginners | Score for matures |
---|---|---|---|
Can player specify odds manually? | No | 1 | 0 |
Can player freely choose the amount to bet? | Yes | 1 | 1 |
You do NOT have to wait or look for another player? | Yes | 1 | 1 |
Do you get more revenue if you bet on obvious loser, and it suddenly wins? | Yes | 1 | 1 |
Do you get more revenue if place your bet earlier? | Yes | 1 | 1 |
Results: | 5 | 4 |
According to the criteria we have chosen, it receives score 5 for beginners and 4 for matures. We can conclude that Blockchain Fair Bets is suited for both beginner and mature players.
It would be great, if somebody could develop this idea and build a blockchain contract for it.
UPDATE from 2021-11-20
A discussion in the Wagerr’s discord thread revealed that Wagerr invented a decent alternative to pool bets - the Peerless Direct Chain Betting.
It is when some Oracle (the “House”), updates odds in real-time during a match, so when you decide to make your bet, you can only accept the specified odds and place a bet into the wagerr’s blockchain.
This way no player can use the latest information to capture the most revenue. Because the “House” uses the same latest information and updates the odds in real-time.
You can read more info in this article.
I think this is a good alternative to the Pool Bets. Though, the commissions in this scheme would still be higher, as the “House” itself takes some part of the profit.