Merge branch 'main' of https://git.mercurio.moe/Mercury/dth-pingpong-backend
This commit is contained in:
commit
0861fe47ba
90
docs/hybrid-matchmaking.md
Normal file
90
docs/hybrid-matchmaking.md
Normal file
|
@ -0,0 +1,90 @@
|
|||
# Hybrid Ranking System: Matchmaking Suggestions
|
||||
|
||||
## Overview
|
||||
|
||||
This proposal outlines a hybrid ranking system for matchmaking in a ping pong app. The system integrates **Elo ratings** for 1v1 matches and **OpenSkill (OSK)** ratings for 2v2 matches. The goal is to use Elo as a supporting metric for matchmaking suggestions in 2v2 scenarios, providing fair and balanced matches for players.
|
||||
|
||||
---
|
||||
|
||||
## Problem Statement
|
||||
|
||||
OpenSkill is ideal for tracking player ratings in 2v2 matches due to its ability to handle uncertainty (data:image/s3,"s3://crabby-images/1dda5/1dda521872d4c8f109e7490f3de1e6818a276de8" alt="") and dynamic team compositions. However, it does not directly account for individual player skill history from 1v1 matches.
|
||||
|
||||
The problem lies in matchmaking for 2v2 games when:
|
||||
1. Player data is sparse (e.g., fewer 2v2 matches played).
|
||||
2. Players' individual skill levels (from Elo) are significantly mismatched within or between teams.
|
||||
|
||||
By combining Elo and OpenSkill, we can make more informed matchmaking suggestions.
|
||||
|
||||
---
|
||||
|
||||
## Proposed Solution
|
||||
|
||||
### Approach
|
||||
|
||||
We propose using Elo ratings from 1v1 matches as an additional weighting factor when suggesting 2v2 matchups. This involves the following steps:
|
||||
|
||||
1. **Team Strength Calculation**:
|
||||
- Use Elo to calculate the **average team Elo**:
|
||||
|
||||
data:image/s3,"s3://crabby-images/a269d/a269d9f03f0f610eb4995ad888cc0df1aee2dcac" alt=""
|
||||
|
||||
2. **Weigh Elo into OpenSkill Predictions**:
|
||||
- Combine OpenSkill predictions with Elo to generate an **Adjusted Compatibility Score**:
|
||||
data:image/s3,"s3://crabby-images/1cc5d/1cc5d4bd3bd6a72a5898f6740f073ff0eb4165e4" alt=""
|
||||
|
||||
- *w_1* and *w_2* are weights balancing the influence of OpenSkill and Elo.
|
||||
|
||||
3. **Match Balance Assessment**:
|
||||
- Predict the expected win probability for each team using OpenSkill and adjust it with Elo to suggest fairer matches.
|
||||
|
||||
4. **Rank Match Suggestions**:
|
||||
- Generate a list of potential matchups ranked by their balance score. Favor matches with close Elo and OpenSkill ratings.
|
||||
|
||||
---
|
||||
|
||||
### Example Scenario
|
||||
|
||||
#### Player Data
|
||||
|
||||
| Player | Elo | OSK (data:image/s3,"s3://crabby-images/bd537/bd5375f89ce102479378ab0aa6f3f7617250c9f3" alt="",data:image/s3,"s3://crabby-images/1dda5/1dda521872d4c8f109e7490f3de1e6818a276de8" alt="") |
|
||||
|--------|-------|-----------------------|
|
||||
| A | 1600 | (30, 5) |
|
||||
| B | 1500 | (28, 6) |
|
||||
| C | 1550 | (29, 4) |
|
||||
| D | 1400 | (27, 5) |
|
||||
|
||||
#### Step 1: Form Teams and Calculate Team Elo
|
||||
- **Team 1**: A + B → Team Elo: data:image/s3,"s3://crabby-images/ed1e8/ed1e8bf7b6403eecd302b80651e7272b84e197a6" alt=""
|
||||
- **Team 2**: C + D → Team Elo: data:image/s3,"s3://crabby-images/5ee74/5ee749f647868f4c352b70dd5d13c753da7e2672" alt=""
|
||||
|
||||
#### Step 2: OpenSkill Predictions
|
||||
- Team 1: Combined data:image/s3,"s3://crabby-images/bd537/bd5375f89ce102479378ab0aa6f3f7617250c9f3" alt=""= 29, data:image/s3,"s3://crabby-images/1dda5/1dda521872d4c8f109e7490f3de1e6818a276de8" alt="" = 5.5$
|
||||
- Team 2: Combined data:image/s3,"s3://crabby-images/bd537/bd5375f89ce102479378ab0aa6f3f7617250c9f3" alt="" = 28, data:image/s3,"s3://crabby-images/1dda5/1dda521872d4c8f109e7490f3de1e6818a276de8" alt="" = 4.5
|
||||
|
||||
Predicted win probability using OSK: **Team 1 is favored.**
|
||||
|
||||
#### Step 3: Adjust with Elo
|
||||
- Elo gap: 1550 - 1475 = 75
|
||||
- Adjust prediction to slightly favor Team 1 more based on the Elo difference.
|
||||
|
||||
#### Step 4: Suggest Matches
|
||||
Rank all potential 2v2 matchups based on their **Adjusted Compatibility Score**.
|
||||
|
||||
---
|
||||
|
||||
## Benefits of the Hybrid System
|
||||
|
||||
- **Fairness**: Prevents unbalanced teams by considering both 1v1 and 2v2 performance.
|
||||
- **Adaptability**: Handles sparse data effectively by leveraging Elo as a fallback metric.
|
||||
- **Dynamic Suggestions**: Offers matchmaking suggestions based on both team composition and player history.
|
||||
|
||||
---
|
||||
|
||||
## Next Steps
|
||||
|
||||
1. Implement the matchmaking algorithm:
|
||||
- Calculate compatibility scores for all possible 2v2 matchups.
|
||||
- Use Elo to filter and refine suggestions.
|
||||
2. Define weights *w_1* and *w_2* for Elo and OpenSkill integration.
|
||||
3. Test the system with real player data to evaluate balance and fairness.
|
Loading…
Reference in a new issue