Gazelle/sections/torrents/voter_picks.php

65 lines
2.0 KiB
PHP
Raw Permalink Normal View History

2012-10-27 08:00:09 +00:00
<?
2013-02-22 08:00:24 +00:00
//global $Cache, $DB;
2012-10-27 08:00:09 +00:00
include(SERVER_ROOT.'/sections/torrents/ranking_funcs.php');
$Top10 = $Cache->get_value('similar_albums_'.$GroupID);
2013-09-13 08:00:53 +00:00
if ($Top10 === false || isset($Top10[$GroupID])) {
2012-10-27 08:00:09 +00:00
2012-10-29 08:00:20 +00:00
$VotePairs = $Cache->get_value('vote_pairs_'.$GroupID, true);
2013-09-13 08:00:53 +00:00
if ($VotePairs === false || isset($VotePairs[$GroupID])) {
2013-05-27 08:00:58 +00:00
$DB->query("
SELECT v.GroupID, SUM(IF(v.Type='Up',1,0)) AS Ups, COUNT(1) AS Total
FROM ( SELECT UserID
FROM users_votes
2014-03-27 08:01:03 +00:00
WHERE GroupID = '$GroupID'
2013-05-27 08:00:58 +00:00
AND Type='Up'
) AS a
JOIN users_votes AS v USING (UserID)
2014-03-27 08:01:03 +00:00
WHERE v.GroupID != '$GroupID'
2013-05-27 08:00:58 +00:00
GROUP BY v.GroupID
HAVING Ups > 0");
2012-10-27 08:00:09 +00:00
$VotePairs = $DB->to_array('GroupID', MYSQL_ASSOC, false);
2013-10-06 08:01:04 +00:00
$Cache->cache_value('vote_pairs_'.$GroupID, $VotePairs, 21600);
2012-10-27 08:00:09 +00:00
}
$GroupScores = array();
foreach ($VotePairs as $RatingGroup) {
// Cutting out the junk should speed the sort significantly
$Score = binomial_score($RatingGroup['Ups'], $RatingGroup['Total']);
if ($Score > 0.3) {
2013-10-06 08:01:04 +00:00
$GroupScores[$RatingGroup['GroupID']] = $Score;
2012-10-27 08:00:09 +00:00
}
}
arsort($GroupScores);
$Top10 = array_slice($GroupScores, 0, 10, true);
2013-05-27 08:00:58 +00:00
$Cache->cache_value('similar_albums_'.$GroupID, $Top10, 0.5 * 3600);
2012-10-27 08:00:09 +00:00
}
if (count($Top10) > 0) {
?>
<table class="vote_matches_table" id="vote_matches">
<tr class="colhead">
2013-06-17 08:01:02 +00:00
<td><a href="#">&uarr;</a>&nbsp;People who like this album also liked... <a href="#" onclick="$('.votes_rows').gtoggle(); return false;">(Show)</a></td>
2012-10-27 08:00:09 +00:00
</tr>
2013-02-22 08:00:24 +00:00
<?
2012-10-27 08:00:09 +00:00
$Top10Groups = array_keys($Top10);
$Groups = Torrents::get_groups($Top10Groups, true, true, false);
$i = 0;
2014-05-07 08:00:45 +00:00
foreach ($Top10Groups as $MatchGroupID) {
if (!isset($Groups[$MatchGroupID])) {
continue;
}
$MatchGroup = $Groups[$MatchGroupID];
2012-10-27 08:00:09 +00:00
$i++;
$Str = Artists::display_artists($MatchGroup['ExtendedArtists']).'<a href="torrents.php?id='.$MatchGroupID.'">'.$MatchGroup['Name'].'</a>';
?>
2013-09-13 08:00:53 +00:00
<tr class="votes_rows hidden <?=($i & 1) ? 'rowb' : 'rowa'?>">
2012-10-27 08:00:09 +00:00
<td><span class="like_ranks"><?=$i?>.</span> <?=$Str?></td>
</tr>
<? } ?>
</table>
<?
}
2013-05-27 08:00:58 +00:00
?>