Si vous ne connaissez pas, allez faire un tour sur la page principale, www.wolframalpha.com/.
Merci à Romain Vernoux qui m'a fait découvrir cet outil en 2012 !
- Wolfram|Alpha est © et ® Wolfram Research Company;
- wolf (ruby cli) est © Gabriel Horner;
- wolfram (ruby cli) est aussi © Gabril Horner.
- ruby et nokogiri sont la propriétés de leurs auteurs respectifs.
L'avantage de ce premier client est sa portabilité : il est très léger (47 lignes de code, avec les commentaires!), et ne demande aucune dépendance, à part grep, curl, tr et sed, déjà installés sur n'importe quel Linux, et disponibles sur Mac OS X (avec brew) and on Windows (with cygwin)..
Néanmoins, ce client est plus minimaliste que wolf (présenté plus bas), et il ne présente aucune option.
La version originale est ici wa.sh (original).
Ma version, sans couleur en sortie, est là wa_nocolor.sh. Une version "plus à jour" se trouve ici wa.sh.
Pour plus de détails, voir plus bas.
Il faut cette fois l'enregistrer dans un fichier ~/.wolfram_api_key sous la forme :
export API_KEY="3HHP2W-UUPQUT6997"Par exemple avec la commande suivante :
mv ~/.wolfram_api_key /tmp/ # Pour ne pas écraser un fichier qui serait déjà là ! echo 'export API_KEY="3HHP2W-UUPQUT6997"' > ~/.wolfram_api_key # Assurez vous que ce fichier ait les bonnes permissions de lecture ! chmod +r ~/.wolfram_api_key
Voici quelques exemples, qui permettent de comparer les sorties des deux clients (voir plus bas pour des exemples avec wolf) :
On pourrait se plaindre de l'incroyable lenteur de cette solution. Plusieurs secondes d'attente pour 4 requêtes, c'est pas mal !
La page principale est github.com/cldwalker/wolf.
Il s'agit aussi d'un client en ligne de commande pour l'outil Wolfram|Alpha.
Pour l'installer sur Ubuntu 11.10 (et plus récent), il est nécessaire d'installer les paquets ruby1.9.1 et ruby1.9.1-dev :
sudo apt-get install ruby1.9.1 ruby1.9.1-dev
Avis
Ruby 1.9.1 n'est plus disponible dès Ubuntu 15.10 !
Je ne peux donc plus tester les exemples d'utilisation de wolf inclus ci-dessous, désolé.
Ensuite, il faut installer Nokogiri.
D'abord, ses dépendances (quelques paquets ruby), et deux librairies :
sudo apt-get install ri1.9.1 rdoc1.9.1 irb1.9.1 sudo apt-get install libreadline-ruby1.9.1 libruby1.9.1 libopenssl-ruby1.9.1 # nokogiri requirements sudo apt-get install libxslt-dev libxml2-dev
Attention, la dernière étape change du tutoriel officiel sur la page de l'auteur. Attention aussi, car cette installation est très longue, la gem ayant besoin d'une étape de compilation, apparemment très longue (plusieurs minutes à 100% de temps CPU).
# Attention : là ça change du tutoriel officiel sudo gem1.9.1 install nokogiri
Et enfin, il faut installer la gem wolf :
sudo gem1.9.1 install wolf
Comme l'explique la page de wolf sur Github, il faut créer un compte, puis obtenir une clé en cliquant sur le bouton "Get an AppID".
Pour l'info, c'est une petite chaîne de caractère qui ressemble à ça :
3HHP2W-UUPQUT6997
Avis
Ceci n'est pas une clé valide ! Utilisez la votre !
Le plus simple est de créer un fichier ~/.wolfrc contenant ça "Wolfram.appid=3HHP2W-UUPQUT6997" :
mv ~/.wolfrc /tmp/ # Pour ne pas écraser un fichier qui serait déjà là ! echo "Wolfram.appid=3HHP2W-UUPQUT6997" > ~/.wolfrc # Assurez vous que ce fichier ait les bonnes permissions de lecture ! chmod +r ~/.wolfrc
Un simple test wolf 0+0 permet d'être sûr de la réussite ou de l'échec de l'installation.
Normalement, les messages d'erreurs renvoyés par Ruby sont à peu près compréhensibles, donc si le premier test vous engueule, il devrait aussi donner les infos nécessaires pour corriger l'installation.
Avis
Le problème le plus fréquent est une confusion entre ruby1.8 et ruby1.9.1 !
Avec l'extension runblock, il est possible d'embarquer le résultat d'un appel à wolf directement dans la page !
Un ajout drôle qui a fait pas mal parler de lui !
Par exemple wolfram.example montre la sortie de la requette "distance Paris Montreal".
Pour plus d'inspiration, il suffit d'aller piocher là bas.
Pour embarquer la commande et la sortie de wolf, j'utilise le morceau de code suivant :
.. runblock:: console $ wolf "ma question"
Une première faiblesse de l'utilisation de la commande rST .. runblock:: console pour exécuter wolf question est la limitation à des caractères ASCII imposée par l'extension runblock (limitation déjà signalée dans cette page, où je suis forcé de changer la langue du terminal pour que gpg ne me sorte pas d'accents).
On pourrait envisager de faire une extension Sphinx qui, comme greffon GNUplot, permettrait d'embarquer des graphiques et des tableaux produits par Wolfram|Alpha. J'ai la flemme de le faire moi-même !