|
shalimar GURU
Joined: 04 Aug 2002 Posts: 4690 Location: Pensacola, FL, USA
|
Posted: Tue Dec 28, 2010 12:49 am
Empirical Rankings |
In the game I play you occasionally get messages such as:
CrimsonKnight has bested Lancelot in the jousting tournament!
I want to collect all of these messages over a period of time, say a month or so, and then rank the individuals afterward.
I am just struggling to get my mind around how to build the comparison table to determine the results, any ideas?
P.S. There is no limit to how many tournaments a single entrant may participate in, so long as they have another player to compete against. |
|
_________________ Discord: Shalimarwildcat
Last edited by shalimar on Thu Oct 27, 2011 7:59 pm; edited 1 time in total |
|
|
|
Tech GURU
Joined: 18 Oct 2000 Posts: 2733 Location: Atlanta, USA
|
Posted: Fri Dec 31, 2010 5:10 am |
I would use a point system. The reason for this is it makes calculations easier (I'll explain) and it prevents folks from trying to game the system.
Cosider
Lancelot who was entered 1 tournament against a Lvl 2 player and won it. Win ratio 100%.
Fred who has won entered 5 tournaments against and won against a Lvl 3, 5, and 1 player. Lost to a Lvl 5 and 7. Win ration 60%
John who has won entered 50 tournaments against all Lvl 1 players and won 40. Win ration 40%
John who has won entered 5 tournaments and won against two Lvl 5s and Lvl 4. Lost against all Lvl 10 and a Lvl 20 players and won 40. Win ration 40%.
Note that I assumed that there a Lvls in Joust and that they affect the outcome. The approach should work even they don't.
I would say that going by win ratio alone, won't cut it. But a win against a level 5 should count more that a win against a level 2. If you simply want to calculate base on wins, I would assign a point value to each level. To prevent say a Lvl 50 win from counting too much I would use a sum of (N * L ln L) when N is the number of victories against a given level L. I chose natural log, but you could use some other slow growing function.
If you want losses to count you can use LD the difference in levels between jousters to drive your formula. When LD is positive subtract (1 / LD) and when LD is negative subtract ( LD ln LD ).
In rereading I realize my math choices were perhaps a little complex. The key is then coming up with a weighting scheme that your comfortable. You can play with the numbers but those were my initial thoughts.
If there are no levels you can use win ratio times the number of matches to determine your first months ranking, then assign 'levels' based on prior months rankings. |
|
_________________ Asati di tempari! |
|
|
|
shalimar GURU
Joined: 04 Aug 2002 Posts: 4690 Location: Pensacola, FL, USA
|
Posted: Sat Jan 01, 2011 12:29 am |
There is no way for me to determine the skill of the player just by the outcome of the match.
I could likely find out by OOC means, but I have no intention of doing so.
I was thinking of relative values:
@x beat @y 3/4 times so x>y
But unless there is a large enough sample that there are a lot of crossovers, it wont make for a very plottable table |
|
_________________ Discord: Shalimarwildcat |
|
|
|
shalimar GURU
Joined: 04 Aug 2002 Posts: 4690 Location: Pensacola, FL, USA
|
Posted: Thu Oct 27, 2011 7:39 pm |
Revisiting this in another vein
Code: |
#TR {({@weapons}) is better than ({@weapons})} {
$better=%1
$worse=%2
#ADDITEM weaponChart.$better.betterThan $worse
#ADDITEM weaponChart.$worse.worseThan $better
} |
Given a large enough sample, how would i use the above database to construct a list from worst to best?
I was thinking of something like...
Code: |
#ALIAS weaponSort {
#local $sorting $weapons $lastSort $this $that
#WAIT 0
$weapons=%dbkeys( @weaponChart)
#FORALL $weapons {#ADDKEY $sorting {%i=5000}}
#UNTIL ($lastSort=$sorting) {
$lastSort=$sorting
#FORALL $weapons {
$this=%i
#FORALL @weaponChart.$this.betterThan {
$that=%j
#IF ($sorting.$this!>$sorthing.$that) {$sorting.$that=($sorting.$this-1)}
}
#FORALL @weaponChart.$this.worseThan {
$that=%j
#IF ($sorting.$this!<$sorthing.$that) {$sorting.$that=($sorting.$this+1)}
}
}
}
#SAY the list from wrost to best
} |
Not sure if that is the most effiecient method though. |
|
_________________ Discord: Shalimarwildcat |
|
|
|
Rahab Wizard
Joined: 22 Mar 2007 Posts: 2320
|
Posted: Thu Oct 27, 2011 8:25 pm |
You don't need both the betterThan and the worseThan tables. Just one of those will be sufficient. I believe that the algorithm will have to be rather more complex than what you have, though it is a start. Let me think about it a bit...
|
|
|
|
oldguy2 Wizard
Joined: 17 Jun 2006 Posts: 1201
|
Posted: Fri Oct 28, 2011 8:02 pm |
Code: |
$sorting.$this!>$sorthing.$that
and
$sorting.$this!>$sorthing.$that
|
This is not valid syntax. You also spelled sorting as sorthing. |
|
|
|
shalimar GURU
Joined: 04 Aug 2002 Posts: 4690 Location: Pensacola, FL, USA
|
Posted: Sun Nov 27, 2011 1:47 am |
It was a contrived bit of code off the top of my head to show what i am trying to accomplish.
|
|
_________________ Discord: Shalimarwildcat |
|
|
|
|
|