代码之家  ›  专栏  ›  技术社区  ›  ma11hew28

Facemash算法[关闭]

  •  17
  • ma11hew28  · 技术社区  · 14 年前

    http://www.thecrimson.com/article/2003/11/19/facemash-creator-survives-ad-board-the/

    8 回复  |  直到 9 年前
        1
  •  19
  •   Reid Barton    14 年前
        2
  •  30
  •   ikwillem    8 年前

    enter image description here

    更新:

    正如我在评论中所说的,我已经把这个代数添加到了我的新网站上。起初它似乎工作得很好。但在一些奇怪的输入之后,一些奇怪的结果开始形成。

    在调试时,我发现我做错了什么。当得到两个节点之间的“直接关系”(也用于间接关系)的分数时,我将分数相加。这是错误的,直接关系的分数应该用-1到+1表示,其中:

    -1 = lost everything 
    +1 = won everything
    

    所以如果A赢了8次给B,B赢了2次给A,分数应该是:

    (A wins) 8 + (B wins) 2 = (total matches)10
    (delta of -1 and +1 =) 2 / (total matches)10 = (points per win) 0.2
    Score of A vs B = (points per win) 0.2 * (wins) 8 - 1 = 0.6
    Score of B vs A = (points per win) 0.2 * (wins) 2 - 1 = -0.4
    

        3
  •  6
  •   Luke    13 年前

    我也重新创造了它,看看吧。 不确定php,但C类是

    http://lukedurrant.com/2010/11/c-elo-rating-class-used-on-facemash-as-seen-in-the-social-network-movie/

    Facemash

    按键代码为

    $(document).keydown(function(event) {
        if (event.keyCode == 37) {
            //Voted Face 1
            Rate("face1", false);
        } 
        if(event.keyCode == 39) {
            //Voted Face 2
            Rate("face2", false);
        }
    
    });
    
        4
  •  4
  •   Nour Wolf    14 年前
        <?php
        //This page is responsible to return a JSON object
        //code starts after the functions for those who might get confused xD
    
        header('content-type: application/json; charset=utf-8');
    
    
        global $responseData;
    
    
        function AdjustRate($Ra, $Ea, $Sa)
        {
            //i used my own rules here 32 points for less than 500
            if($Ra < 500)
                $k = 32;
            elseif ($Ra < 1000)//24 points for anything between 500 and 1000
                $k = 24;
            else
                $k = 16;//16 for anything more than 1000
    
            return $Ra + ($k*($Sa - $Ea));
        }
    
        function GetExpectedChance($rA, $rB) // the ELO formula taken from http://en.wikipedia.org/wiki/Elo_rating_system
        {
            return (1/(1+pow(10,(($rB-$rA)/400))));
        }
    
        function setNewRates($lastCall) // function I used to update my database tables
        {
            global $responseData;
    
            $A = $lastCall->p1;
            $B = $lastCall->p2;
            $C = $lastCall->c;
            $A->E = GetExpectedChance($A->rate, $B->rate);
            $B->E = GetExpectedChance($B->rate, $A->rate);
    
            // decide who won and who lost
            if($A->id == $C){
                $winner = $A;
                $looser = $B;
            }
            elseif ($B->id == $C) {
                $winner = $B;
                $looser = $A;
            }
    
            // 3 cases, in all of them winner will get his rate/hits increased by 1
            //Case #1: normal case we just update rate/hits for the winner, this applies all the time
            $winner->rate += 1;
            $winner->hits += 1;
            //Case #2 / #3 : here we should adjust the rate after applying case #1
            // if he won while he is expected to lose OR if he lost while expected to win
            // there should be minimum rate different of 40 between the two
            $diff = abs($winner->rate - $looser->rate);
            if($diff >= 40 && ($winner->E < 0.5 || $looser->E >= 0.5)) {
                $winner->rate = AdjustRate($winner->rate, $winner->E, 1);
                $looser->rate = AdjustRate($looser->rate, $looser->E, 0);
            }
    
    
            // update the db to update rates, hits for both winner and looser
                $updateQuery = 'UPDATE user SET rate='.$winner->rate.',hits='.$winner->hits.' WHERE id=' . $winner->id;
                mysql_query($updateQuery);
    
                $updateQuery = 'UPDATE user SET rate='.$looser->rate.' WHERE id=' . $looser->id;
                mysql_query($updateQuery);
    
            // Save to responsedate
            $responseData->winner = $winner;
            $responseData->looser = $looser;
        }
    
        //CODE STARTS HERE :)
    
        // Setup the mysql connection
        include 'db.php';
        // Part 1: calculate the rate and save to db, if we have a lastcall
        // GET the last call data object, it has p1, p2, c, these are the items i recieved from my javascript ajax call
        $lastCall  = json_decode((string)$_GET['lastCall']); // it was a JSON object so i need to decode it first
        // Save last call data, will be sent with the respond as well
        $responseData->lastCall = $lastCall;
    
        // if there is a json object, means that there was a rating process and I have to set the new rates
        if($lastCall->c != NULL)
        {
            setNewRates($responseData->lastCall);
        }
    
        // Part 3: Select new persons and addthem to our responseData
        $q = Array();
        $q[0] = 'SELECT id, name, sex, rate, hits FROM user WHERE fm_status=1 AND sex="female" ORDER BY RAND() LIMIT 2';
        $q[1] = 'SELECT id, name, sex, rate, hits FROM user WHERE fm_status=1 AND sex="male" ORDER BY RAND() LIMIT 2';
    
        // girls or boys ?
        srand(mktime());
        $query = $q[array_rand($q)];
        $result1 = QueryIntoArray($query);
        $responseData->user = $result1;
    
    
        // Part 4: encode to JSON/JSONP string then respond to the call
        $json = json_encode($responseData);
        $json = isset($_GET['callback'])? "{$_GET['callback']}($json)" : $json;
        echo $json;
    
        mysql_close();
        // by Noor Syron :)
        //I used this in my www.mimm.me
    
        ?>
    
        5
  •  1
  •   pratikpc    12 年前

    `我已经用Perl语言设计了所有来自google搜索的代码,并且可以正常工作。

    给你

    use strict;
    use warnings;
    use WWW::Mechanize;
    use LWP::Simple;
    
    sub images()
    {
    my $mech = WWW::Mechanize->new();
    my ($site,$count,$file,$dir);
    print "\t\t\tDesigned By NUMWARZ GAMING\n\n";
    print "Enter the name of the site you want to search for images\t:\n";
    $site = <STDIN>;
    
        print "Enter the folder where you want to save this\t:\n";
    
        $dir = <STDIN>;
    
        open my $doc, ">" , $dir."sitelist.txt";
    
        $mech->get( $site);
    
        my @links = $mech->images();
    
        $count = 0;
    
        for my $link ( @links ) 
        {
        $file = $dir.$count.".jpg";
    
        mirror($link->url,$file);
    
        print $file," : "$link->url,"\n";
    
        print $doc $link->url." ".$file."\n";
    
        $count+=1;
      }
      close $doc;
      exit;
      }
    
     images();
    
        6
  •  0
  •   Henrik P. Hessel    14 年前

    不,不在这里,不在网上任何地方。Facemash源代码从未向公众发布过。唯一一个可能还有副本的是 Mark Zuckerberg 他自己。

        7
  •  0
  •   abhijeet    13 年前
        8
  •  0
  •   Mike    12 年前