Subversion Repositories Sites.tela-botanica.org

Rev

Rev 4 | Blame | Last modification | View Log | RSS feed

<?php

/***************************************************************************\
 *  SPIP, Systeme de publication pour l'internet                           *
 *                                                                         *
 *  Copyright (c) 2001-2005                                                *
 *  Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James  *
 *                                                                         *
 *  Ce programme est un logiciel libre distribue sous licence GNU/GPL.     *
 *  Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne.   *
\***************************************************************************/


// Ce fichier ne sera execute qu'une fois
if (defined("_ECRIRE_INC_POPULARITES")) return;
define("_ECRIRE_INC_POPULARITES", "1");

//
// Popularite, modele logarithmique
//

function calculer_popularites($t) {

        $duree = time() - $t;
        // duree de demi-vie d'une visite dans le calcul de la popularite (en jours)
        $demivie = 1;
        // periode de reference en jours
        $periode = 1;
        // $a est le coefficient d'amortissement depuis la derniere mesure
        $a = pow(2, - $duree / ($demivie * 24 * 3600));
        // $b est la constante multiplicative permettant d'avoir
        // une visite par jour (periode de reference) = un point de popularite
        // (en regime stationnaire)
        // or, magie des maths, ca vaut log(2) * duree journee/demi-vie
        // si la demi-vie n'est pas trop proche de la seconde ;)
        $b = log(2) * $periode / $demivie;

        // oublier un peu le passe
        spip_query("UPDATE spip_articles SET maj=maj, popularite = popularite * $a");

        // ajouter les points visites
        $count_article = Array();
        $query = "SELECT COUNT(*) as count,id_objet FROM spip_visites_temp WHERE maj > DATE_SUB(NOW(), INTERVAL $duree SECOND) AND type='article' GROUP BY id_objet";
        $res = spip_query($query);
        while ($row = @spip_fetch_array($res)) {
                $count_article[$row['count']] .= ','.$row['id_objet'];  // l'objet a count visites
        }

        foreach($count_article as $count => $articles) {
                $query = "UPDATE spip_articles
                        SET maj=maj, popularite = GREATEST(1,popularite) + $b * $count
                        WHERE id_article IN (0$articles)";
                spip_query($query);
        }

        // ajouter les points referers
        $count_article = Array();
        $query = "SELECT COUNT(*) as count,id_objet FROM spip_referers_temp WHERE maj > DATE_SUB(NOW(), INTERVAL $duree SECOND) AND type='article' GROUP BY id_objet";
        $res = spip_query($query);
        while ($row = @spip_fetch_array($res)) {
                $count_article[$row['count']] .= ','.$row['id_objet'];  // l'objet a count referers
        }

        foreach($count_article as $count => $articles) {
                $query = "UPDATE spip_articles
                        SET maj=maj, popularite = GREATEST(1,popularite) + $b * $count
                        WHERE id_article IN (0$articles)";
                spip_query($query);
        }

        // et enregistrer les metas...
        list($maxpop, $totalpop) = spip_fetch_array(spip_query("SELECT MAX(popularite), SUM(popularite) FROM spip_articles"));
        ecrire_meta("popularite_max", $maxpop);
        ecrire_meta("popularite_total", $totalpop);
        ecrire_metas();
}
?>