]> git.sesse.net Git - wloh/blob - www/rating.pl
Move CSS out into an external file.
[wloh] / www / rating.pl
1 #! /usr/bin/perl
2 use strict;
3 use warnings;
4 no warnings qw(once);
5 use CGI;
6 use CGI::Carp qw( fatalsToBrowser );
7 use DBI;
8 use Encode;
9 use POSIX;
10 use HTML::Entities;
11 use utf8;
12 use locale;
13 require '../config.pm';
14
15 my $dbh = DBI->connect($config::local_connstr, $config::local_username, $config::local_password)
16         or die "connect: " . $DBI::errstr;
17 $dbh->{AutoCommit} = 0;
18 $dbh->{RaiseError} = 1;
19
20 binmode STDOUT, ':utf8';
21
22 # Find auxillary parameters.
23 my %params = ();
24 my $q = $dbh->prepare('SELECT * FROM ratings WHERE id < 0');
25 $q->execute;
26 while (my $ref = $q->fetchrow_hashref) {
27         $params{$ref->{'id'}} = $ref->{'rating'};
28 }
29 my $match_stddev = $params{-2} * sqrt(2.0);
30
31 print CGI->header(-type=>'text/html; charset=utf-8', -expires=>'+5m');
32 POSIX::setlocale(&POSIX::LC_ALL, 'nb_NO.UTF-8');
33
34 printf <<"EOF", $params{-3}, $match_stddev;
35 <html>
36   <head>
37     <title>WLoH-rating</title>
38     <link rel="stylesheet" href="/style" type="text/css" />
39   </head>
40   <body>
41     <h1>WLoH-rating</h1>
42
43     <p><em>Dette er et hobbyprosjekt fra tredjepart, og ikke en offisiell del av
44       <a href="http://wordfeud.aasmul.net/">Wordfeud Leage of Honour</a>.</em></p>
45
46     <p>Ratingen er dog basert på spilledata fra WLoH (takk til Lobotommy
47       for tilgang!), og oppdateres
48       hver hele time. Den er fullstendig uoffisiell, og har ingen innflytelse
49       på WLoH, men brukes for å estimere vinnersannsynligheter i
50       <a href="/">sannsynlighetsberegningen</a>.</p>
51
52     <p>Vær obs på at det
53       er betydelig usikkerhetsmargin, spesielt for spillere som ikke
54       har spilt spesielt mange kamper.</p>
55
56     <p>Modellen kan endre seg når som helst når jeg føler for det :-)
57       Ikke ta ratingen alt for alvorlig, selv om den er basert på
58       relativt fornuftige matematiske modeller. Husk at all statistikk
59       sier mer om fortiden enn om framtiden.</p>
60
61     <h2>Modellparametre</h2>
62
63     <p>For de som vet litt om slikt. Mer utførlig forklaring for begynnere kommer seinere.</p>
64
65     <ul>
66       <li>MLE-basert modell med én skalar (styrke) per spiller og to globale skalarer (begge standardavvik, se under), løst med syklisk MM (minorization-maximization). Antall iterasjoner før konvergens: $params{-1}.</li>
67       <li>Rimelighetfunksjon, prior: Normalfordeling med µ=1500, &sigma;=%.1f (est.)</li>
68       <li>Rimelighetfunksjon, per kamp: Normalfordeling med µ=(score1 - score2), &sigma;=%.1f (est.)</li>
69       <li>Vekting: Inneværende sesong samt de tre siste vektes fullt ut
70         (likt med prior). Deretter eksponentielt synkende vekting, med
71         halveringstid på tre sesonger. Spill som er registrert med
72         150-0, 0-150 eller 150-150 ignoreres.</li>
73     </ul>
74
75   <h2>Rankingliste</h2>
76
77   <table>
78     <tr>
79       <th></th>
80       <th>Nick</th>
81       <th>Ranking</th>
82       <th>Sist sett</th>
83     </tr>
84 EOF
85
86 $q = $dbh->prepare('
87 SELECT *
88 FROM ratings
89   NATURAL JOIN kanonisk_navn
90   NATURAL JOIN siste_divisjon
91 ORDER BY rating DESC');
92 $q->execute;
93
94 my $i = 0;
95 while (my $ref = $q->fetchrow_hashref) {
96         if (++$i % 2 == 0) {
97                 print "    <tr class=\"odd\">\n";
98         } else {
99                 print "    <tr class=\"even\">\n";
100         }
101         printf "      <th>%d.</th>\n", $i;
102         printf "      <td><a href=\"http://wordfeud.aasmul.net/bruker-%d\">%s</a></td>\n", $ref->{'id'}, HTML::Entities::encode_entities(Encode::decode_utf8($ref->{'navn'}));
103         printf "      <td class=\"num\">%.1f</td>\n", $ref->{'rating'};
104         printf "      <td><a href=\"http://wordfeud.aasmul.net/serie-%d\">%s</a></td>\n", $ref->{'serie_id'}, $ref->{'serie_navn'};
105         print "    </tr>\n";
106 }
107
108 print <<"EOF";
109     </table>
110   </body>
111 </html>
112 EOF
113
114 $match_stddev = $params{-2} * sqrt(2.0);
115
116 $dbh->rollback;