diff options
author | nfoy <nfoy@purdue.edu> | 2014-04-29 14:59:37 -0400 |
---|---|---|
committer | nfoy <nfoy@purdue.edu> | 2014-04-29 14:59:37 -0400 |
commit | a4f0f384efd1b56880c7acc58a492ddbd0c02583 (patch) | |
tree | dd0adec2600ee1a362af2795971be3c29e1fc58e /lib/scoring/fibonacci_peer_with_blowout.rb | |
parent | 4e69e23c20b9b8e54d28c88a95bfb5105aaca384 (diff) | |
parent | 577f203243b1ac914a3ee3f4635005be06d637c6 (diff) |
Merge branch 'master' of https://github.com/LukeShu/leaguer
Diffstat (limited to 'lib/scoring/fibonacci_peer_with_blowout.rb')
-rw-r--r-- | lib/scoring/fibonacci_peer_with_blowout.rb | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/lib/scoring/fibonacci_peer_with_blowout.rb b/lib/scoring/fibonacci_peer_with_blowout.rb index 9d72643..ea4dec5 100644 --- a/lib/scoring/fibonacci_peer_with_blowout.rb +++ b/lib/scoring/fibonacci_peer_with_blowout.rb @@ -1,15 +1,17 @@ module Scoring module FibonacciPeerWithBlowout def self.stats_needed - return ["votes", "win", "blowout"] + return ["votes", "win", "blowout"] + @match.users.map{|u|"review_from_#{u.user_name}"} end def self.score(match) scores = {} match.users.each do |user| - stats = Statistic.where(user: user, match: match) - - votes = stats.where(name: "votes" ).first.value + stats = user.statistics.where(match: match) + votes = 0 + match.users.each do |u| + votes += convert_place_to_votes stats.where(name: "review_from_#{u.user_name}").first.value + end win = stats.where(name: "win" ).first.value blowout = stats.where(name: "blowout").first.value scores[user] = self.score_user(votes, win, blowout) @@ -23,5 +25,9 @@ module Scoring fibonacci = Hash.new { |h,k| h[k] = k < 2 ? k : h[k-1] + h[k-2] } fibonacci[votes+3] + (win ? blowout ? 12 : 10 : blowout ? 5 : 7) end + + def self.convert_place_to_votes(place) + (place == 0 or place == 1) ? 1 : 0 + end end end |