Skip to content

analyse un corpus de textes avec gensim

Notifications You must be signed in to change notification settings

mdiplo/habeascorpus

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

habeascorpus

Outil d'exploration de corpus. Organisé en trois composants :

  • /scripts : permet d'appliquer des algorithmes qui déterminent des topics dans un corpus en utilisant la bibliothèque Gensim (http://radimrehurek.com/gensim/).
  • /api : API RESTful (http://www.django-rest-framework.org/) sous forme de serveur qui répond aux requêtes GET (dans un navigateur web) pour renvoyer les données du corpus calculées avec Gensim.
  • /browser : un navigateur web Angularjs (http://angularjs.org/) qui consomme l'API pour permettre la visualisation des données, en utilisant notamment d3.js (http://d3js.org/)

Préparation des données

Le corpus se présente sous la forme d'un fichier TSV (un article par ligne)

Pour SPIP on peut exporter sa base comme suit :

echo "SELECT a.id_article,a.titre, a.chapo,a.texte,a.lang, GROUP_CONCAT(DISTINCT u.nom SEPARATOR ', ') AS auteurs, GROUP_CONCAT(DISTINCT m.titre SEPARATOR ', ') AS mots, SUBSTRING(a.date_redac,1,7) AS date FROM spip_articles a LEFT JOIN spip_auteurs_articles au ON a.id_article=au.id_article LEFT JOIN spip_auteurs u ON au.id_auteur=u.id_auteur LEFT JOIN spip_mots_articles am ON a.id_article=am.id_article LEFT JOIN spip_mots m ON am.id_mot=m.id_mot WHERE a.statut IN ('publie','prop') AND a.id_secteur=1 AND a.id_article IN (SELECT id_article FROM spip_mots_articles WHERE id_mot IN (598,600,618,619,607,620,602,597)) GROUP BY a.id_article;" | mysql -uroot -p $BASE -B > $BASE.tsv

(ici avec un test sur le statut 'publié') ; ce format permet d'extraire facilement avec grep le nombre d'articles écrits par Untel (ou parlant de "truc"), ou avec wc de mesurer le nombre de mots et de signes correspondants (voir http://seenthis.net/messages/224616).

Une fois le fichier corpus.tsv obtenu, on le place dans un dossier data/; il faut aussi créer un dossier models/ qui va contenir l'ensemble des fichiers générés par habeascorpus.

corpus="articles_fr"
habeascorpus="."  # ou `/chemin/vers/habeascorpus`)

Représentation bag-of-words

La première étape est le calcul de la représentation bag-of-words du corpus :

time python $habeascorpus/scripts/corpus_to_matrix.py $corpus -v

$habeascorpus est le chemin de habeascorpus sur le disque dur.

L'option --stopwords=stopwords_file permet d'ignorer certains mots.

On obtient ainsi dans le dossier data le fichier dictionnaire corpus_wordids.txt qui associe un id à chaque mot du corpus, et le fichier corpus_bow.mm, représentation bag-of-words du corpus.

temps indicatif: 3 min (articlesfr, 21000 articles)

Algorithmes

On peut ensuite appliquer divers algorithmes:

TFIDF

time python $habeascorpus/scripts/tfidf.py $corpus -v --saveindex

(corpus_name est le nom du fichier contenant les articles sans l'extension .tsv)

L'option --saveindex permet de sauvegarder un fichier d'index (utile pour la recherche de doublons, traductions,...)

temps indicatif: 3 min 30

LDA

nb_topics=100
time python $habeascorpus/scripts/lda.py $corpus $nb_topics -v --saveindex

L'option --saveindex permet de sauvegarder un fichier d'index (utile pour la recherche de contenu similaire)

temps indicatif: 24 min

LSI

nb_topics=100
time python $habeascorpus/scripts/lsi.py $corpus $nb_topics -v --saveindex

L'option --saveindex permet de sauvegarder un fichier d'index (utile pour la recherche de contenu similaire)

temps indicatif: 2 min 30

Trucs cools à faire

Doublons

Pour détecter les doublons dans un corpus :

time python $habeascorpus/scripts/find_doublons.py $corpus -v

les résultats sont enregistrés dans le fichier models/doublons_{corpus}.txt

Contenu similaire

Pour trouver les articles similaires à article.txt dans un corpus :

method=tfidf
cat article.txt | python $habeascorpus/scripts/similar_articles.py $corpus $method -v

Avec method : tfidf, lda100, lda50, lsi100,...

Matrice de similarité

Pour construire la matrice de similarités pour un corpus :

python $habeascorpus/scripts/similarity_matrix.py corpus_name method -v

API

L'API RESTful permet de récupérer les données calculées précédemment en effectuant des requêtes GET.

Initialisation

Il faut commencer par créer une base de données contenant les données précedemment calculées. Depuis le dossier data :

python $habeascorpus/manage.py generate_database

Utilisation

Pour démarrer l'API, lancer depuis le dossier data la commande :

python $habeascorpus/api/manage.py runserver

On accède à l'API en entrant l'url http://127.0.0.1:8000/api/ dans un navigateur web.

Requêtes

  • http://127.0.0.1:8000/api/documents/ : liste des documents du corpus

  • http://127.0.0.1:8000/api/documents/id/ : détails d'un document

  • http://127.0.0.1:8000/api/topics/ : liste des topics

  • http://127.0.0.1:8000/api/topics/id/ : détails d'un topic

  • http://127.0.0.1:8000/api/topics/id/history/ : historique d'un topic

Navigateur

Pour visualiser les données dans un navigateur web, démarrer l'API et accéder à l'URL http://127.0.0.1:8000/static/index.html

Dépendances

numpy? ; nltk ; scipy

sudo apt-get install python-numpy python-scipy
sudo easy_install six

et bien sûr gensim:

pip install gensim

Installation du simserver (en dev)

Bien configuré dans habeascorpus/settings.py

On le lance alors avec

python manage.py runserver

ce qui affiche: Development server is running at http://127.0.0.1:8000/

Un proxy permet de publier les résultats sur notre URL de référence : dans .htaccess

RewriteRule ^simserver/ http://127.0.0.1:8000/simserver/ [P]   

Il faudra éventuellement activer le module proxy_http d’apache

sudo a2enmod proxy_http

Pour ne pas avoir 1s de délai quand on envoie, il faut supprimer l’entête Expect: curl -H "Expect;" --data-urlencode texte@text.txt http://127.0.0.1:8000/simserver/

http://stackoverflow.com/questions/8717387/request-always-takes-atleast-1-second-when-timeout-2

Oldies

Traduction

Pour associer les articles d'un corpus_etranger à leur traduction dans corpus_fr, on pouvait faire :

python $habeascorpus/scripts/translate_corpus.py corpus_fr corpus_etranger output_name -v

hélas Google translate a fermé son accès "free lunch" et la librairie goslate est abandonnée. À revoir le cas échéant.

About

analyse un corpus de textes avec gensim

aarchivesdiplo:~/habeascorpus

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 98.8%
  • HTML 1.2%