#TrueSkill
The code for the TrueSkill calculator is in the "Skills" folder and its unit tests are in the "UnitTests" folder.
For more details, see the "README" file in each of those folders.
Hi there!
Thanks for downloading this code and opening up this file. The goal of this project is to provide an annotated reference implementation of Microsoft's TrueSkill algorithm.
I describe the philosophy and the buildup of the math involved in my blog post "Computing Your Skill" available at moserware.com.
In addition, there is a math paper that goes along with the blog post that explains most of the more technical concepts.
This project isn't intended to win performance tests, it's meant to be read and understood. If you see ways to improve its clarity, please submit a patch.
If you just want to use the TrueSkill algorithm, simply use the TrueSkillCalculator class and enjoy. If you need examples, please look in the UnitTests\TrueSkill folder.
If you want to understand the inner workings of the algorithm and implement it yourself, look in the Skills\TrueSkill folder. There are three separate implementations of the algorithm in increasing levels of difficulty:
1. TwoPlayerTrueSkillCalculator.cs is the easiest to follow and implement. It uses
the simple equations directly from the TrueSkill website.
2. TwoTeamTrueSkillCalculator.cs is slightly more complicated than the two player
version and supports two teams that have at least one player each. It extends
the equations on the website and incorporates some things implied in the paper.
3. FactorGraphTrueSkillCalculator.cs is a wholly different animal than the first two
and it is at least an order of magnitude more complex. It implements the complete
TrueSkill algorithm and builds up a "factor graph" composed of several layers.
Each layer is composed of "factors", "variables", and "messages" between the two.
Work happens on the factor graph according to a "schedule" which can either be
a single step (e.g. sending a message from a factor to a variable) or a sequence of
steps (e.g. everything that happens in a "layer") or a loop where the schedule runs
until values start to stabilize (e.g. the bottom layer is approximated and runs until
it converges)
TrueSkill is more general than the popular Elo algorithm. As a comparison, I implemented the Elo algorithm using the both the bell curve (Gaussian) and curve that the FIDE chess league uses (logistic curve). I specifically implemented them in a way to show how the only difference among these Elo implementations is the curve. I also implemented the "duelling" Elo calculator as implied in the paper.
Everything else was implemented to support these classes. Note that a "player" can be an arbitrary class. However, if that player class supports the "ISupportPartialPlay" or "ISupportPartialUpdate" interfaces, you can add these extra parameters. The only calculator that uses this info is the factor graph implementation. See those files for more details.
I use this code personally to rank around 45 people, so it's important that it's accurate. Please let me know if you find errors. Bug fix patches are strongly encouraged! Also, feel free to fork the project for different language implementations.
I'd love to hear from you via comments on the "Computing Your Skill" blog post.
Have fun and enjoy!
Jeff Moser jeff@moserware.com