module Scheduling class Elimination include Rails.application.routes.url_helpers def initialize(tournament_stage) @tournament_stage = tournament_stage end def create_matches num_teams = (tournament.players.count/tournament.min_players_per_team).floor num_matches = (Float(num_teams - tournament.min_teams_per_match)/(tournament.min_teams_per_match - 1)).ceil + 1 for i in 1..num_matches tournament_stage.matches.create(status: 0, submitted_peer_evaluations: 0) end match_num = num_matches-1 team_num = 0 tournament.players.shuffle # for each grouping of min_players_per_team tournament.players.each_slice(tournament.min_players_per_team) do |team_members| # if the match is full, move to the next match, otherwise move to the next team if (team_num == tournament.min_teams_per_match) match_num -= 1 team_num = 1 else team_num += 1 end # create a new team in the current match tournament_stage.matches[match_num].teams.push(Team.create(users: team_members)) end end def finish_match(match) matches = match.tournament_stage.matches_ordered cur_match_num = matches.invert[match] unless cur_match_num == 1 match.winner.matches.push(matches[cur_match_num/2]) end end def graph(current_user) matches = @tournament_stage.matches_ordered numTeams = @tournament_stage.tournament.min_teams_per_match logBase = numTeams # depth of SVG tree depth = Math.log(matches.count*(logBase-1),logBase).floor+1; # height of SVG matchHeight = 50*logBase; height = [(matchHeight+50) * logBase**(depth-1) + 100, 500].max; str = <<-STRING STRING base = 1 pBase = 1 (1..matches.count).each do |i| matchDepth = Math.log(i*(logBase-1), logBase).floor+1 puts matchDepth if matchDepth > Math.log(base*(logBase-1), logBase).floor+1 pBase = base base = i end puts base rh = 100 / (logBase**(depth-1)+1) - 100/height; puts rh rw = 100/(depth+1) - 5 puts rw rx = 50/(depth+1) + 100/(depth+1)*(depth-matchDepth) puts rx ry = 100/(logBase**(matchDepth-1)+1) * (i-base+1) - rh/2 puts ry str += "\t\n" str += "\t\t\n" if matches[i].teams[t-1] str += "\t\tTeam #{matches[i].teams[t-1].id}\n" end if (t < numTeams) str += "\t\t VS \n" end t = t + 1 end if i > 1 parent = (i+logBase-2)/logBase pDepth = Math.log(parent*(logBase-1), logBase).floor+1 lastrx = 50/(depth+1) + 100/(depth+1)*(depth-pDepth) lastry = 100/(logBase**(pDepth-1)+1) * (parent-pBase+1) - rh/2 str += "\t\t\n" end str += "\n" end str += '' return str end private def tournament_stage @tournament_stage end def tournament tournament_stage.tournament end end end