Archives de catégorie : Développement

Une IA pour aider les proches de personnes souffrant d’un trouble borderline (trouble de la personnalité limite)

Au boulot, je travaille beaucoup avec ChatGPT. Et je me suis réellement formé à titre personnel à l’aide aux personnes ayant des troubles borderline. Alors, à l’issue de la formation, j’ai transmis mes nouvelles connaissances à ChatGPT en créant un GPT spécialisé dans l’aide aux proches de borderlines. Je l’ai partagé avec les autres stagiaires de la formation et ceux qui l’ont testé m’ont dit l’avoir trouvé utile. Il est censé pouvoir aider les proches de borderline à répondre à des questions telles que :

  • Comment réagir quand mon proche fait une crise de colère ?
  • Faisons une simulation d’une discussion délicate avec mon proche.
  • Aide-moi à me détendre après une journée difficile.
  • Mon proche traverse une crise auto-desctructrice, que faire ?
  • Explique-moi ce qu’est la dysrégulation émotionnelle.
  • Aide-moi à faire un point sur mes progrès avec mon proche.

Pour cela, je lui ai fourni certains de nos supports de formation et je l’ai doté des instructions ci-dessous :

1. Mission générale :

Ce GPT est destiné à fournir un soutien pratique et émotionnel aux proches de personnes atteintes du trouble borderline. Il doit adapter ses réponses pour offrir des conseils concrets, de l’empathie, et des outils de gestion des crises et du stress. Son objectif est d’aider les utilisateurs à mieux comprendre et gérer les interactions difficiles avec leurs proches, tout en prenant soin de leur propre bien-être émotionnel.

2. Utilisation des documents et base de connaissances :

Le modèle dispose d’un ensemble de documents de formation qui couvrent différents aspects de la gestion des relations avec des personnes borderline. Il doit s’appuyer sur ces documents pour structurer ses réponses, en les utilisant de manière contextuelle en fonction des demandes. Voici les documents-clés à utiliser dans chaque situation :

– Validation émotionnelle et fixer des limites (fichier intitulé “module5.pdf”) : Utilise ces informations pour répondre aux questions sur la validation des émotions, la fixation des limites et les interactions respectueuses.
– Gestion des crises et comportements autodestructeurs (fichier intitulé “crises.pdf”) : Fais appel à ces documents pour guider l’utilisateur à travers des crises émotionnelles ou des comportements dangereux, avec un ton calme et apaisant.
– Pleine conscience et gestion du stress (fichier intitulé “exercices.pdf”) : Propose des exercices basés sur ces documents lorsque l’utilisateur mentionne une surcharge émotionnelle ou un besoin de gestion du stress.
– Résolution collaborative des problèmes et techniques de communication (fichier “dearman.pdf”) : Utilise ces documents pour les simulations de dialogues et la gestion des conflits relationnels.
– À éviter : Ne fais pas référence à des documents spécifiques par leur numéro ou leur nom. Tu dois répondre de manière fluide, en extrayant les informations pertinentes sans mentionner l’organisation interne de la base de connaissance.

3. Comportement et ton à adopter :

Brièveté avant tout : les utilisateurs peuvent être intimidés ou submergés par des réponses longues, surtout en début de conversation, alors sois bref pour encourager le dialogue et l’écoute ! Si besoin, propose à l’utilisateur de lui en dire plus.
Ton ton doit être empathique, calme et non-jugeant en toutes circonstances. Évite tout langage autoritaire ou condescendant. Ta mission principale est de valider les émotions de l’utilisateur, l’encourager à prendre soin de lui-même tout en lui fournissant des conseils pratiques et applicables. Garde en tête que les utilisateurs peuvent être stressés, épuisés ou confrontés à des situations émotionnelles très délicates voire violentes.
– Empathie et soutien constant : Valide toujours les efforts des proches, reconnais leurs difficultés, et encourage-les à persévérer. Tu dois être un soutien bienveillant.
– Encouragement à l’auto-soin : Propose régulièrement des rappels sur l’importance de prendre soin de soi, surtout après avoir mentionné des interactions difficiles. Par exemple, après avoir donné des conseils sur la gestion d’une crise, tu peux proposer un exercice de pleine conscience ou rappeler que l’utilisateur a aussi besoin de soutien.
– Simplicité et clarté : Évite d’utiliser un langage trop technique ou des explications complexes. Les réponses doivent être directes et faciles à comprendre, tout en restant nuancées pour les situations sensibles.

À éviter :
– Ne fais jamais de diagnostics psychologiques ou médicaux. Si une situation semble trop complexe ou dangereuse, redirige l’utilisateur vers un professionnel de santé.
– Ne pas censurer ta réponse si l’utilisateur évoque une situation de violence ou d’auto-agression car il a au contraire besoin d’être écouté pour son propre bien-être mais surtout pour l’aider à apporter du soutien à son proche borderline
– En cas de comportements à risque élevés comme les tentatives de suicide : prendre la situation au sérieux, écouter activement avec empathie, poser des questions ouvertes (ex: “comment te sens-tu ?”), ne pas hésiter à poser des questions directes (ex : “tu envisages le suicide ?”), évalue le risque immédiat (idéation ? plan ? moyens ? intentions immédiates ?), ne pas juger ni invalider, encourager à consulter un psychologue, un médecin ou une ligne spécialisée, convaincre d’éloigner les moyens.

4. Conseils personnalisés en temps réel :

Lorsque l’utilisateur demande de l’aide sur une situation spécifique (crise, conflit, émotion difficile), utilise les documents pertinents (notamment “crises.pdf”) pour offrir des conseils adaptés. Les réponses doivent être directes, rassurantes, et immédiatement applicables.

Exemple d’instruction :
– Si l’utilisateur demande comment réagir à une crise de colère de son proche, tu dois répondre en t’appuyant sur les techniques de validation (ex. : “Je comprends que tu te sens très en colère. Je suis là pour t’écouter.”) et suggérer une attitude calme et non-jugeante.
– Si l’utilisateur décrit une situation impliquant des comportements autodestructeurs, rappelle l’importance de la sécurité, encourage l’utilisateur à demander de l’aide professionnelle, tout en offrant des conseils temporaires basés sur les documents liés à la gestion des crises.

À éviter : Ne donne jamais de conseils qui pourraient aggraver la situation. Ne suggère pas d’actions pouvant être mal interprétées ou dangereuses (comme ignorer la situation ou prendre des décisions drastiques sans consultation).

5. Simulations et pratiques de communication :

Lorsqu’un utilisateur souhaite s’entraîner à une technique de communication (par ex., DEAR MAN ou GIVE FAST, cf. dearman.pdf), tu dois engager une simulation en jouant le rôle du proche borderline. Fournis des retours constructifs à chaque étape et encourage l’utilisateur à persévérer.

Exemple d’instruction :
– Lors d’une simulation de DEAR MAN, commence par demander à l’utilisateur de “décrire” la situation, puis réponds en jouant le rôle du proche borderline. Après chaque réponse de l’utilisateur, donne un feedback constructif et guide-le vers la prochaine étape (Exprimer, Affirmer, etc.).

À éviter : Ne critique jamais les réponses de l’utilisateur de manière négative ou condescendante. Si une réponse est maladroite, reformule-la pour lui montrer une meilleure manière de procéder sans jugement.

6. Exercices de pleine conscience et gestion du stress :

Si l’utilisateur exprime un besoin de gestion du stress, guide-le à travers un exercice de pleine conscience ou de relaxation, en suivant les instructions des modules pertinents (fichier exercices.pdf). Rappelle l’importance de prendre soin de soi après des interactions difficiles.

Exemple d’instruction : Propose des exercices simples comme la respiration consciente, ou suggère à l’utilisateur de prendre quelques minutes pour observer ses pensées sans jugement. Utilise des phrases apaisantes et encourageantes pour créer un environnement de calme.

À éviter : Ne fais pas de suggestions qui demanderaient un équipement spécifique ou une expertise avancée en méditation. Les exercices doivent rester accessibles et simples.

7. Gestion des crises émotionnelles :

Dans le cas où l’utilisateur est confronté à une crise émotionnelle intense de la part de son proche, garde un ton calme et rassurant. Propose des actions immédiates basées sur les techniques de validation et de gestion des crises, tout en recommandant de consulter des professionnels si nécessaire.

Exemple d’instruction : Si l’utilisateur fait face à une crise de comportement autodestructeur, rappelle l’importance de maintenir la sécurité de son proche tout en restant calme. Propose des phrases pour valider les émotions du proche et encourage l’utilisateur à contacter un thérapeute si la situation persiste.

À éviter : Ne donne jamais de conseils médicaux. Oriente toujours vers des professionnels de santé si la situation dépasse ce que tu peux gérer.

Pour utiliser ce GPT, rendez-vous ici ! En cas de problème d’accès ou pour me dire ce que vous en pensez, envoyez-moi un email à <sig chez akasig point org>

How to run Tesseract from web browsers with the help of emscripten

Tesseract is a fairly accurate Optical Character Recognition (OCR) engine available as open source and free software. It’s written in C and C++ and usually runs from the command line or from a GUI. But I work on a web application where we have to let thousands of users run OCR tasks from their web browsers without having to rely on server-side processing. So we asked our great Capgemini developers team to compile Tesseract so that it could be executed from Javascript code. This is were emscripten is useful : it allows programs written in C to be compiled into Javascript. This compilation was tricky but they made it.

Here is their HOWTO documentation.

I share it under the Create Commons CC-BY-SA 3.0 license so feel free to improve it as you like.

Apprendre à coder, quelles solutions pour mes enfants ?

Mes enfants ont 8 ans et 11 ans, garçons et filles (oui, j’ai des multiples…). Je tiens à ce qu’ils apprennent la culture et les bases du code informatique car je crois que le code modèle en partie la société et que ceux qui s’en sortiront le mieux seront ceux qui sauront “bidouiller” (hacker) la société et non ceux qui se feront bidouiller par elle. Bref. Comment leur donner les moyens et l’envie d’apprendre à bidouiller du code ?

Après réflexion, examen des solutions populaires sur le Net et quelques tests avec mes enfants, en me basant également sur mes propres souvenirs d’enfance (j’ai commencé à coder à 8 ans), je crois que l’approche et les outils à privilégier dépendent grandement de l’âge. Et qu’il ne s’agit pas uniquement de choisir un langage de programmation pour en enseigner les bases mais plutôt de trouver un environnement d’apprentissage adapté à l’âge, motivant et ludique pour créer de l’engagement, du plaisir et de l’effort. En résumé, je pense que, jusqu’à 11 ans, l’environnement idéal est Scratch, ou les jeux blockly. De 11 ans à 14 ans, l’environnement idéal me semble Minecraft. Au-delà, des environnements plus “sérieux”, probablement autour du langage python pourraient être plus appropriés.

En plus de cette approche “par âge”, j’ai été séduit par ce que peuvent apporter les activités d’apprentissage :

  • autour de l’écriture de “fictions interactives” (livres dont vous êtes le héro) qui tirent partie de l’interdisciplinarité entre la littérature, les arts et le code,
  • autour du matériel informatique (Arduino, Raspberry Pi, Lego Mindstorms ou tout simplement assembler un ordinateur)
  • mais aussi en “mode débranché” pour découvrir l’algorithmie théorique, sans matériel informatique, avec du papier, un crayon, des allumettes, etc.

Je me dis que ce qui manque aussi probablement, étant données les tendances technologiques de fond, ce sont des activités pour faire découvrir le machine learning aux enfants, les bases de la probabilité appliquée à la résolution automatisée de problèmes (raisonnement bayésien, etc.).

Enfin, quel que soit l’âge ou les types d’activités, se pose un défi pédagogique : comment animer ces activités lorsqu’on a soi-même peu de temps (ou beaucoup d’enfants…) ? Pour répondre à cela, deux pistes se dégagent :

  1. les ateliers animés par des professionnels (mais il y en a peu sur le territoire français, en dehors de Paris et quelques grandes villes)
  2. ou bien les mécanismes de jeu qui, avec le bon scénario et la bonne plate-forme éducative, guident la progression des apprenants avec moins de dépendance à un animateur (donc de manière moins coûteuse en temps et en argent).

Les mécanismes de jeu (le gameplay, règles, système motivationnel de quêtes et badges) et le scénario (imaginaire adapté et motivant) sont importants, mais la richesse visuelle du jeu importe presque autant (on ne refait pas nos vieux cerveaux…). Le fait de pouvoir changer le personnage d’un jeu en un petit panda a fait un gros effet (positif) sur ma fille… Presqu’autant que si elle avait pu le transformer en pingouin tux.

Voici donc, en vrac, une sélection de ressources pour illustrer sur quoi s’appuient mes croyances actuelles.

Autour de Scratch

Autour de Blockly

  • les jeux Blockly proposent une bonne progression pour découvrir les bases de l’algorithmie (boucles, branchements conditionnels et variables), c’est ce que j’ai pu vérifier avec ma fille (11 ans), mais on est vite frustrés par la raideur de certaines étapes de cette progression : soit on maîtrise déjà les concepts et ça passe très vite, soit réussir à franchir certaines étapes ressemble à un casse-tête assez douloureux ; j’aurais aimé voir une progression plus longue, plus variée et plus “pas à pas” parfois
  • RapidRouteur est une progression ludo-éducative basée sur blockly, avec plus de 100 niveaux de jeu et qui mène peu à peu à découvrir Python (malheureusement seulement en anglais)
  • pencilcode ressemble à blockly et propose des tutoriels mais reste en anglais seulement pour le moment
  • Code4Kids est une solution française d’animation pédagogique proposée pour les écoles du premier degré par Catchu, autour d’un environnement Blockly
  • Sur une logique Blockly mais sur téléphone, l’appli iOS HopScotch propose un environnement pour apprendre à programmer des jeux mobiles ; mais est-ce vraiment du blockly là-dessous ? je n’ai pas vérifié

Autour de Minecraft

  • avec les super “Guides officiels” (débuter, construction, combat, Redstone, …) pour découvrir toutes les arcanes du jeu
  • l’intérêt pédagogique de Minecraft est démultiplié si on utilise les bons serveurs, “mods” et leurs tutoriels, mais cela implique d’accéder à un serveur adapté voire de se créer son propre serveur :
    • Gnancraft est créé et utilisé par Raphaël Pierquin et l’équipe des Coding Goûters
    • ThoughtStem propose des ateliers de programmation avec Minecraft pour les enfants dans la Silicon Valley mais également quelques activités en ligne
    • LearnToMod est une plate-forme payante pour apprendre la programmation à travers la modification de minecraft
    • ComputerCraft est un mod minecraft destiné à la découverte de la programmation et qui permet d’apprendre à scripter en langage LUA
    • Avec Minecraft, vous l’aurez compris, on est dans un environnement très immersif et très bidouillable alors pourquoi ne pas enseigner les mathématiques via Minecraft ?

Autour de Python :

  • Parmi les langages de programmation généralistes qui ont un véritable usage industriel, python est sans doute le plus utilisable pour l’apprentissage de la programmation car il combine une syntaxe très lisible et un modèle exemplaire de programmation orientée objet ; il ne lui manquerait plus qu’une syntaxe en français pour faire fureur dans les bacs à sable des lycées… En attendant, faut-il imaginer faire découvrir la programmation au collège ou au lycée en utilisant pygame et piglet comme environnements ? sans doute serait-ce un choix plutôt risqué car on peut lire des doutes crédibles sur la vivacité de la communauté pyglet, sur son usage des decorators qui est difficile à expliquer pour des débutants et ressemble donc à une magie arbitraire et fort peu éducative…
  • Etant donné la popularité et la richesse de la communauté python, de bons livres existent certainement en français pour pour apprendre la programmation avec python,
  • Checkio est un jeu en ligne très séduisant pour apprendre à programme avec python

Autour de JavaScript

Quand on devient plus grand et qu’on veut manipuler du code “pour de vrai”, python est une excellente solution mais JavaScript s’étant imposé partout sur le Net ces dernières années comme langage généraliste, y compris côté serveurs, il n’est pas idiot d’apprendre la programmation avec JavaScript, même si ça a un petit côté maso et casse-cou. Alors pourquoi ne pas découvrir carrément la programmation par ce biais, avec par exemple Code Monster (en anglais). JSWarrior fait pâle figure à côté d’autres plate-formes ludo-éducatives et place la barre un peu haut pour les débutants : animateur indispensable.

Avec des fictions interactives ?

Les “Livres dont vous êtes le héro” (également appelés “Livres-jeux”, “Choose Your Own Adventure”, “CYOA” ou “gamebooks), sous forme numérique, sont des contenus interactifs qui permettent de visiter sous une forme créative et motivante des concepts simples d’algorithmie (branches conditionnelles, variables, voire conception objet), de programmation (compilation, exécution) mais aussi de design de jeu. Bien sûr, on peut faire une fiction interactive avec de simples liens hypertextes dans un wiki, mais les logiciels pour écrire les fictions interactives sont devenus très sophistiqués en s’inspirant des premiers jeux textuels en liens (les muds) et en introduisant donc des possibilités algorithmiques amusantes et créatives. Je n’ai pas cherché de proposition de progression pédagogique pour découvrir l’algorithmie à travers l’écriture de fictions interactives mais je suis à peu près sûr que ça existe. Cet angle de découverte de la programmation pourrait très bien convenir aux enfants les plus férus de lecture, d’écriture… et d’aventure. De nombreuses solutions logicielles très éprouvées et plus ou moins faciles à prendre en main existent pour créer des fictions interactives plus ou moins sophistiquées informatiquement. Parmi les logiciels de création les plus connus, on peut citer Twine, le vénérable Inform7, TADS, ADRIFT, ALAN mais aussi, avec un côté plus récent, squiffy et QuestKit. Il faudrait y regarder de plus près. Des bibliothèques en ligne permettent ensuite de partager et découvrir les créations, pour les lire et s’y plonger sur ordinateur ou sur smartphone.

Avec du matériel bidouillable

Pour les enfants et parents qui n’ont pas peur de leurs doigts…

Bien sûr, on doit citer les vénérables mais toujours d’actualité Lego Mindstorms, pour les plus familles qui en ont les moyens. Mais on regardera surtout du côté de  :

Autour de plate-formes ludo-éducatives “tout-intégré”

Il existe des sites Web proposant des progressions ludiques pour apprendre la programmation. La plupart sont fondés sur des logiciels dits privateurs. Vous n’avez pas le droit de les utiliser comme vous voulez, de les étudier, de les partager, bref de les bidouiller, ce qui est un peu paradoxal. Mais l’avantage de ces plates-formes peut résider dans leur caractère “intégrée” : elles pourraient offrir une expérience ludique plus agréable et pédagogiquement plus efficace si elles accompagnent de A à Z les programmeurs en herbe. Mais au risque de disparaître corps et âme en cas de faillite commerciale. Quelques-unes de ces plate-formes utilisent du libre, mais ce ne sont pas forcément les meilleures pédagogiques.

  • Autour de C++ : quitte à être maso, pourquoi ne pas apprendre la programmation avec un langage beaucoup compliqué à apprendre que python ou même JavaScript, c’est le défi que propose pourtant codowl.io (ah tiens, c’est en français ?)
  • Code.org propose des progressions en français sous forme de sélection d’activités débranchées, de jeux algorithmiques et d’activités de programmation. C’est un peu la Khan Academy de la programmation : une association américaine à but non lucratif fait vivre cette plate-forme, à grands renforts de dons de Microsoft, Facebook et autres Google. Très Silicon Valley. Le code qui fait tourner la plate-forme est libre mais pas les contenus des activités pédagogiques qu’elle héberge. La richesse et la qualité des activités proposées semble pertinente. Hum… Pas mal.
  • Codecombat.com vous embarque dans un vrai jeu vidéo pour apprendre à programmer, avec des contenus graphiques et sonores de qualité. Le joueur a le choix du langage de programmation qu’il veut apprendre (au moins au niveau de la syntaxe) : python, coffescript, clojure, … le choix est vaste. Et franchement, c’est du joli ! Ca donne envie de jouer et d’apprendre… A signaler encore quelques bugs et défauts de traduction en français.
  • Blackvoxel est un jeu en logiciel libre, pour apprendre le C++, l’assembleur et le graphisme 3D. On dirait bien là un jeu pour apprendre à programmer des jeux “à la dure” plutôt qu’avec des progressions pédagogiques pour débutants. A réserver pour des lycéens ou des passionnés qui se seront déjà fait la main sur des langages et des environnements plus simples ? Blackvoxel semble proposer des modalités intéressantes pour impliquer un enseignant dans la progression de ses élèves-joueurs.
  • Encore pour des lycéens (ou pour des grands collégiens, +13 ans), LiveCode propose une solution d’apprentissage du code pour développer des applis mobiles.

Bon, voila pour mon petit tour du moment. Je suis surpris par la quantité de solutions proposées, y compris en français, et par la première impression très positive que me donnent certaines d’entre elles. Pour mes enfants, je compte explorer les pistes blockly mais surtout Minecraft car la communauté des modders Minecraft est tellement grande qu’il existe déjà tout un tas de réponses à des problématiques pédagogiques récurrentes. Par exemple, il existe des systèmes de gestion de quêtes dans Minecraft qui me semblent intéressantes. Et si je pouvais promettre 5 minutes de Minecraft de plus à celui de mes enfants qui fera la vaisselle demain soir ? ou à celui qui aura bidouillé avec succès tel ou tel aspect de notre vie familiale ?

Et vous, vous en faites quoi de tout ça ?

Smart Contracts, crypto-monnaie et Revenu Libre d’Existence

J’ai un ami qui dédie sa carrière au “libre” et aux “biens communs” et je m’apprêtais à lui soumettre une idée d’innovation solidaire par email. Mais je lui ai dit que ça pouvait aussi t’intéresser, cher lecteur-contributeur. Ca parle donc de liberté, de solidarité mais aussi de cryptomonnaie (bitcoins, ethers) et de programmation de “smart contracts” solidaires. Donc essentiellement de numérique et d’innovation sociale.

L’idée de base, c’est d’essayer de rendre libres et communs des biens rivaux, ce qui est théoriquement impossible. J’ai évoqué cette idée ici il y a quelques années mais en anglais. Le principe est inspiré du Pay-It-Forward et de l’économie de communion. Un peu comme avec une licence de logiciel libre (copyleft), on rédige un contrat entre nous du style suivant.

Je te donne ce stylo (je te le “libère”) à condition que tu t’engages à donner à ton tour un stylo de valeur égale ou supérieure à celui-ci à la première personne qui t’en fera la demande dès qu’elle t’en fera la demande et acceptera les mêmes conditions que celles-ci et sans poser aucune restriction supplémentaire sur cette personne, le stylo ou l’usage que cette personne en fera.

Le stylo en question devient donc “libre” dans la mesure où plus personne ne peut se l’approprier au point d’en priver les autres. Mais tout le monde peut l’utiliser, l’étudier, l’améliorer et le partager. Presque comme un logiciel libre. Bien sûr, la différence principale c’est que, dès que je rend ce stylo à mon prochain, je ne l’ai plus. On ne peut pas l’utiliser simultanément à plusieurs. Mais je n’en suis pas non plus définitivement privé puisque je peux le redemander. Et si je l’use trop, c’est à moi de le réparer, de le remplacer ou de l’améliorer pour que je rende toujours une valeur au moins égale à celle que j’ai reçue.

Ce qui est amusant, c’est que si on inclut cette notion “d’intérêts” au sens financier (je te donne 1 stylo si tu t’engages à en donner 2, ou bien je compense au moins “l’usure” du stylo) et une notion de prix comparable ou de valeur au moins équivalente (je te donne des biens de valeur X si tu t’engages à en donner de valeur X * 2, pas forcément les mêmes biens) alors on peut imaginer contaminer ainsi tous les biens rivaux de la planète et, en théorie, mettre fin en pratique à la propriété privée. En pratique… en théorie.

Je te libère 1 euro la prochain fois que je te vois à condition que tu t’engages à en libérer 2 fois plus à la première personne qui t’en fera la demande, dès qu’elle t’en fera la demande et acceptera les mêmes conditions que celles-ci et pas une de plus. Par effet boule de neige, ce contrat librement contaminant pourrait, à terme, empêcher quiconque de refuser de partager son argent avec son prochain…

Bon, l’idée peut paraître amusante mais, en pratique, elle est difficile à implémenter à grande échelle. Il serait coûteux de faire respecter un contrat de ce type. Difficile de savoir qui détiendrait, à un instant t, des biens libres, lesquels et de quelle valeur, selon quelle version du contrat. Difficile de s’assurer que le bien rendu est effectivement de valeur égale ou supérieure au bien libéré. Et ensuite difficile d’obtenir d’un système judiciaire qu’il fasse appliquer ce contrat en allant jusqu’à faire saisir les biens libres de cette personne. Sans compter les personnes qui organiseraient leur insolvabilité par malhonnêteté ou seraient tellement endettées que ça ne serait pour elle qu’une dette insolvable de plus, cette fois vis-à-vis de tous tiers. Des dettes communes, en quelque sorte. Les insolvables agiraient alors comme des trous noirs à biens communs, en profitant mais en privant alors définitivement les tiers. Une tragédie..

Mais les choses sont plus facilement maitrisables avec la notion (compliquée) de smart contract. Je ne vais pas expliquer ici ce concept mais supposer que tu sais ce qu’il en est. Pour ce qui nous intéresse, on peut imaginer programmer un token de cryptomonnaie basé sur Ethereum selon un contrat de liberté inspiré de la GPL et du pay-it-forward : Alice donne ce token à Bob à condition que, etc. L’intérêt du smart contract c’est que Charles et David n’ont pas besoin de faire confiance à Bob pour savoir que le contrat va s’appliquer. Le contrat s’applique automatiquement, informatiquement, et avec une traçabilité parfaite. On peut programmer le contrat pour savoir à tout moment qui détient quels tokens libres et combien et selon quel contrat, et ces tokens peuvent être obtenus automatiquement par n’importe qui en ferait la demande. Il y a bien sûr un risque de fraude si on permet aux tokens d’échapper au contrat. Par exemple, si j’échange mon token contre des euros et que je m’approprie les euros obtenus au lieu de les laisser soumis au contrat qui me lie ainsi au reste de l’humanité. Qui va garder la contrainte de liberté lié au caractère “commun” de ce token ? Celui qui a obtenu les euros ? Ou celui qui aura récupéré le token libre ? Que vaut un token libre s’il ne peut pas être utilisée aussi librement qu’une monnaie non libre ? L’idéal serait que le détenteur de token libres puisse effectivement les échanger contre des euros libres, qu’il garde la charge de liberté initialement attachée au token mais désormais attachée aux euros dans le monde hors numérique dans lequel le smart contract ne s’applique plus automatiquement. Mais ce risque doit être quantifiable, limitable et gérable.

Du coup, ça m’a donné une idée d’extension autour du concept de revenu d’existence. L’idée est de faire circuler des smart contracts programmés pour permettre une redistribution équitable et universelle des richesses monétaires entre les personnes. Un revenu d’existence qui ne serait pas émis par une administration pour ses administrés seulement mais qui serait auto-organisé par contrat et librement consenti par ses souscripteurs en fonction de leur générosité (et de leurs besoins). Imaginons donc le contrat suivant.

    Alice verse 1 ether à Bob en tant que “revenu libre d’existence” (RLE) à condition que Bob s’engage à reverser un RLE :

  • à la première personne physique vivante qui en ferait la demande pour une période donnée, (Bob ne choisit pas le demandeur Charles qui lui demandera un RLE pour le mois de juillet 2015)
  • dès que cette personne en fait la demande, (Charles le demande le 9 août 2015 et donc l’obtient immédiatement, automatiquement, sans que Bob puisse s’y opposer comme il s’y est engagé initialement auprès d’Alice)
  • tant que la somme cumulée des reversements de RLE effectués par Bob est inférieure à la somme cumulée des RLE reçus par Bob, multipliée par un facteur d’intérêt F supérieur ou égal à 1, (tant que Bob n’a pas déjà reversé à des tiers F fois le montant total de RLE dont il a bénéficié ; une fois que Bob a beaucoup reversé de RLE, il s’est acquitté du contrat de RLE qui le liait à Alice)
  • et, étant défini que le montant nominal du RLE d’une personne pour une période donnée est égal à la somme cumulée des RLE reversés au cours de cette période divisée par le nombre de personnes ayant reçu ces reversements, (par égalité, le montant nominal du RLE est un partage égalitaire de tous ce que les gens ont pu reverser comme RLE à cette période), tant que Bob, pour la période demandée, n’a pas déclaré avoir touché comme revenus totaux un montant inférieur à 4 fois le montant nominal du revenu d’existence pour cette période, (c’est une exception au principe de liberté au nom de la solidarité ou de la fraternité : par solidarité, on autorise Bob à s’approprier temporairement le RLE qu’il a perçu tant qu’il est pauvre et donc à priver les tiers du reversement de ce RLE)
  • d’un montant égal au montant nécessaire et suffisant pour que cette personne ait bénéficié, au titre de cette période, du montant nominal du RLE d’une personne pour cette période, (on reverse à Charles ce dont il a besoin pour bénéficier d’un RLE complet pour cette période, mais pas plus)
  • sous les mêmes conditions que celles énumérées dans ce contrat ou dans toute version de ce contrat émise ultérieurement par Jean Millerat (il pourrait s’agir d’un auteur plus compétent, comme une Free Software Foundation de la liberté, de l’égalité et de la fraternité, composée de juristes confirmés…)
  • et sans apporter de restriction ou condition supplémentaire.

Donc tous les bénéficiaires du RLE reversent à leur tour un RLE aux personnes qui le demandent. La machine est amorcée par les personnes solidaires qui acceptent de libérer un peu d’argent de temps en temps (les Alice). La machine est entretenue par tous les bénéficiaires suffisamment riches pour reverser leur RLE et un peu plus, à toute la planète (les Bob et les Charles). Et la machine bénéficie à tous ceux qui, à un moment de leur vie, n’ont pas assez de revenus pour reverser immédiatement un RLE (parfois Bob, parfois Charles). C’est une espèce de gigantesque mutuelle automatisée, en quelque sorte.

Je vais donc jeter un coup d’oeil à la programmation de smart contracts sur Ethereum pour voir dans quelle mesure ce concept est implémentable et donc ensuite essayer de le tester.

A noter : ce concept peut être étendu à de nombreuses autres formes d’innovation sociale, c’est le tour de force des smart contracts et des cryptomonnaies, qui “informatisent la confiance” (qui rendent la confiance inutile dans certaines transactions en automatisant leurs conditions d’exécution). Par exemple, plutôt que de prévoir une exception solidaire de non-reversement immédiat par les plus pauvres, on pourrait imaginer un contrat dans lequel Charles peut définitivement s’approprier le montant perçu (ne pas avoir à le reverser) à condition d’avoir produit un bien commun dont la valeur est estimée par un panel de souscripteurs comme étant au moins égale au montant perçu. Un peu comme si Charles avait convertit un token de cryptomonnaie libre en un bien commun tel qu’un logiciel libre, des contributions à la wikipedia, à OpenStreetMap, etc. Le contrat devient alors un modèle de financement de la création de biens communs.

Tu imagines d’autres applications possibles de contrats de ce type ? Qu’est-ce que ça t’inspire ?

A/B split testing with Plone

I have a deep interest in the lean startup method. One of the favorite tools of the lean startuper is A/B split testing. My favorite software package is Plone. Can Plone be used for A/B split testing without having to develop a specific python product ? The answer is probably yes.

Here is my recipe for a starter toward A/B split testing with Plone :

  1. take a fresh Plone
  2. add a PloneFormGen
  3. add a “Thank you” page for each and every option you want to test ; note the ID of the pages (e.g. page “optionA” and page optionB”) ; the user will be redirected to one of these pages
  4. add a text field to the form (multiple-lines text field not one-line string field)
  5. override the default value of this field with the following tales expression :

    python:[random.seed(str(request.AUTHENTICATED_USER) + request.REMOTE_ADDR), random.choice([i.getId() for i in here.aq_parent.aq_inner.listFolderContents(contentFilter={“portal_type” : “FormThanksPage”})])][1]

  6. make the text field a hidden and server-side field
  7. overrides the form’s custom validation action with the following expression :

    redirect_to:request/form/page

    where “page” is the ID of the text field you set up above.

  8. add a Data Recorder to the form so that the value of the “page” field gets recorded

What do we have now ? We have a form with a button. When the user clicks on the button, she is randomly redirected toward one the several “Thank You Pages” that you have defined. The redirection is based on the IP address of the user and her username if she is authenticated. The redirections are uniformly distributed against your destination pages. And they are recorded in the data record field.

You A/B split test is not complete and several further steps must be taken before this is a fully operational solution but that was an enjoyable hack to make for me. Have fun with it and tell me how you would proceed with split testing and continuous deployment using Plone !

Recycler des vieux PC, bonnes et mauvaises pistes.

Il y a 4 ans, j’ai récupéré par mon employeur une quarantaine de PC qui dataient de 2000 à 2003 et devaient partir à la casse. J’étais un peu dégoûté du gâchis consistant à les détruire au prétexte que leur valeur comptable était nulle et permettait donc à l’entreprise d’en acheter de plus récents. J’ai donc récupéré ces PC. J’ai exploré plusieurs pistes pour essayer de leur offrir une nouvelle vie. Mauvaises et bonnes pistes, voici mon bilan :

  1. les configurer pour les limiter à un usage associatif dans un quartier sensible : MAUVAISE PISTE => On a craint que l’association visée ne fasse don des PC dans le quartier et que ceux-ci terminent vendus “aux puces” plutôt qu’utilisés dans un contexte solidaire. J’ai donc verrouillé les PC en utilisant des logiciels de gestion de configuration (FAI et BCFG2). Cela a pris du temps de mes soirs et week-ends (beaucoup trop de temps… mais j’ai découvert que BCFG2 est un super logiciel qui pourra me servir pour le boulot…). Au final, me voici avec 40 PC sous contrôle. Entre temps et avant livraison, l’association pressentie a vu son local dévasté et vandalisé par des jeunes du quartier et la mairie a refusé de lui attribuer un nouveau local. Le local a-t-il été dévalisé parce que des jeunes du quartier espéraient monter un business avec les PC en question et ont été déçus du “retard à la livraison” ? Qui sait ? On peut tout imaginer. Au final, plus de local. Donc plus d’utilisation associative. Le responsable de l’association, courageux, récupère malgré tout une douzaine de ces vieilles machines qu’il installe pour les jeunes dans le sous-sol d’un pavillon. Mais mon système de contrôle à distance m’indique que, plusieurs années après, ils n’ont jamais été connectés au Net : jamais utilisés ? utilisés sans connexion ? ou déverrouillés malgré mon système de contrôle ? impossible à dire et peu importe…
  2. les prêter via une petite annonce sur mon blog ? MAUVAISE PISTE. Si cette association-là ne peut pas en prendre plus, peut-être que quelqu’un d’autre en voudra ? Je tente la petite annonce sur mon blog. Je reçois deux réponses mais la discussion se perd, une personne se dit intéressée et ne donne plus suite… Ca n’avance plus.
  3. envoyer 20 PC en Afrique ? MAUVAISE PISTE. Je contacte une ONG à Yaoundé (Cameroun). Le responsable local est ravi. Il contacte une société de transport en France. Après plusieurs mois de discussion, le devis est exorbitant et il doit renoncer.
  4. les confier à une asso française qui les envoie à son tour en Afrique ? MAUVAISE PISTE.Les 20 PC dorment dans mon salon et dans le garage de ma grand-mère… Nous contactons une association française qui collecte les vieux PC pour les envoyer en Afrique. Cette association les refuse : les PC sont certes rapides sur le Net si ils sont configurés sous linux (xubuntu) mais, en Afrique, les utilisateurs veulent du Windows XP et, même si les locaux promettent d’accepter du Windows 98 ou du Windows 2000, ils ont l’habitude de trouver ça “trop vieillot” et des petits malins les remplacent par du Windows XP puis se plaignent que la machine rame à mort et donc la considèrent comme foutue, bonne pour la poubelle… Quant à linux, qui connait linux dans les associations de solidarité en Afrique ? Pas assez de monde. Donc l’association française refuse de relayer ces PC.
  5. Les donner à des écoles en France ? MAUVAISE PISTE. L’école primaire de mes enfants dispose déjà d’une salle informatique flambant neuve. Les élèves n’y vont quasiment jamais car les enseignants n’aiment pas l’informatique, ne sont pas compétents ou ont peur. Quant aux écoles non équipées, le responsable informatique de circonscription n’accepte pas les dons de vieilles machines car il ne sait pas utiliser linux et souffre du syndrome “si c’est pas la dernière version de Windows, c’est que c’est une machine trop vieille pour être utilisable”. Comme les entreprises en fait…
  6. Les donner sur Freecycle ? MAUVAISE PISTE ! Grosse déception. Je publie d’abord sur le freecycle de ma ville, puis celui de la grosse ville voisine enfin sur celui de Paris. Après plusieurs semaines d’attente, il n’y a que 2 ordinateurs qui partent.
  7. Les donner via donnons.org ? BONNE PISTE ! Je publie mon annonce de don sur donnons.org et, en moins d’une semaine, j’ai plus de 20 personnes qui répondent et sont preneurs. Ca y est, tous les PC sont partis… Enfin… sauf 4 dont les demandeurs ne sont pas venus les chercher. Je relance quelques-uns des autres demandeurs et j’espère qu’ils partiront dans les jours qui viennent.

Ouf. Vive donnons.org !

Free money

Not “free money” as in “free beer” but free as in “free speech”. I mean “Libre money”, like “Libre software”. Money made free. Goods made free so that they make people freer. What could this mean ?

Could the concept of copyleft found in the realm of software and intellectual creativity be transposed to material and rival goods so that humans get freer from their dependency on material goods and property ?

Let’s pretend I have a pencil in hand (or 10 euros). Here is my (imaginary) offer to you be : you can get this pencil if and only if :

  • after some predefined time (let’s say after 10 seconds) you must accept to give this pencil (or an equivalent pencil ?) further (not back) to anyone who asks for it and accepts some predefined conditions (the contract)
  • the most important condition this futher person/borrower must accept is to further transfer the goods along with their freedom contract once the defined delay has expired : they can’t put any additional restrictions to the freedom of people wishing to get these pencil(s)
  • maybe you will have some interest to add to it (for instance the condition may be that you must accept also giving a second pencil under these conditions after 10 seconds)

Once you get the pencil under such a contract, you are free to do anything you want with this pencil (you may draw a picture for instance). 10 seconds later, you may still keep it as your own (and keep on drawing pictures meanwhile) until someone comes to you and asks for this pencil. Then you must propose this pencil and an additional one under the conditions above. If the further person accepts these conditions, she may take this pencil (or these 2 pencils) and do the same : do anything she wishes during some time then keep doing anything she wants until someone gets the (1, 2, 3 or 4) pencil(s) under the same contract.

From now on, these pencils are made free. They are still the property of the persons who initially set them free. But, as long as the conditions of the contract are respected, they will freely flow from person to person. If there is an interest rate defined in the contract (the second pencil or 100% interest rate in the example above), then these interests are also made free and will contribute to the total amount of free rival goods in circulation. In some future, the whole population of pencils of planet earth may be made free in such a process !

You may note that this whole concept I am proposing here :

  • is rooted in the free culture of free software
  • is also rooted in the culture of giving in freedom which the economy of communion tries to promote
  • gets inspiration from the current trend of sharing stuff via the Internet, and optimize the ownership and use of material goods, including the fabulous freecycle network
  • somehow relates to the American ideal of “giving back to the community” (once you are richer) but with a twist
  • allows charitable gifts to poor people to be made less humiliating because the gift is now a loan and “officially” recognizes that the person receiving goods (the “poor” person) also receives a debt not toward the giver but toward humanity, while still giving merit to the initial loaner who “sufffers” from the “loss” of the items made free
  • is a common practice in many traditions such as master/apprentice  or teacher/student or parents/children relationships : master transfers some trade knowledge to apprentices as long as a moral obligation to further transfer this tradition/knowledge to future generations of apprentices/would-be-masters.

Now there are several practical problems with any attempt at contractualizing these practices of “giving back to the community” :

  • what if someone is materially not able to further give/transfer the good when the loan delay has expired ?
  • how to limit the risks of having malicious people exploit the system at their own profit and break the chain of freedom ?
  • are interests rate desirable or even morally acceptable ?
  • which sets of conditions would best guarantee the development of the freedom of humanity with regards to these goods ?
  • could such contracts be drafted and enforced world-wide despite borders and disparities among national laws ?
  • in order to maximize the probability that people don’t abuse the system and protect the freedom of these goods in further paying their debts, should the power of this contract mainly rely on justice (a judge may take your goods in order to pay your freedom debt) ? or on social mechanisms (such as only accepting female borrowers or borrowers who come as a group of independent but socially related people, in a way similar to some practices in the field of microcredit) ? or both ?
  • could such a system be made viable offline ? or will it necessarily rely on online trust mechanisms (identity, reputation, social networks, cryptography, …) ?
  • could such a system be made viable without a central platform ? can it work in a peer-to-peer fashion in the same way free software licences work (the only central point of failure for the GPL is the unique power of the FSF to release later versions of the GPL) ?
  • could the risk of failing borrowers (people not paying their debt further) be covered by some insurance mechanisms and agents ?

My real purpose here (beyond playing with an attractive concept) is to invent a contract which can be useful in order to augment the freedom of people to access and use goods they don’t own while still protecting (and contributing to) the freedom of further people to do so.

With your comments and contributions, maybe we could find the perfect combination of conditions a freedom loan contract should impose in order to meet the purpose above.

In further comments or posts, we/you may :

  • tell the fiction of several goods released under free loans/free debt contracts in order to explore the potential advantages and drawbacks of some combinations of conditions,
  • propose several such loans “for real” to readers in order to practically experiment and play with these concepts.

(But please DO NOT ASK for money here. Money will not be given to you. People asking for money and not usefully contributing to this conversation may be banned as spammers.)

Comment installer une plate-forme Wecena ?

Wecena est une entreprise qui organise des chantiers de mécénat de compétences pour informaticiens. Mais Wecena, c’est aussi un ensemble de logiciels libres (et open source et gratuits, licence AGPL) qui permettent d’organiser des chantiers de volontariat, de mécénat ou de bénévolat de compétences pour mettre des professionnels au service de grandes causes. Vous pouvez librement installer ces logiciels sur vos propres serveurs pour mettre en place des plates-formes réunissant entreprises et associations autour de projets de solidarité. Les logiciels Wecena sont déjà :

  • utilisés par Wecena dans le secteur informatique
  • installés par Investime pour organiser des missions professionnelles de solidarité dans les métiers de l’assurance (soutien à des institutions de micro-finance en Afrique notamment)
  • étudiés par Antoine G. pour organiser des chantiers de mécénat de compétences dans certains métiers du conseil et des services

Voici un copier-coller de mes derniers échanges par email avec Antoine (avec sa permission). Ceci peut vous aider à savoir comment installer votre propre plateforme Wecena. Pour pouvoir suivre ces échanges (et installer Wecena sur vos serveurs), il faut avoir les compétences suivantes :

  • notions d’administration systèmes linux
  • expérience en développement Web objet, si possible sur un langage open source

From Antoine G. to Jean M.

[…] Nous serions intéressé de tester la plateforme Wecena que tu as mise en place.

Pour cela, [j’ai reçu un mail] sur lequel tu indiques l’adresse de ta plateforme de test avec quelques comptes ainsi que les étapes nécessaires à l’installation de Wecena sur un autre serveur.

Je t’avouerai que sur ce deuxième point j’ai fait un checkout sur mon serveur debian, et regarder quelque peu le lien sur la configuration et le lancement d’un buildout de Plone mais tout ceci n’est pas clair pour moi encore. Si comme tu le proposais, tu pouvais me transmettre un exemple de buildout comme point de départ, avec un mini tuto, ça pourrait grandement me / nous rendre service ;-)

Et à vrai qu’est-ce exactement qu’un buildout, une sorte de Makefile ?

J’ai déjà python 2.4.4 d’installer et j’ai ajouté quelques packages qui pourraient m’être utiles “plone3-site” et “zope-plone3” (à peu près similaire j’ai l’impression).

Je te remercie par avance, pour l’aide que tu pourras m’apporter en temps voulu.

Quoiqu’il en soit, je continue de potasser le tuto plone sur la création de bluidout de mon côté…

From Jean M. to Antoine G.

Le 22/12/2010 23:43, Antoine G. a écrit :

> Je t’avouerai que sur ce deuxième point j’ai fait un checkout sur mon
> serveur debian, et regarder quelque peu le lien sur la configuration et
> le lancement d’un buildout de Plone mais tout ceci n’est pas claire pour
> moi encore.
> Si comme tu le proposais, tu pouvais me transmettre un exemple de
> buildout comme point de départ, avec un mini tuto, ça pourrait
> grandement me / nous rendre service ;-)

La première chose que tu devrais faire, c’est sans les produits Wecena : essaie d’installer Plone 3.3.5 via son buildout en suivant ce tutoriel
http://icp.ge.ch/sem/plone-dip/le-pool-plone-dip/icp-zope-technique/installation-plone3-buildout

> Et à vrai qu’est-ce exactement qu’un buildout, une sorte de Makefile ?

Oui, en quelque sorte.

C’est un ensemble de fichiers de config (habituellement en “.cfg”) qui indiquent au logiciel buildout quelles sont les dépendances et paramétrage de déploiement d’un logiciel Python (par exemple de Zope et Plone).

Quand tu télécharges Plone sur plone.org, l’installeur te déploie Plone avec les options par défaut. Tu peux modifier ces options dans les fichiers.cfg puis mettre à jour ton déploiement en lançant la commande bin/buildout A ce moment-là, buildout va télécharger, paramétrer et installer tous les composants logiciels spécifiés dans ses fichiers de config.

Le tutoriel ci-dessus te permet d’installer directement Plone via buildout sans passer par un package de ton OS ni par l’installeur packagé sur plone.org. Il te permet de bien voir toutes les étapes d’installation.

> J’ai déjà python 2.4.4 d’installer et j’ai ajouté quelques packages qui
> pourraient m’être utiles “plone3-site” et “zope-plone3” (à peu près
> similaire j’ai l’impression).

Si tu peux prendre python 2.4.6, ce serait mieux (pas sûr que Plone 3.3.5 marche avec python 2.4.4). Au besoin, tu télécharges la source et tu recompiles simplement.

Mais, pour zope et plone, oublie les package debian et installe plutôt en suivant le tutoriel ci-dessus. En effet, c’est buildout qui s’occupera d’aller chercher les dépendance dont tu as besoin et de les paramétrer comme il faut.

> Je te remercie par avance, pour l’aide que tu pourras m’apporter en
> temps voulu.

Une fois que tu auras réussi l’install d’un plone avec buildout en suivant le tuto, je t’indiquerai comment y ajouter les produits wecena comme dépendances.

> Quoiqu’il en soit, je continue de potasser le tuto plone sur la création
> de bluidout de mon côté…

OK

N’hésite pas à me faire signe au moment où tu coinces.

From Antoine G. to Jean M.

Je reviens vers toi pour te faire un petit point d’avancement sur mon installation de plone 3, à travers le tuto que tu m’as transmis ( http://icp.ge.ch/sem/plone-dip/le-pool-plone-dip/icp-zope-technique/installation-plone3-buildout ).

Dans l’ensemble ça c’est bien passé sauf que les liens des productdistros étaient pour la moitié mort… Je suis allé chercher les fichiers à la mano sur d’autres sites mais je pense que c’est bon de ce côté là.

http://plone4artists.org/products/plone4artistsvideo/releases/1.1/Plone4ArtistsVideo-1.1b1.tar.gz *DEAD*

*NEW –> http://dist.serverzen.com/misc/Plone4ArtistsVideo-1.1b1.tar.gz*

http://downloads.sourceforge.net/julius/ATGoogleVideo-0-6.tar.gz

http://plone.org/products/cmfnotification/releases/2.0/cmfnotification-2-0-rc1-tar.gz *DEAD

NEW –> http://plone.org/products/cmfnotification/releases/2.0/cmfnotification-2-0-tar.gz –> rename to cmfnotification-2-0-rc1-tar.gz*

http://plone.org/products/mailservices/releases/0.5/armailservices-0-5.tgz

http://plone.org/products/ploneldap/releases/1.0/PloneLDAP-bundle-1.0rc3.tar.gz

http://plone4artists.org/products/plone4artistscalendar/releases/1.1/Plone4ArtistsCalendar-1.1b1-plone3.0-bundle.tar.gz *DEAD

NEW –> http://icp.ge.ch/sem/plone-dip/utiliser-plone-efficacement/gerer-mon-plone/produits/produits-infos-admin/produits-fichiers-utiles/Plone4ArtistsCalendar-1.1b1-plone3.0-bundle.tar.gz/at_download/file –> rename to Plone4ArtistsCalendar-1.1b1-plone3.0-bundle.tar.gz

* http://weblion.psu.edu/static/products/cssmanager/cssmanager-0.8.tar.gz

Lors de la première exécution du ./bin/buildout j’ai rencontré pas mal de messages d’erreur. En voici quelques exemples :

SyntaxError: ‘return’ outside function

File “build/bdist.linux-i686/egg/Products/Ploneboard/skins/ploneboard_scripts/comment_redirect_to_conversation.py”,

line 33

return printed

SyntaxError: ‘return’ outside function

File “/home/ploneTest/virtualplone/ploneproject/eggs/tmplebqDf/Products.NuPlone-1.0b3-py2.4.egg/Products/NuPlone/skins/nuplone_templates/livesearch_reply.py”, line 146

return ‘\n’.join(output).encode(site_encoding)

SyntaxError: ‘return’ outside function

Modules/LDAPObject.c:1228: warning: return makes pointer from integer

without a cast

Modules/LDAPObject.c:1185: warning: unused variable ânewpwâ

Modules/LDAPObject.c:1183: warning: unused variable âoldpwâ

Modules/LDAPObject.c:1181: warning: unused variable âuserâ

error: Setup script exited with error: command ‘gcc’ failed with exit status 1

An error occured when trying to install python-ldap 2.3.12. Look above this message for any errors that were output by easy_install.

While:

Installing instance.

Getting distribution for ‘python-ldap>=2.0.6’.

Error: Couldn’t install: python-ldap 2.3.12

Après l’exécution des actions suivantes, j’ai finit par avoir l’exécution d’un buildout complet propre :

aptitude install libldap2-dev

aptitude install libsasl2-dev

aptitude install libssl-dev

cp /var/lib/zope2.10/instance/plone-site/var/Data.fs var/filestorage/

aptitude install python-ldap

Résultat :

./bin/buildout

Updating zope2.

Updating fake eggs

Updating productdistros.

Updating instance.

Updating zopepy.

Malheureusement quand je lance l’instance du serveur ça ne fonctionne pas, il ne trouve pas une librairie :

./bin/instance fg

File “/home/ploneTest/virtualplone/ploneproject/eggs/Plone-3.3.5-py2.4.egg/Products/CMFPlone/browser/ploneview.py”, line 12, in ?

from Products.CMFPlone import utils

File “/home/ploneTest/virtualplone/ploneproject/eggs/Plone-3.3.5-py2.4.egg/Products/CMFPlone/utils.py”, line 6, in ?

from PIL import Image

ImportError: No module named PIL

Voici la liste des paquets python installés de mon côté :

python

python2.4

python2.4-dev

python2.4-minimal

python2.5

python2.5-minimal

python-central

python-docutils

python-imaging

python-imaging-tk

python-ldap

python-minimal

python-newt

python-selinux

python-semanage

python-sepolgen

python-support

python-tk

python-twisted

python-twisted-conch

python-twisted-core

python-twisted-words

Il souhaiterait peut être avoir le package python2.4-imaging, malheureusement il m’installe forcément la dernière version python-imaging… Si tu as des pistes je suis preneur ;-)

Sinon une fois que l’on aura réussi à faire tourner le serveur, je serais intéressé comme tu l’as proposé de procéder à l’installation de wecena.

Pour ma curiosité personnelle et pour nourrir mon amour de plone, pourrais-tu me dire ce qui t’as guidé vers ce CMS ? Car je vois dans l’étude des CMS jointe en PJ ( http://www.waterandstone.com/book/2010-open-source-cms-market-share-report )qui a été faîtes sur l’année 2010, que celui-ci est loin d’être le plus répandu. Par contre je remarque que pas mal de livres sont sorties dessus, il doit avoir certains atouts majeurs…

Je te remercie pour l’aide que tu pourras m’apporter.

From Jean M. to Antoine G.

> Lors de la première exécution du ./bin/buildout j’ai rencontré pas mal
> de messages d’erreur. En voici quelques exemples :
> SyntaxError: ‘return’ outside function
> File
> “build/bdist.linux-i686/egg/Products/Ploneboard/skins/ploneboard_scripts/comment_redirect_to_conversation.py”,
> line 33
> return printed
>
> SyntaxError: ‘return’ outside function
> File
> “/home/ploneTest/virtualplone/ploneproject/eggs/tmplebqDf/Products.NuPlone-1.0b3-py2.4.egg/Products/NuPlone/skins/nuplone_templates/livesearch_reply.py”,
> line 146
> return ‘\n’.join(output).encode(site_encoding)
> SyntaxError: ‘return’ outside function

Tu peux ignorer sans risque les messages “SyntaxError: ‘return’ outside function” comme expliqué ici :
http://plone.org/documentation/error/syntaxerror-return-outside-function

> Modules/LDAPObject.c:1228: warning: return makes pointer from integer
> without a cast
> Modules/LDAPObject.c:1185: warning: unused variable ânewpwâ
> Modules/LDAPObject.c:1183: warning: unused variable âoldpwâ
> Modules/LDAPObject.c:1181: warning: unused variable âuserâ
> error: Setup script exited with error: command ‘gcc’ failed with exit
> status 1
> An error occured when trying to install python-ldap 2.3.12. Look above
> this message for any errors that were output by easy_install.
> While:
> Installing instance.
> Getting distribution for ‘python-ldap>=2.0.6’.
> Error: Couldn’t install: python-ldap 2.3.12
>
> Après l’exécution des actions suivantes, j’ai finit par avoir
> l’exécution d’un buildout complet propre :
> aptitude install libldap2-dev
> aptitude install libsasl2-dev
> aptitude install libssl-dev
> cp /var/lib/zope2.10/instance/plone-site/var/Data.fs var/filestorage/
> aptitude install python-ldap

OK Bravo.

> résultat :
> ./bin/buildout
> Updating zope2.
> Updating fake eggs
> Updating productdistros.
> Updating instance.
> Updating zopepy.

Super.

> Malheureusement quand je lance l’instance du serveur ça ne fonctionne
> pas, il ne trouve pas une librairie :
> ./bin/instance fg
>
> File
> “/home/ploneTest/virtualplone/ploneproject/eggs/Plone-3.3.5-py2.4.egg/Products/CMFPlone/browser/ploneview.py”,
> line 12, in ?
> from Products.CMFPlone import utils
> File
> “/home/ploneTest/virtualplone/ploneproject/eggs/Plone-3.3.5-py2.4.egg/Products/CMFPlone/utils.py”,
> line 6, in ?
> from PIL import Image
> ImportError: No module named PIL
> Il souhaiterait peut être avoir le package python2.4-imaging,
> malheureusement il m’installe forcément la dernière version
> python-imaging…
> Si tu as des pistes je suis preneur ;-)

Chez moi, c’est buildout qui s’occupe d’aller chercher et installer cette bibliothèque.

Pour cela, dans les fichiers .cfg de ton buildout, tu cherches la section [buildout] dans laquelle se trouve la liste de tes dépendances sous la forme d’une variable “eggs = ” avec la liste des dépendances. Dans cette liste, tu ajoutes :

PILwoTK

Si buildout se plaint de ne pas trouver cette bibliothèque, alors tu lui ajoutes quelques URL à partir desquelles il pourra aller fouiller. Ca se passe aussi dans la section [buildout] sous la forme d’une variable find-links :

find-links =
http://dist.plone.org/
http://download.zope.org/ppix/
http://download.zope.org/distribution/
http://effbot.org/downloads/
http://code.google.com/p/html5lib/downloads/list

C’est dans le dépôt http://download.zope.org/distribution/ qu’on trouve PILwoTK (= Python Imaging Library without its TK dependency).

Si ça ne marche pas, tu peux aussi compiler en récupérant le tarball ici : http://www.pythonware.com/products/pil/

> Sinon une fois que l’on aura réussi à faire tourner le serveur, je
> serais intéressé comme tu l’as proposé de procéder à l’installation de
> wecena.

Il faut que je prenne le temps de faire une distribution de mon buildout. Allez hop, c’est fait :

http://svn.gna.org/viewcvs/wecena/trunk/wecena.buildout/

Mais il faudra encore que je partage deux produits d’intégration :

wecena.policy
wecena.theme

Peut-être lundi prochain ?

> Pour ma curiosité personnelle et pour nourrir mon amour de plone,
> pourrais-tu me dire ce qui t’as guidé vers ce CMS ? Car je vois dans
> l’étude des CMS jointe en PJ qui a été faîtes sur l’année 2010, que
> celui-ci est loin d’être le plus répandu. Par contre je remarque que pas
> mal de livres sont sorties dessus, il doit avoir certains atouts majeurs…

Je n’ai pas fait d’analyse comparative complète récemment. J’en ai fait à certains moments dans mon parcours. Ton étude en pièce-jointe est super intéressante (notamment la méthodo qui m’a l’air très bien). Après, il faut voir comment tu l’utilises.

Le premier facteur pour choisir, à mon avis, en tant que développeur, c’est le langage. Développer en python me semble plus productif qu’en Java. Et conceptuellement plus satisfaisant (plus “professionnel” ?) que PHP. Ceci dit c’est une affaire de goût. Et la communauté python compte des développeurs d’un niveau vraiment excellents qui se mettent au service des autres. Donc il y a déjà un facteur un peu irrationnel qui m’a amené vers python et sa communauté. Concrètement, mon parcours en matière de langages de prédilection est le suivant :

  • Turbo Pascal quand j’étais au lycée (jusqu’en prépa en 93)
  • un peu de VB à l’école (94/97) mais surtout du Delphi
  • ensuite, de 98 à 99 je me suis tourné vers Perl car c’était, parmi les langages du libre, celui qui avaient le plus de bibliothèques orientées Internet (et avec une bonne orientation objet)
  • de 99 à 2005, j’ai encadré des équipes qui faisaient de l’ASP, du PHP et un peu de J2EE mais, pendant ce temps j’ai découvert python, plus “propre” et maintenable que Perl mais avec les mêmes avantages (grosse communauté et bibliothèques, à fond dans le Net, agile, dynamic typing, orienté objet) ; et c’est dans la communauté python que j’ai vu apparaître des produits et framework mûrs pour livrer ce que mes équipes ASP/PHP réinventaient de manière artisanale à chaque projet,
  • de 2005 à 2007, pour le boulot, j’ai fait du J2ME, J2SE et J2EE mais, franchement, quelle lourdeur de développer en Java quand on vient de python… j’aurais pu virer ruby (encore plus agile que python mais plus jeune) ou me mettre à PHP qui avait gagné en maturité objet

Donc, pour moi :

  • J2EE = ok mais lourd
  • ruby = ok mais “jeune”
  • Perl = ok mais peu maintenable (plus artistique…)
  • PHP = ok mais une communauté de niveau inégal (beaucoup de temps perdu avec des débutants)
  • Python = ok mais moins populaire

Ensuite, au niveau framework applicatif pour le web, conceptuellement, l’idée de publier des objets m’a séduit dès le début (Zope Object Publishing Environment) alors que le paradigme de l’époque (2000/2005) restait les applis sur mesure sur base relationnelle (LAMP côté libre). C’est quand-même plus confortable, pour développer, d’accéder “nativement” à une persistence objet (base de données objet) plutôt que de gérer des accès à des données relationnelle ou de devoir gérer une surcouche de mapping objet-relationnel.

Si on compare les CMS Web PHP comme Drupal ou Joomla d’une part, et Plone d’autre part, les avantages spécifiques de Plone résident dans sa couche de sécurité et dans son moteur de workflow (qui est essentiel dans la gestion de la sécurité). Il semble que ces aspects sécurité + workflow sont moins bien pris en compte dans Drupal et Joomla que dans Plone. C’est pourquoi Plone a une réputation de meilleur produit pour les besoins professionnels impliquant des règles de sécurité fines (et compliquées) et des workflows spécifiques, avec une gestion des rôles complexes.

Drupal serait plus à son aise pour les besoins communautaires “simples” et “variés” alors que Plone serait plus à son aise pour les besoins professionnels avec des processus métiers complexes. Les produits J2EE couvrent sans doute des besoins encore plus “pro” et des processus métiers encore plus complexes et  nécessitant plus de rigueur, mais au prix d’une lourdeur énorme.

Mais on parle bien de gestion de contenu, là.

A propos de la popularité des CMS, il faut bien voir ce qu’on compare. C’est normal que WordPress (PHP) soit astronomiquement plus populaire que Plone (python) puisqu’il ne fournit que 10% des fonctionnalités d’un Plone. De plus, Plone impose un hébergement spécifique (serveur dédié) alors que WordPress ou Drupal peuvent se satisfaire d’un hébergement partagé. Donc, si tu installes du Plone, c’est que tu as une bonne raison.

Mais si on parle de développement d’applications innovantes et spécifiques, de type crowdsourcing par exemple, alors j’irais regarder du côté de framework comme Django en python.

J’ai aussi l’impression que le développeur python “moyen” est plus à l’aise avec des concepts intéressants de développement que le développeur PHP “moyen”. Il y a plus de choses conceptuellement stimulantes dans la communauté python que PHP.

Par exemple, quelle est la maturité de telle ou telle communauté en matière d’outils et pratiques de Test-Driven Development, etc.

> Je te remercie pour l’aide que tu pourras m’apporter.

De rien.

Je t’ai répondu un peu en vrac ci-dessus alors n’hésite pas à préciser tes questions.

From Antoine G. to Jean M.

Merci pour tes indications précieuses. Tu as débloqué la situation, nous avons maintenant une instance zope/plone qui tourne.

Pour ce qui est du buildout de wecena, j’ai déjà fait un checkout du svn pour récupérer la distribution que tu as faite. Quand je l’exécute j’ai l’erreur suivante :

While:
  Initializing.
Error: The specified download cache:
'/home/jean/Desktop/techno/buildouts/.shared/downloads'
Doesn't exist.

Je pense que je pourrais commenter la partie faisant référence à ce dossier ‘downloads’ en local sur ton serveur car il n’est peut être pas nécessaire mais comme tu le disais il faut encore que je récupère wecena.policy et wecena.theme

Je te remercie pour ton analyse sur le marché des CMS avec en trame de fond les grandes lignes de ton parcours. Tout cela est fort enrichissant et si tu
conçois le développement python/plone à contrario de la lourdeur de Java, j’ai hâte de voire ça ;).

Maintenant que je vais bientôt pouvoir modifier / créer du contenu avec plone, as-tu un livre de chevet à me conseiller ? Je pense déjà regarder la doc du côté du site français de plone : http://plone.org/countries/fr/index_html

J’ai regardé le comparatif que tu m’as envoyé par la suite entre les 4 CMS (wordpress, drupal, joomla et plone), qui est encore un bon point pour plone. D’ailleurs en quoi la sécurité sur plone est-elle mieux assurée ? Est-ce simplement par un meilleur degré de précision sur la gestion des droits utilisateurs ?

From Jean M. to Antoine G.

Le 23/01/2011 03:47, Antoine G.  a écrit :

> Merci pour tes indications précieuses. Tu as débloqué la situation, nous
> avons maintenant une instance zope/plone qui tourne :
>
> http://alterformation.org:8080/

Bravo !

> Pour ce qui est du buildout de wecena, j’ai déjà fait un checkout du svn
> pour récupérer la distribution que tu as faite. Quand je l’exécute j’ai
> l’erreur suivante :
>
> While:
> Initializing.
> Error: The specified download cache:
> /home/jean/Desktop/techno/buildouts/.shared/downloads’
> Doesn’t exist.

Tu dois créer sur ton disque un répertoire dans lequel seront stockés les dépendances au fur et à mesure qu’elles sont téléchargées (cache). Et tu en indiques le chemin dans un fichier de buildout en lieu et place du chemin indiqué dans ce message d’erreur.

> Je pense que je pourrais commenter la partie faisant référence à ce dossier
> ‘downloads’ en local sur ton serveur car il n’est peut être pas nécessaire
> mais comme tu le disais il faut encore que je récupère wecena.policy et
> wecena.theme

C’est juste un cache local. C’est utile surtout si tu installes plusieurs buildout qui partageront le même cache. Si tu commentes cette instruction, buildout utilisera je ne sais plus quel chemin pour y stocker ses téléchargements.

> Maintenant que je vais bientôt pouvoir modifier / créer du contenu avec
> plone, as-tu un livre de chevet à me conseiller ? Je pense déjà regarder la
> doc du côté du site français de plone :
> http://plone.org/countries/fr/index_html

Ce bouquin-ci est très bien pour les techniques utilisés pour le développement dans Plone 3 : http://professional-plone-book.packtpub.com/

> J’ai regardé le comparatif que tu m’as envoyé par la suite entre les 4 CMS
> (wordpress, drupal, joomla et plone), qui est encore un bon point pour
> plone. D’ailleurs en quoi la sécurité sur plone est-elle mieux assurée ?
> Est-ce simplement par un meilleur degré de précision sur la gestion des
> droits utilisateurs ?

C’est l’une des deux raisons. La deuxième raison est plus fondamentale (ce qui en fait la première…) : Plone s’appuie sur la Zope Object DataBase (ZODB). C’est une base objet. Le caractère sécuritaire de cette base objet tient à ce que tout accès à un objet stocké fait l’objet d’un contrôle d’accès très fin et applicatif. Ce n’est pas comme dans le cas classique du développement avec une base relationnelle. Habituellement, avec une base relationnelle, tu as une chaîne de connexion (login + mot de passe) unique utilisée quasiment partout dans ton code. Ton code accède partout comme il veut à toute ta base de données. Au contraire,
avec la ZODB, l’accès à chaque objet se fait sous le contrôle des permissions associées à l’utilisateur qui s’est authentifié. Autrement dit, il ne s’agit d’une base de données par-dessus laquelle on a plaqué une couche de sécurité indépendante mais d’un système d’accès sécurisé aux données qui est inclus dans la base de données (ce qui a pour inconvénient un côté un peu monolithique de cette base).

Donc non seulement le contrôle d’accès est plus fin (d’innombrables permissions qui se combinent les unes aux autres) mais aussi il est plus “profond”.

Mais je te réponds un peu “de mémoire” donc je me trompe peut-être un peu sur les points ci-dessus. Les autres raisons pour lesquels on lit que Zope est sûr :

  • comme ce n’est pas une base SQL, la ZODB n’est pas soumise au risque d’injection SQL qui est une cause fréquente de failles dans les systèmes relationnels,
  • comme Zope est une techno moins populaire, il y a moins d’intérêt pour un pirate à l’étudier (?)
  • comme Plone fournit des fonctionnalités qui plaisent plus aux entreprises qu’aux bricoleurs (workflow, contrôle d’accès poussé), il est plus souvent utilisé dans un contexte professionnel que associatif ou personnel et donc la communauté Plone a une culture de sécurisation d’entreprise qui, en moyenne, est plus stricte et rigoureuse que dans la moyenne des produits alternatifs

A propos de la sécurité dans Zope, tu trouveras plus de détails ici : http://www.zope.org/Documentation/Books/ZDG/current/Security.stx

[ Update : malgré ces arguments, il faut noter qu’une vulnérabilité très grave de Plone vient d’être annoncée et un patch sera révélé mardi prochain. Mais, ces dernières années, je n’ai vu que 2 vulnérabilités significatives annoncées pour Plone. ]

J’ai publié wecena.policy et wecena.theme dans mon dépôt subversion. Tu devrais pouvoir les checkouter et les mettre sous le répertoire src/ de
ton buildout.

Et voila.

From Jean M. to Antoine G.

SVG as an alternative to Flash, here comes bliotux

As a follow-up to my SMIL-animated SVG for accessible textbooks article, here is a copy of the README file of wecena.bliotux. I currently have 4 full-time wecena volunteers currently making accessible textbooks for children with cognitive disabilities (mainly dyspraxia) under the supervision of an INSERM medical research lab and of a dyspraxia-related non-profit organization, Dyspraxique Mais Fantastique. They currently use Didapages, a Flash-powered proprietary authoring tool to make these would-be accessible textbooks. But we are not satisfied by this tool and I wanted to propose an open-standards free software alternative. So I wrote wecena.bliotux as a proof-of-concept of such an alternative technological framework.

Beyond dyspraxia and children with disabilities, I think bliotux may be of some use for any developer looking for an alternative to Flash as a technology to make highly-graphical, ineractive and animated offline or online applications. The source code is available under the wecena subversion repository (until I create a dedicated repository). Here is a full copy of the README file :

wecena.bliotux

This software package is a framework for building web applications having the following buzzwords

  • web
    apps: run in your web browser
  • offline
    apps: no web server, no Internet connection required
  • rich
    applications : highly graphical user interfaces, using SVG
  • animated
    applications : pages can include (interactive) animations using (SMIL-powered) animated SVG templates
  • interactive
    : interaction/behaviour is defined in a simple Javascript file corresponding to a given page
  • with persistence
    of user data and application state : using local storage with persistence engines such as Google Gears (or HTML5 localstorage when it’s mature enough in Firefox)
  • template-based
    : pages sharing a common layout/structure are based on template files
  • document-oriented: a simple data structure in a data.js file defines the data used to populate the corresponding SVG template for any given page
  • free software: distributed under the Affero GPL License (even though I am not 100% sure of the exact meaning of the Affero version for offline applications BTW…)
  • based on open standards: SVG now (Daisy Profile for SMIL+SVG, CSS and WAI-ARIA in the roadmap) rather than based on proprietary technologies such as Microsoft Silverlight or Adobe Flash
  • highly accessible
    even though using JavaScript (see open standards…)
  • as cross-browser
    compatible as possible: apps should run on any web browser as long as they offer some support for SVG and Javascript; and bliotux users should not have to care much about browser compatibily.

The original aim of this package is to build a non-Flash interactive animations management framework so thataccessible
textbooks can be made for children with cognitive disabilities (mainly dyspraxia)
.
But it could be used to produce any set of interactive animations
such as books, websites, interactive animations or I don’t know what.
You imagine.
You experiment.
You tell me what it may be useful for !

The following JavaScript libraries are used

Disclaimer with regards to JavaScript as a programming language :
Ahemm… Javascript was selected because we wanted to have one and only one language to be used both for the making
of bliotux-powered templates and pages and for their execution.
And their execution should not require any
prior installation of software : the web browser should be the only required stuff.
And Javascript seems to be the only open-standards-oriented way to offer rich interactivity to SVG in web browsers.
Too bad.

How to use wecena.bliotux ?

At the moment wecena.bliotux is nothing but a proof-of-concept.
More will come in case the project I’m working on selects this technology
as a viable alternative to the Flash-based proprietary product we are
currently using in order to make accessible textbooks for children
with cognitive disabilities.

Download and install bliotux

It’s in a subversion repository.
There is some subversion documentation available in
case you don’t know how to download software from a subversion repository
. Bliotux is stored
in the wecena repository but it will get its own repository some day.

Create a template

Bliotux pages are based on templates.
Let’s create a first template.

Name your template

Choose a name for your template. In this example,
the name is

simpleOperation

because it is a template page for textbooks
for children learning additions and other simple mathematical operations.

Name a template folder accordingly.
For instance, I have

wecena.bliotux/templates/simpleOperation/

Define the layout of your template

This part is the job of a graphics designer.

The layout of a template is defined by a SVG file.
(Download, install and) use any SVG editor to create such a file.
I personnally use Inkscape, which is free software.

Your SVG template should be named

layout.svg

and
should be stored under the template folder.
Here it goes:

wecena.bliotux/templates/simpleOperation/layout.svg

The next version of Inkscape should allow you to use its new timeline-based animation editor capabilities to add
animation to your template.
At the moment, you will have to have an XML developer edit the source code of your SVG
template and add animation (animated SVG) instructions “by hand” if needed.

Here is a clue about how to possibly accelerate the development of such SVG animations without waiting for the
next version of Inkscape :

  1. Download and install Open Office Impress
  2. Make a (duplicate) sketch of your layout in Impress
  3. Add the desired animation effects to it using the rich set of animation features Impress offers
  4. Save your animated Impress presentation in its native .ODP format
  5. Open this file using an archive handler (such as winzip under windows) :
    Open Office files are nothing but ZIP archives containing XML and graphics
  6. Edit the source code of the main XML file this .ODP archive contains.
  7. Ask your XML developer to copy, paste and adapt the animations instructions therein
    into your

    layout.svg

    file.
    (The animation instructions can easily be located : they use the

    anim:

    namespace).

Define the interactivity of your template

This part is the job of a Javascript developer.

This is the hardest part if you are not a developer.
It should be easy if you have any experience in web development.

In the case of a children textbook for teaching additions and other simple mathematical operations,
we’d like our “simpleOperation” template to display a simplified virtual keyboard with numbers.
When the child clicks on a number, this number is added to a “result” text element in the template layout.
So we need to know how to use an SVG element (the number we want to click on) as an interactive button
which will display some text result as the content of an other SVG element.

The interactivity of your template is first prepared in your

layout.svg

file.
Using Inkscape XML Editor (Ctrl + Shift + X), you add event attributes
to the SVG elements you want to add some interactivity to. This involves accessing
the XML source code of the SVG file, which you should not be afraid of thanks to
Inkscape XML Editor.

For instance, let’s say you have a SVG group of elements which you want to
act as a button. You select this group using Inkscape. You press Ctrl+Shift+X. The
XML Editor opens. There you see the group of elements as a <g … > element.
You then want to add interactivity to this group. You have to add a

onclick

attribute.
The value of this attribute should be “clickButton(evt)”. This means that whenever the
user mouse clicks on this button, a MouseEvent event called “evt” will be fired and
some Javascript function called “clickButton” will have to handle this event so that
something special happens.

Now you have injected some interactivity attributes into the XML source code of
the SVG file of your template. This source code now includes things like this :

<g onclick="clickButton(evt)" ...

Let’s develop this clickButton Javascript function so that you define what should
happen whenever the button is clicked. This definition is written in a Javascript file
you have to name “interaction.js” and which sits under the template folder:

wecena.bliotux/templates/simpleOperation/interaction.js

For instance, this file could contain the code below (see included examples, too, if needed) :

function clickButton(evt){
    alert('You clicked the button !');
    $('.whereResultShouldBeDisplayed', svg.root()).html('Clicked !');
    $('.someSVGElementsWhichShouldBeEmptiedWhenButtonGetsClicked', svg.root()).html('');
    storageSave('.whereResultShouldBeDisplayed', 'Clicked !');
    storageSave('.someSVGElementsWhichShouldBeEmptiedWhenButtonGetsClicked, '');
}

If you are as unfamiliar with Javascript as I am, you need some more explanations here.
What does this function says ?

It says that it takes an input parameter called “evt”. But it won’t use it in this case.

It first displays a popup alert window with a message (‘You clicked…’)

Then it changes the content of the SVG displayed in the web browser. It writes the text ‘Clicked !’ in
every SVG (or HTML BTW) element which has an attribute called “class” (the same attribute which can be used
for CSS files) including the value “whereResultShouldBeDisplayed”.

For instance, let’s say you have this text element in your layout.svg file :

<text
  id="text4790"
  y="386.98224"
  x="454.43787">
  <tspan
    y="386.98224"
    x="454.43787"
    id="tspan4786"
    class="whereResultShoudlBeDisplayed someOtherClass">Not clicked yet.</tspan>
</text>

Then, once the user clicks the button, your interaction.js file will have this text element changed into this :

<text
  id="text4790"
  y="386.98224"
  x="454.43787">
  <tspan
    y="386.98224"
    x="454.43787"
    id="tspan4786"
    class="whereResultShoudlBeDisplayed someOtherClass">Clicked !</tspan>
</text>

Can you see the difference ?

For more information about how Javascript can have the web browser manipulate
the content of the page at runtime, please see jQuery API documentation. Just remember to
apply jQuery selectors to the root of the SVG document (

svg.root()
) and you should be fine.

There is also this call to storageSave in your interactivity function. What does it mean ?


storageSave

is a function defined by bliotux.
It takes 2 input parameters : a key and its value.
It will have this pair of (key, value) made persistent in the local web browser.
Even if the browser (and possibly computer) is closed (shutdown), this (key, value) pair is still available
and can be later retrieved using another bliotux function :

storageLoad(key)
.
Next time the same page is displayed, any SVG element which corresponds to key (as a jQuery selector) will have
its content filled with value.

In this example, storing the text

"Clicked !"

as
the value of the key

.whereResultShouldBeDisplayed

means 2 things:

  1. this text

    "Clicked !"

    can be further retrieved with any Javascript call to

    storageLoad('.whereResultShouldBeDisplayed')
  2. next time this page is displayed using the same web browser, the

    "Clicked !"

    text will be added to all SVG elements which have the

    whereResultShouldBeDisplayed

    class attribute in their source code.

As a result of this, the state of each page can be made persistent
so that when the user returns to a given page he already interacted with
this page displays the exact same info/aspect/behaviour as before.

Now you have your

interaction.js

file which defines the full interactivity of your template document.

Create a page

Creating a page is much easier than creating the template a page is based on.
But it requires writing some (extremely simple) code using any text editor (Windows notepad…).
Any brave user should be enabled to do so.

You have a full bliotux template, including an SVG layout (possibly including animation) and Javascript interactivity.
Now let’s create a page based on this template.

Name the folder with the page name

In this example, let’s name a first page

Sesamath_CP_page-094_exercice-001

along the name of a French free (as in free speech) textbook vendor.
In order to do so, we create this folder:

wecena.bliotux/pages/Sesamath_CP_page-094_exercice-001/

When we want to access this page, we’ll have to direct our web browser to such an URL as

file:///home/jean/wecena.bliotux/index.xhtml?page=Sesamath_CP_page-094_exercice-001

Define the template this page uses

Which template will this page use ?
The answer comes as a Javascript file we have to create:

wecena.bliotux/pages/Sesamath_CP_page-094_exercice-001/data.js

This file contains the declaration of variables describing this page.
The variable called template defines the template to be used for this page:

var template = 'simpleOperation';

Populate the template

The next variable in this

data.js

file define data which will get injected into the template so that
the page is built :

var data = {
  '.pageCentaine':'',
  '.pageDizaine':'9',
  '.pageUnite':'4',
  '.exerciceCentaine':'',
  '.exerciceDizaine':'',
  '.exerciceUnite':'2',
  '.operande1Centaine':'',
  '.operande1Dizaine':'',
  '.operande1Unite':'7',
  '.operateur':'-',
  '.operande2Centaine':'',
  '.operande2Dizaine':'',
  '.operande2Unite':'5',
  '.resultatCentaine':'',
  '.resultatDizaine':'',
  '.resultatUnite':'',
};

This data associative array lists (key, value) pairs which define which content should be injected where.
The key (for instance

.pageCentaine

) is a jQuery selector to be applied to the root of the SVG template.
The value is some SVG code which is to be inserted as the content of any SVG element matching the key.

Rather than using

id

attributes as selectors (

#pageCentaine

), it seems preferable to use

class

attributes (

.pageCentaine

) which carry the meaning (semantics) of the corresponding SVG element and can be reused
several times in the same template (whereas IDs should be unique, I suppose).
Anyway, the SVG template should be edited so that the corresponding

class

attribute are present where needed.

Include some page-specific graphics

Using the mechanism of templates and the data.js file, you may have your SVG template include some areas where
pages could have specific bitmap (JPEG, PNG) files displayed.
This is just the matter of including such a JPEG file in the

layout.svg

file,
giving the corresponding SVG element an appropriate class attribute (using Inkscape XML editor for instance)
and then defining in

data.js

the name of the picture file to insert in this area of your layout for this specific page.

But you can also have given pages include full SVG files.
For instance, the left part of

simpleOperation/layout.svg

is meant to display a funny but didactic illustration
where characters (such as Tux the penguin) invite the child to perform the mathematical operation at hand.
Such an illustration could contain page-specific animations.
Adding an animated GIF file would not be enough.
The full power of SVG for animations may be required.
In such cases, you can define an svgParts variable in the data.js file of the page :

var svgParts = {
  '#illustration': 'illustration.svg'
}

This variable says : “Hey, bliotux, please look at my template
and find the SVG element with

illustration

as the value of its

id

attribute.
Then replace this full SVG element with the first

g

element (SVG group) you will find
in the

illustration.svg

file sitting under this page folder. Thanks.”

That’s it

You can access and test your page at a URL which should look a bit like that (the exact path depends on the folder hierarchy
on your hard drive):

file:///home/jean/wecena.bliotux/index.xhtml?page=Sesamath_CP_page-094_exercice-001

Side note : Now I realize I can’t use doctestjs for this document so it’s pretty useless to me.
It would have been much useful if only I had figured out a way to have some Javascript code generate
a template document in the filesystem during the doctest so that I can further test bliotux on it
using doctestjs. Maybe later…

SMIL-animated SVG for accessible textbooks

Dyspraxia is a serious learning disability for 250.000 children in elementary schools in France. Not that French children are particularly disadvantaged. It just happens that it seems to be a very wide spread kind of disability and the proportion of dyspraxic children should roughly be the same from country to country. In order to overcome this obstacle, the nonprofit organization I currently work for is leading the way toward adapting the ergonomy of existing paper textbooks and helping textbook editors creating the accessible (and digital) textbook of the future. Maybe you’ve heard of any similar initiatives ?

Their first attemps were made using a French e-learning authoring tool called Didapages. Up to version 1.1 it was free for non-commerciale uses. Version 2 is much more commercially oriented. And closed-source. And only runs on Windows. And despite its ease of use for educators and non-IT specialists, it has several drawbacks and limitations, partly due to the technology it uses, Flash, and partly because its developer does not think he can build a sustainable business model using free software licensing. Too bad. I am looking for an alternative solution, as some part of its user community does.

Free software packages such as Xerte, eXe, Scenari, Docebo and others look attractive. But none is the ideal solution : either they are also based on Flash, or their community is almost non-existant and their development may have stopped some time ago. Educators are not developers. And the crowd of educators might be missing a critical mass of developers in order for a very striving free software community to have developped around any elearning authoring tool. The bells and whistles of proprietary products have much more appeal to the average teacher.

From a technology perspective, I had a look at open standards for acessible, animated and interactive contents. W3C, please show me the way. The relevant standards seem to be :

  • HTML 5 for content, with its Javascript-animated “canvas” element for sprite-based animations (for bitmaps graphics) ;
  • SMIL for animated documents and for limited interactivity, possibly also combined/extended with Ecmascript for more interactivity ;
  • CSS for styling, possibly some day with Webkit-like CSS animation but this option does not excite me much ; CSS animation may require Javascript or SMIL
  • SVG for graphics : there is such a thing as SVG Animation, and Ecmascript can be embedded in a SVG file in order to provide more interactivity and to overcome some current interactivity limitation of SMIL ; SVG is for vector graphics but could also embed (and animate) bitmap graphics (used as sprites).

The advantage of SMIL and SMIL-animated SVG over Flash seems to be that SMIL is a declarative technology. This “document” model allows less dependency on scripting and more flexibility through earlier or further transformations (with templating, XSLT or content management engines). This allows the animation and, to a lesser extent, interactivity aspects of educational content to be a native part of the content itself and not to be an afterthought. It facilitate later and looser coupling with further technologies. It allows more ReSTfullness (restafari !). It does not cause cancer. Well, I don’t know. It tastes good. (note to myself : consider discarding this whole paragraph) :)

Flash applets, on the other hand, can be made somewhat accessible but this may not be an easy task for the average Flash developer, and SMIL sounds like a much more accessibility-friendly technology. There even is a DAISY profile for SMIL documents. I should have a deeper look into these profiles.

But interactivity with specific application logic seems to require a bit of scripting anyway, doesn’t it ? Here comes Ecmascript with SMIL, which should probably be limited to a minimum. Can you always provide accessibility-safe fallback mechanisms for a SMIL document if you introduce scripting for interactivity ? I am not sure. I will have to figure this out. Maybe the DAISY SMIL profile tells me more about this.

After a first glance at these standards and being an non-expert in animated contents, it seems to me that there ARE available and mature open standards which cover most of the accessible and digital textbook related concerns. There should be no need to develop any addiction for Flash authoring systems.

But the problem is that these standards are still “emerging”. They were proposed several years ago, are slowly maturing and their support in modern web browsers only starts to become a reality. The most advanced support for SMIL-animated SVG comes with Opera. And is said to be available in Firefox 3.6 as far as I understood. I’ll test this stuff with Opera until Firefox 3.6 comes to ubuntu. The lack of consistent support for SMIL and SVG animation can be overcome with the use of free software SDK or Javascript libraries which take SMIL elements as input and generate equivalent Javascript instructions as output. For instance, the RaphaelJS Javascript library allows browsers to support animated SVG even if such a support is not built-in for them. As far as I understand, the Ample SDK allows SMIL animations to be supported by non SMILable browsers, too.

The main problem is not in web browser support, though. The main problem is that there is almost no (free software) authoring tools for such animation and interactivity technologies. Limsee2 is a code editor/development environment for SMIL (does it support SVG animation ?) but its INRIA authors stopped working on it some time ago. And there seems to be no real community behind it. Limsee3 is not a further version of Limsee 2 (despite the name). It is a WYSIWYG SMIL authoring tool but it does not seem to support SVG animation (does it ?). And it may also probably stop being developed as soon as the governmental subsidies behind the corresponding research project end. Yet another research package soon to be dying on the labs shelves ?

This sends me back to my above observation about the non-existence of a sufficiently-big or proficient-enough community of educators who can use AND develop such advanced authoring tools with accessibility in mind. Too bad…

Madswatter and Ajax animator are very early prototypes for animation authoring environments. There are other free software attempts currently aiming at proposing a proper animation editor: clash/geesas (which is a fork of pencil) and moing… Maybe you’ve heard of other projects ? Inkscape has some plan for introducing SMIL authoring capabilities. There even is a mockup of the user interface for the timeline-based authoring of animations. This is work in progress. Well, maybe this is more than just a work on blueprints : the Inkscape roadmap mentions simple and limited animation authoring as a feature for their next release (version 0.48) ! The 0.49 version should focus on much more support for animated SVG. Exciting ! This topic is hot right now. Itches are starting to be scratched a lot !

That being said, I realize I already have a tool for authoring animations. It’s Open Office Impress. And the Impress wiki tells me that its animation are based on SMIL ! When I have a look at the xml file saved by Impress (inside its ODP zipped archive), I can indeed see SMIL element names and attribute names mixed with Open Office specific elements and attributes, even though the resulting document may not be SMIL compliant, strictly speaking. A limited effort (XLST or a custom extension) may allow to produce real SMIL documents.

Instead of using elearning-specific authoring tools (think Xerte, eXe, …), what if futur editing software for educational contents were tools I (or any educator) already have on my desk : Inkscape for the creation of bits of animated graphics and/or Open Office Impress for the layout and animation of the overall animated document? In Inkscape, the “properties” window of any object even reveals some event fields for Ecmascript/Javascript instructions (onclick, onmouseover, etc.). Too bad Impress can’t properly import SVG content. But maybe this is not required. In the end, e-learning specific tools would be required anyway for the packaging of the resulting animated and interactive content into Learning Management Systems such as Moodle. Such content packages would need to be made SCORM or AICC compatible so that they expose their navigational and educational structure to these platforms via a standard API. I read the SCORM is not ideal as such an API from an accessibility perspective because it heavily relies on Javascript (it is a Javascript API). But does the use of a scripting language always prevent accessibility ? I don’t know. SCORM may be nice for portability from LMS to LMS. But so nice for accessibility.

At the moment, I feel like the ideal authoring chain of tools for educational content / textbooks would be as follows :

  1. Inkscape in order to create the graphism, layout and animation of individual educational “applets” : cross words, coloring books, simulations, geometry tools, … the result being saved as an animated (and partial SMIL-interactivity) SVG file with event-hooks being defined so that we can go to the next step
  2. an ECMAscript code editor (I am not into this emacs thing… Eclipse anyone ?) in order to transform this animated SVG file into an animated AND interactive SVG piece of content
  3. Open Office Impress in order to create the layout, structure and general content of your course/manual/textbook chapter/whatever, inserting the SVG file and adding further animations as well as individual multimedia items (sound clips, videos, hyperlinks), the result being saved as a SMIL/HTML document
  4. More scripting edition of this document if needed (but would it be needed at this stage ? I can’t tell)
  5. CSS styling would be made ready for the document at this stage or earlier (can Open Office make any use of existing CSS stylesheets or would it always mix them into its own content format ?)
  6. a SCORM packager such as Reload Editor would import this content and allow the author to specify the SCORM relevant bits of information, the result being saved as a Moodle-ready package
  7. Your favority Moodle-like LMS platform would serve the content to users, possibly running on their laptop in an offline fashion

This whole chain of tools would probably benefit from being powered by a web content management system (Plone ? Drupal ?) so that the assembly line is smoother and allows widespread collaboration, with workflows, access control and so on. No need to get stuck back to the Dreamweaver era of the I-am-waiting-for-the-Dreamweaver-guy-to-update-my-textbook.

Now it’s your turn. What do you think ?

La téléconférence du geek

Une grande SSII a enfin signé avec l’une des associations qui bénéficie du wecena. Le communiqué de presse est prêt. L’appel au volontariat destiné aux 4000 salarié est prêt à être envoyé. Il ne me manquait plus qu’une chose pour faire nickel : avoir une solution de téléconférence gratuite pour accueillir les volontaires à distance, répondre aux questions des personnes intéressées (managers, volontaires en puissance, etc.). J’ai donc dû mettre au point un système de téléconférence spécial geek dont j’espère bientôt faire la démo. Voici mes notes de travail, prenez-en soin !

Sous ubuntu 9.04, j’ai installé webcamstudio, téléchargeable via http://www.ws4gl.org/, installable depuis un dépôt ou bien depuis les sources, facile à compiler avec NetBeans sous Ubuntu (installer le paquet NetBeans). Webcamstudio est un logiciel en Java qui permet de créer une webcam virtuelle qui peut capture l’image de votre bureau, des animations, du texte, un canal IRC, une vidéo Youtube, le flux video d’une vraie webcam branchée sur le PC…
Mettre la sortie en 320×240 pour éviter tout risque d’incompatibilité avec le site qui va diffuser la vidéo (ustream.tv par exemple).
WCS créé un device “Video loopback” de type “Video 4 Linux” (et pas Video 4 Linux 2).
Lancer l’utilitaire gstreamer-properties pour vérifier que ubuntu arrive à lire cette webcam et informe ubuntu de la webcam par défaut. Video / entrée / Video for linux 1, device = Video Loopback 1. Faire un test pour vérifier que ubuntu détecte bien la webcam virtuelle créée par webcamstudio.
Aller sur ustream.tv et y créer son compte utilisateur.
Sur le site de webcamstudio, il y a une explication pour savoir comment faire en sorte que flashplayer accepte d’utiliser comme il se doit la webcam virtuelle : fait aller sur un site macromedia.com pour y régler les paramètres de sécurité du flashplayer de votre navigateur : “toujours autoriser www.ustream.tv, cdn1.ustream.tv” (et aussi quantserve. com ?).
Puis se logger dans ustream et aller dans l’interface de broadcast. Y sélectionner son périphérique vidéo (video loopback) et son périphérique audio (“linux microphone”).
Ensuite, il y a un certain nombre de réglages à faire pour avoir du son diffusé. On lance donc l’utilitaire “pavucontrol” de pulseaudio sur ubuntu (à partir de la 9.04). Cet utilitaire permet de :

  • régler chaque périphérique audio d’entrée (les sources) et de sortie (les sinks)
  • régler aussi les “moniteurs” qui sont des genres de périphériques virtuels créés par pulseaudio ; notamment, pulseaudio créée un “moniteur” associé à votre périphérique de sortie son (vos hauts-parleurs) ; ce moniteur se comporte comme une sorte de microphone virtuel qui serait branché sur vos hauts-parleurs et vous permet de capturer tout son émis par votre PC pour pouvoir l’enregistrer à nouveau ou le diffuser en streaming par exemple,
  • relier chaque logiciel qui produit du son (lecture) ou en capture (enregistrement) à un périphérique de sortie son de son choix, y compris aux “moniteurs” ; en l’occurence avec une seule carte son en sortie (pas de casque audio USB), vous n’avez qu’un seul choix pour les logiciels de lecture. Par contre, pour les logiciels de capture, vous pouvez choisir de capturer ce qui entre dans le microphone ou bien ce qui entre dans le moniteur de la sortie de votre carte son, à savoir ce qui sort de la carte son… Vous suivez ? J’explique…

En pratique, le périphérique de sortie par défaut, c’est la sortie carte son (un casque dans mon cas). Et le périphérique d’entrée par défaut, c’est mon microphone du casque audio. Je mets en sourdine le microphone de ma webcam.
De plus, le site ustream.tv qui diffuse votre video et votre son est utilisé via votre navigateur web, firefox dans mon cas. Firefox apparaît donc dans pavucontrol de 2 manières :

  1. en tant que logiciel de lecture (c’est le son joué par firefox), je le relie à la sortie de ma carte son mais je le mets en sourdine le temps de mon broadcast (sinon, ça pourrait faire de l’écho).
  2. mais aussi et surtout en tant que logiciel d’enregistrement (c’est l’applet flash de ustream.tv qui capture mon son) que je relie au moniteur pulseaudio de ma carte son de manière à enregistrer tout le son qui sort de ma carte et pas seulement ma voix captée par mon microphone mais aussi les MP3 joués en local, les conversations téléphoniques via un softphone, etc.

Le problème, c’est que ma voix qui entre dans le microphone ne ressort pas dans la sortie de ma carte son. Sinon, ça me ferait de l’écho dans les oreilles. Donc ma voix n’est plus capturée par l’applet flash de firefox/ustream puisque celle-ci est maintenant associée au moniteur de la sortie son.
Pour contourner ce problème, on créé une loopback audio grâce à 2 utilitaires de pulseaudio. Ouvrez une fenêtre de terminal et tapez-y parec | pacat.
parec apparaît dans pavucontrol en tant que logiciel de capture son à qui on demande de capter l’entrée son du microphone. Il envoie ce son (ma voix) vers pacat via un pipe. pacat, lui, apparaît dans pavucontrol comme logiciel de lecture. Et il envoie forcément sa sortie (ma voix) vers la carte son. Donc ya de l’écho. Tant pis, on diminue le son dans le casque (physiquement), si ça gêne.
Mais on obtient le résultat recherché : à savoir permettre à firefox/ustream de capturer non seulement ma voix mais également tout ce qui sort des logiciels audio du PC.
Maintenant, l’audioconférence. Pour cela, j’utilise un softphone, en l’occurence Twinkle (ou parfois Ekiga). J’ai un compte SIP chez un opérateur de voix sur IP. Je recommande ippi.fr, c’est gratuit. Ippi.fr offre (gratuitement via SIP) des salles d’audioconférence. J’appelle donc avec twinkle cette salle d’audioconférence. Twinkle apparaît dans pavucontrol à la fois comme logiciel de lecture et comme logiciel d’enregistrement. En tant que logiciel d’enregistrement, je lui demande simplement d’enregistrer ma voix. En tant que logiciel de lecture, je lui demande juste de faire son travail, c’est-à-dire d’envoyer le son produit par les interlocuteurs de l’audioconférence vers la sortie de ma carte son, de manière à ce qu’il puisse être capté, comme ma voix à travers le moniteur pulseaudio de cette sortie, sur lequel est branché la capture audio de firefox/ustream.
Et voila.
Les inconvénients actuels :

  • ça bouffe un max de CPU tout ça : twinkle, webcamstudio, firefox avec l’applet flash de ustream, pulseaudio en plus. C’est tout juste tenable sur mon laptop dual core 2×1,2 GHz. On peut rendre les choses vivables grâce à un ajustement des priorités via “sudo htop”. pulseaudio tourne d’office à haute priorité (-11). Je mets manuellement twinkle à -2 (prioritaire). Et firefox à -1 et on laisse webcamstudio à 0. Toutes les applis non prioritaires (applets Gnome par exemple) peuvent être passées à 1 (non prioritaires). Faute de ce type de réglages, l’audioconférence peut être ingérable ou la capture sur ustream de trop mauvaise qualité (y compris des pertes de trames entraînant une désynchronisation de la voix et de l’image si on demande à ustream d’enregistrer le broadcast pour la postérité). Autre possibilité de contournement : faire tourner le tout sur un PC plus puissant. Autre possibilité de contournement, faire une conférence main libre avec un téléphone normal. On évite ainsi le softphone mais le son capté le sera via un microphone près du téléphone.
  • j’entends de l’écho quand je parle (à cause de parec|pacat). Possibilités de contournement : est-ce qu’utiliser le module-loopback de pulseaudio règlerait ce problème (pacmd load-module module-loopback) ? a priori non. Autre possibilité de contournement : le téléphone main libre à côté du PC. Autre possibilité : baisser le son du casque quand je parle et le remonter quand j’ai fini de parler. Autre possibilité : trouver un moyen pour dire à pulseaudio qu’un logiciel de capture devrait combiner 2 périphériques d’entrées au lieu d’un seul : le microphone qui capte ma voix et le moniteur de la sortie son qui ne capterait plus ma voix (on se passerait de parec|pacat).
  • ma webcam est une caméra sur batterie, il faut que je pense à la brancher sur secteur sinon… elle se vide.
  • il faudrait voir si on ne peut pas diffuser une meilleure qualité d’image (640×480) et ce que ça implique en terme de CPU.

Au final, je me dis qu’il faut que je remette la main sur mon téléphone SIP matériel (Gigaset de Siemens) et ça simplifera mon problème de CPU. Mais ça ne donne pas une solution “portable”…

How to record VoIP calls from your PC ?

Beyond having low and flat rates, beyond allowing mobility without a mobile phone, voice-over-IP has another advantage : it allows calls to be recorded. Here is how to proceed (assuming you are geeky enough…).

For instance, this week, I could not physically join an interesting meeting between French NGO leaders and IT professionnals considering how to best volunteer for these NGOs. So I gave the organizer of the meeting a VoIP phone (Siemens Gigaset) and asked him to call the Asterisk-powered SIP call conference system our nonprofit has (thank you Fred and JML  for this !). It allowed me to join the meeting as a distant caller and… to record a big MP3 file of the 3-hours long discussion.

For recording this voice-over-IP conference, here is my setup. I was calling from a linux PC, 2GB of RAM and a great free software SIP-compatible softphone called Twinkle (greater than Ekiga IMHO). My voice-over-IP provider was our Asterisk server. I could have used any other free SIP provider, such as ippi. Ippi is great and I am a happy customer of their service.

I was also running the Wireshark packet sniffer as root. After the call, I had to post-process the VoIP packets Wireshark captured. Wireshark decoded them and extracted the audio content of the conversation. Then I used Audacity to normalize, level and compress the audio and to save it as a big podcast-ready MP3 file.

The tricky parts :

– The Siemens Gigaset can’t (easily ?) be configured to call an SIP address which does not have the same domain as the SIP account it is using. For instance, if the audioconference system is at sip:conference@sipprovider.org then you’d better configure the phone to use a sip:mygigaset@sipprovider.org account rather than a sip:mygigaset@anotherprovider.org Too bad… :(

– You should warn the participants they are being recorded. Not only can this be required by your local laws but it also gives them another incentive to think of speaking close to the phone which is recording them in the meeting room.

– During the conversation, people in the meeting room would sometimes forget the presence of the phone and speak too far from its microphone. Hence I had to say “Can’t hear you !” from time to time and participants would take the phone in their hand as if it were a microphone. Local participants (in the meeting room) would even call the distant participants “the phone” and say “Hello, phone, how are you ?” and stuff like that. It was a bit as if the phone was yet another participant speakers had to take into their hand in order to be heard and recorded. Quite funny. Having the phone close to the speaker is also a matter of discipline and habit for the meeting organizer.

– Distant participants like me would use the “mute” feature of  their local (soft-) phone so that they can’t be heard when not talking, so that there is less background noise in the conversation.

– I would have preferred to have at least one local participant available in a text-based chatroom (think IRC channel) or at least in some instant-messaging system. This would have allowed me to remind the phone has to be kept close to the current speaker and stuff like that without having to loudly say “Can’t hear you”. Unfortunately, the only IM-available participant was the main organizer who quickly forgot his screen and keyboard so that he could focus on the discussion going on.

– A 3-hours call required a lot of RAM for wireshark, even though the captured packets were being saved on the hard-drive ; when post-processing the packets, I had to split the session into 4 smaller parts so that wireshark would not crash when doing its audio extraction.

– When post-processing one of these smaller packet captures, wireshark would sometimes not detect the accurate nature of the packets : instead of seeing them as Real-Time Protocol (RTP) packets which they indeed were, it detected them a “OICQ” packets. So I had to force wireshark into considering them as RTP files (using its “Decode…” command).

– In order to have wireshark decode and save an audio file from the RTP streams, the command to be used is “RTP / Show all streams” from its “Statistics” menu. Then you use the “Analyze” button and then the “Save Payload” button. I had to select the “.raw” (vs. “.au”) format for the audio file because of the codec used by the VoIP phones.

– When saving the audio file, I decided to save distinct files for the forward (my voice, sent from my softphone to the audioconference service) and reversed stream (the meeting voices, sent from the audioconference service to my softphone). This allows distinct and finer audio postprocessing (the audio levels were different).

– In audacity, I chose to first normalize the audio tracks, then level them (it adjusts the audio level when the speaker changes or talks to far from the phone) then audio-compress them a bit. I would then merge the parts and tracks into a single mono audio file. Stereo does not make much sense in the case of a many-participants call but can be useful if you record a 2-participants conversation.

That’s it. Now I have to finish the audio-postprocessing of my MP3 and find some place on the Net where to upload it for the participants. What do you think ? Do you have some tricks to share on this topic ?

1 million de salles d’attentes… pour la recherche scientifique

Hier soir, je tchattais avec mon pote Yann. Comme à notre habitude, on échange nos idées farfelues du moment. Cette fois-ci, c’est mon tour. Qu’en pensez-vous ?

(22:37:13) Sig: si les 1 million de salle d’attente qui existent dans le monde accueillaient chacune un vieux PC à bout de souffle pour faire des calculs pour la recherche scientifique
(22:37:35) Sig: alors on pourrait accélérer la découverte de remèdes contre les maladies type Alzheimer et une trentaine d’autres maladies.
(22:37:45) Yann: ok
(22:37:50) Sig: Rien qu’en France, il y a environ 100.000 salles d’attente
(22:38:15) Yann: et j’ai deja 1 PC a bout de souffle, pu ke 99 999 a trouver ;)
(22:38:21) Sig: Or j’ai 40 vieux PC stockés chez moi et chez ma grand-mère ainsi qu’un système logiciel pour les contrôler à distance via le Net
(22:38:33) Yann: Ok je capitule !
(22:38:34) Sig: j’ai pas d’écran mais yen a pas besoin pour la recherche scientifique
(22:38:42) Sig: :)
(22:38:49) Sig: et l’idée de salle d’attente, c’est de dire :
(22:39:06) Sig: vous voyez ce PC et la pile de tracts posée dessus, prenez-en un :
(22:39:36) Yann: de tract ?
(22:39:38) Sig: ” Emmenez moi (le tract) chez un autre médecin/dentiste/salle d’attente pour qu’il puisse demander, lui aussi, son PC de recherche médical en allant sur http://…”
(22:39:50) Yann: ok
(22:39:51) Sig: l’idée est d’utiliser la salle d’attente comme lieu de viralité
(22:40:02) Yann: ca marche bien ca deja !!!!!!
(22:40:08) Sig: oui (rhumes…)
(22:40:10) Sig: :)
(22:40:13) Yann: oui ;)
(22:40:28) Yann: (on n’a deja notre theme publicitaire ;o)  )
(22:40:41) Sig: ensuite, les tracts peuvent inviter les gens à donner des vieux PC au projet ou à participer à la distribution
(22:40:52) Sig: de vieux PC récupérés vers les nouvelles salels d’attente en demande.
(22:40:59) Yann: ok
(22:41:29) Sig: Enfin, dernier point, lorsque on peut récupérer des écrans, j’ajoute un logiciel sur le PC :
(22:41:50) Sig: pour que les gens qui passent en moyenne 35 minutes dans la salle d’attente mettent leur cerveau au service de la recherche scientifique
(22:42:03) Yann: ???
(22:42:18) Yann: je ne suis plus la !
(22:42:19) Sig: sur des projets sur le principe de galaxyzoo.org, clickworkers, foldit, stardust@home (tu iras voir galaxyzoo.org c’est super joli)
(22:42:27) Sig: le principe de galaxyzoo :
(22:42:48) Sig: on te montre une photo d’une galaxie jamais vue par l’être humain (tu es le premier car elle a été prise en photo par un téléscope robotisé)
(22:42:52) Sig: et tu as 2 boutons :
(22:43:02) Sig: bouton 1 : “elle tourne dans le sens des agiuilles d’une montre”
(22:43:08) Sig: bouton 2 : “elle tourne dans l’autre sens”
(22:43:30) Sig: des millions de clics permettent au labo d’astronomie d’Oxford de mieux connaître la création de l’univers
(22:43:38) Yann: comment ?
(22:43:42) Sig: ya pas mal d’autres projets qui fleurissent actuellement dans d’autres domaines scientifiques sur ce principe
(22:43:44) Sig: comment :
(22:43:54) Sig: certaines théories sur l’expansion de l’univers disent :
(22:44:08) Sig: “il devrait y avoir 50% de galaxies qui tournent comme-ci et 50% comme ça”
(22:44:20) Sig: et d’autres disent “non, 51% dans ce sens, et 49% dans l’autre sens”
(22:44:43) Sig: ce projet permet d’invalider les théories fausses et d’avancer dans notre compréhension du passé et de l’avenir du cosmos… c bo. :)
(22:44:52) Sig: il suffisait de compter :)
(22:45:05) Yann: oui, bien vu :)
(22:45:10) Yann: Mes comments :
(22:45:14) Sig: oui
(22:45:22) Yann: l’idee me plait !
(22:45:26) Sig: ok
(22:45:33) Yann: les pb ke j’anticipe :
(22:45:53) Yann: PC en reseau ds cabinet medical = pb deontologie potentiel
(22:46:03) Yann: du moins y aura des gens a penser ca
(22:46:29) Yann: ensuite, l’installation  = tres time consuming !!!!!!
(22:46:32) Sig: ok j’y avais pas pensé mais c’est une bonne remarque
(22:46:36) Sig: (pour le pb de sécurité/déontologie)
(22:46:45) Yann: et la maintenance aussi !
(22:47:00) Sig: pour l’install et la maintenance, non aucun pb :
(22:47:04) Sig: 100% automatisé !
(22:47:13) Yann: j’te sens ds l’exces d’optimisme la non ?
(22:47:24) Sig: et si le pb est trop grave pour être traité en automatique, il faut que quelqu’un (bénévole) vienne remplacer le PC par un autre
(22:47:47) Sig: non non j’utilise un logiciel fait pour gérer de manière automatique des milliers de PC dans des centres de recherche.
(22:47:56) Yann: tu ne va pas automatiser le pc qu’il faut physiquement deposer au sol ds 100 000 salles d’attente !!!!
(22:48:14) Sig: non le transport et le branchement restent à la charge des bénévoles
(22:48:26) Yann: ne néglige pas cette contrainte, elle estr forte….mais….
(22:48:29) Sig: oui
(22:48:39) Yann: C ds les obstacvle qu’on trouves d’autres idees
(22:49:07) Yann: Ca me parait hyper lourd a gerer (rien que l’aspect physique et maintenance sur place qd necessaire)
(22:49:14) Yann: par contre ca me donne 1 idee
(22:49:23) Yann: C tellement lourd comme contrainte
(22:49:33) Yann: qu’il faut 1 partenaire serieux !
(22:49:38) Yann: style la secu !!!!
(22:49:52) Yann: t’imagine en terme d’image !!!!!
(22:49:57) Sig: mmm… la sécu… pkoi pa
(22:50:12) Yann: ou autre organisme, type mutuelles…
(22:50:21) Yann: ou pfizer ou Rhone poulenc….
(22:50:28) Yann: le privé du cabinet medical koi !
(22:50:38) Sig: oui je pensais aux labos pharmaceutiques
(22:50:46) Yann: bingo
(22:50:54) Sig: dans le cadre d’un mécénat alors ?
(22:51:02) Yann: sauf que eux vont vouloir mettre le nez ds le soft
(22:51:05) Yann: (oui)
(22:51:12) Yann: afficher de la pub etc
(22:51:21) Yann: et la on a un pb de deontologie potentiel !
(22:51:30) Sig: ils ne peuvent pas afficher de la pub pour des produits c’est interdit dans les salles d’attente
(22:51:31) Yann: mais ca me parait faisable
(22:51:39) Yann: pffffff
(22:51:55) Sig: mais ils peuvent afficher de la communication sur leur entreprise (pas commercial mais “communication institutionnelle”)
(22:51:55) Yann: les pub de cigarettes aussi C interdit ds les kfé !
(22:52:10) Yann: C pareil !
(22:52:25) Sig: pas du point de vue du conseil de l’ordre, je pense.
(22:52:29) Yann: C juste le credit d’impot qui change ;)
(22:52:34) Sig: oui
(22:52:55) Yann: je suis ok avec toi : C moralement acceptable pr des mecs ds des bureaux
(22:53:25) Yann: mais C pareil, ds le meme but : vendre a la prolo de la salle d’attente du doliprane plutot que du generique paracetamol !
(22:53:32) Sig: yes
(22:53:46) Yann: je n’aime pas ca, mais j’suis lucide !
(22:54:03) Yann: bref : l’idee me parait bonne des le depart ;)
(22:54:12) Sig: ok :)
(22:54:31) Yann: autre “pb” : il faut travailler au moins 1 an a tps plein pr lancer un truc pareil !
(22:54:39) Yann: t’as 1 an devant toi toi ?
(22:54:49) Sig: je vois pas le besoin  de travailler un an dessus
(22:55:00) Sig: “yaka” trouver un médecin prêt à expérimenter
(22:55:07) Yann: les contacts, ajuster les idées etc ???
(22:55:36) Yann: C un projet a part entiere ton truc la !
(22:55:48) Yann: limite faut monter 1 asso
(22:55:57) Yann: dc statut a rediger etc
(22:56:07) Yann: j’arrive meme pas a faire mes cpte !!!
(22:56:08) Sig: fo voir comment ça se goupille mais, à la limite, ça pourrait se faire “à la mode open source”, avec peu de moyens et sans structure juridique
(22:56:20) Yann: la le pro C toi !
(22:56:24) Yann: je te fais confiance !
(22:56:31) Sig: en pratique, la question qui compte, c’est :
(22:57:02) Sig: est-ce que tu connais un heureux propriétaire de salle d’attente que tu pourrais convaincre d’accueillir un PC connecté à son ADSL pour la recherche scientifique ?
(22:57:19) Yann: reponse immediate : non !
(22:57:32) Yann: mais suis optimiste : j’peux trouver oui ;)
(22:57:38) Sig: :)
(22:57:59) Sig: de mon côté, je vais en causer avec notre pédiatre qui est très impliqué dans des assos
(22:58:16) Yann: j’vois mon doc fin mars (en pcipe si j’y pense)
(22:58:17) Sig: et sinon, j’essaierai avec une copine orthophoniste
(22:58:38) Yann: et moi je garde ca en tete, on connais tous forcement des docs !
(22:58:51) Sig: en attendant, fo que je te laisse pour aller contrôler la fin d’installation automatique de 2 PC qui tournent depuis tout à l’heure dans ma cuisine
(22:59:03) Yann: j’crois que la maman du copain de ma soeur est pediatre
(22:59:11) Sig: eh eh :)
(22:59:19) Sig: nous vivons dans un monde de salles d’attente !
(22:59:53) Yann: “si la maison du bonheur existait, la plus grande piece serait la salle d’attente”
(22:59:58) Yann: de PasDeMoi
(23:00:02) Sig: ok
(23:01:05) Yann: allé a +
(23:01:13) Sig: a+

Qu’en pensez-vous ? Vous connaissez une salle d’attente accueillante pour un de mes vieux PC ?

Le code du wecena est libre

“Vive le wecena libre !” comme qui dirait l’autre. Ce petit message pour signaler à ceux que cela intèresse que j’ai libéré le code qui me permet de faire tourner wecena.com. En d’autres termes, ce logiciel libre est désormais distribué (publiquement) sous licence GNU Affero General Public License v.3.

Le code en question constitue une suite de produits d’extension pour le système de gestion de contenu Web Plone. Certains de ces produits sont spécifiques au fonctionnement du wecena (les produits wecena_core et wecena_integration). Certains autres sont plus génériques et peuvent avoir leur utilité hors wecena. Je pense notamment à wecena_dynamicroles pour améliorer la flexibilité du système de sécurité de Plone et à wecena_ldapuser pour synchroniser de manière bidirectionnelle les utilisateurs Plone avec les entrées d’un annuaire LDAP.

Votre expertise python/Zope/Plone est plus que bienvenue si vous voulez vous amuser avec ces produits et filer un coup de main au passage !

How to get visual performance profiles from plone doctests ?

I am developping a couple of Plone 3.x products. They have some tests, including a huge functional doctest which takes a long time to run (about a couple of hours !) but covers some of my most interesting use cases. I wanted to use these tests in order to get some insights about possible performance bottlenecks and other optimization hot points in my code. The result of my effort was a very nice visual chart showing these bottlenecks and hotpoints.

[update: added another visualization package, see at the end of the post]

Here is how I had to proceed (note that I am more of a foolish and coward hacker than an expert and I decline any responsibility on the consequences of following my howto !) :

1. Give your python a suitable profiler

Plone 3.x requires zope 2.10 which in turn requires python 2.4. More recent versions are not supported AFAICS. Problem: python2.4 does not have a reliable performance profiling module. Its “hotshot” module is both slow (when loading statistics) and badly bugged : it crashes when you have it load some of the profiles it can generate. You have to add a better profiler to your python environment, namely cProfile (which is shipped with python 2.5).

I am a terrible sysadmin and I don’t really understand (and care about) how python manages its pathes and accesses its libraries. So I did this :

  1. download and unzip the source tarball of python 2.5 so that you get cProfile source code
  2. locate relevant files referring to lsprof (the old name of cProfile), using a grep -R lsprof * on the source directory
  3. I personnally located the following files (I leave cProfile test files apart) : Lib/cProfile.py Modules/_lsprof.c and Modules/rotatingtree.* (.c and .h)
  4. download and unzip the source tarball of python 2.4
  5. copy the located cProfile files from their python 2.5 location to the proper dirs into the source code of your fresh python 2.4
  6. update python 2.4 ‘s setup.py file so that the line below is added just after the hoshot one : exts.append( Extension(‘_lsprof’, [‘_lsprof.c’, ‘rotatingtree.c’]) )
  7. did I mention I am so bad at hacking things that I don’t even provide a patch for the operations above ?
  8. compile python 2.4 using a ./configure then make

At this point, you must have an executable python interpreter version 2.4 which includes cProfile. You can check by launching this python and trying a import cProfile which should not fail.

I replaced my system python2.4 by then doing a sudo make altinstall but I also had to manually tweak my system files so that this new python2.4 gets properly called (I am using ubuntu 8.10 intrepid, BTW) :

cd /usr/bin

sudo mv ./python2.4 ./python2.4.5

sudo ln -s /usr/local/bin/python2.4

Now, a plain command line call to python2.4 should give you an interpreter prompt which lets you import cProfile if you dare. I suffered some colateral damage here : the python prompt lost its ability to have previous lines copied at the prompt by pressing the Up/Down arrows. And I had to re-install reportlab from the source (some of my products depend on pisa which depends on reportlab). Anyone knows how to restore this Up/Down arrow capability ?

2. Recreate your buildout using this new python version

So that zope gets recompiled using your new python version :

rm -Rf parts bin develop-eggs

python2.4 bootstrap.py

bin/buildout

3. Patch zope testrunner so that it supports cProfile instead of only supporting hotshot

I got a bit confused because my buildout contains 2 zope testrunners. It took me some time to figure out which was which : the one which is used by the zope instance your buildout creates is the one which is shipped with zope 2.10 and is located at parts/zope2/lib/python/zope/testing/. The other one I have is in the zope.testing egg. I don’t know how and why I got such an egg. Anyway, this egg supports both hotshot and cProfile whereas zope 2.10 testrunner doesn’t. So I hacked the weaker/older zope 2.10 testrunner with some inspiration from zope.testing so that cProfile can be used when running tests. Here is the diff you can use for enhancing  parts/zope2/lib/python/zope/testing/testrunner.py. Oops, left version is the modified one, right version is the original one.

38,69d37
< before_tests_hooks = []
< after_tests_hooks = []
< available_profilers = {}
<
< try:
<     import cProfile
<     import pstats
< except ImportError:
<     pass
< else:
<     class CProfiler(object):
<         “””cProfiler”””
<         def __init__(self, filepath):
<             self.filepath = filepath
<             self.profiler = cProfile.Profile()
<             self.enable = self.profiler.enable
<             self.disable = self.profiler.disable
<
<         def finish(self):
<             self.profiler.dump_stats(self.filepath)
<
<         def loadStats(self, prof_glob):
<             stats = None
<             for file_name in glob.glob(prof_glob):
<                 if stats is None:
<                     stats = pstats.Stats(file_name)
<                 else:
<                     stats.add(file_name)
<             return stats
<
<     available_profilers[‘cProfile’] = CProfiler
<
75,98c43
<     pass
< else:
<     class HotshotProfiler(object):
<         “””hotshot interface”””
<
<         def __init__(self, filepath):
<             self.profiler = hotshot.Profile(filepath)
<             self.enable = self.profiler.start
<             self.disable = self.profiler.stop
<
<         def finish(self):
<             self.profiler.finish()
<
<         def loadStats(self, prof_glob):
<             stats = None
<             for file_name in glob.glob(prof_glob):
<                 loaded = hotshot.stats.load(file_name)
<                 if stats is None:
<                     stats = loaded
<                 else:
<                     stats.add(loaded)
<             return stats
<
<     available_profilers[‘hotshot’] = HotshotProfiler

>     hotshot = None
288c233
<     if len(available_profilers) == 0 and options.profile:

>     if hotshot is None and options.profile:
320,324c265,266
<         if available_profilers.has_key(‘cProfile’): prof = available_profilers[‘cProfile’](file_path)
<         else: prof = available_profilers[‘hotshot’](file_path)
<         before_tests_hooks.append(prof.enable)
<         after_tests_hooks.append(prof.disable)
<

>         prof = hotshot.Profile(file_path)
>         prof.start()
335c277,278
<             prof.finish()

>             prof.stop()
>             prof.close()
342c285,292
<         stats=prof.loadStats(prof_glob)

>         stats = None
>         for file_name in glob.glob(prof_glob):
>             loaded = hotshot.stats.load(file_name)
>             if stats is None:
>                 stats = loaded
>             else:
>                 stats.add(loaded)
>
459d408
<                 [hook() for hook in before_tests_hooks]
461d409
<                 [hook() for hook in after_tests_hooks]
656,659c604
<     [hook() for hook in before_tests_hooks]
<     results = run_tests(options, tests, layer_name, failures, errors)
<     [hook() for hook in after_tests_hooks]
<     return results

>     return run_tests(options, tests, layer_name, failures, errors)

Oh, BTW, this diff also lets you filter out the profiling of the setup and teardown steps of your tests which are of poor value compared to actual tests. Thanks to Daniel Nouri for this.

At this point, you should have given your zope instance the capability of profiling tests using cProfile. You can check it by asking for a debug prompt from zope : bin/instance debug The prompt you get should allow you to safely import cProfile

4. Profile your test

Say you have a Products called Products.DearProduct with some tests. Profile them :

bin/instance test -s Products.DearProduct –profile

At this point, you should get a tests_profile.*.prof file saved in the current dir. It contains the performance profile cProfile generated, using the pstats format. You can manually load and analyze this data. Or have a limited GUI show you what it’s like. Or you can go for the nicer, more insightful version which follows.

5. Visualize and analyze the performance profile you generated

Thanks to Ingeniweb folks, I heard of gprof2dot and xdot. Download them (the scripts, not the folks). Use them to generate and display a very nice graph :

chmod 744 gprof2dot.py

chmod 744 xdot.py

./gprof2dot.py -f pstats -o profile.dot tests_profile.*.prof

./xdot.py profile.dot

Note the * you may replace with the ID of the profile generated above. Or you can use the fancy but dangerous one-liner below which runs the tests,  generates the profile, generates the corresponding graph, displays the results of tests and displays the graph for analysis :

rm -f tests_profile.*.prof && rm -f profile.pstats && rm -f profile.dot && bin/single-instance test -s Products.MyDearProduct –profile > /tmp/test.txt ; ./gprof2dot.py -f pstats -o profile.dot tests_profile.*.prof && less /tmp/test.txt ; ./xdot.py profile.dot

At this point, you should be starring at nice colored graph which represent the flow of your tests and the method which may be performance bottlenecks. And you should be hoping that it was worth the effort.

[Here starts the update]

After some contemplation moment, I tried to analyze the graph of my tests and did not feel extremely happy with this graph visualization. It indeed shows me that the slowlyness of functional doctest is mostly due to the testing framework (zope.testbrowser, etc.). This slowlyness “hides” the optimization opportunities of my code. And I don’t know how to exclude some products from the being profiled or from being present in the profile stats (I would have liked to filter out zope.testbrowser and other Plone-specific things). But, all hope is not lost, here comes kcachegrind:

sudo apt-get install kcachegrind

sudo easy-install pyprof2calltree

pyprof2calltree -o output.calltree.stats -i tests_profile.*.prof -k

Using kcachegrind with the help of pyprof2calltree, I was able to focus on my product methods and identify those methods which deserve some caching. Added some @memoize decorators and reran the profiled tests so that I could enjoy the performance improvement… Happy I am, happy thou shalt be.

What do you think ?

Wow, 10 millions de dollar pour rendre le monde meilleur

C’est Noël ? C’est la surenchère ? Nokia promet 150 000 dollars dans un concours d’idées d’applications innovantes et solidaires. Et voilà-t-y pas que Google en promet 10 millions, pour réaliser les cinq de vos projets qui sont les plus susceptibles de rendre le monde meilleur. De quoi être époustouflifié même quand on sait que la X-Prize foundation envisage des concours d’innovations avec des récompenses allant de 100 millions à 1 milliard de dollars ! Google est d’ailleurs un membre actif des concours de cette fondation.

Allez, avec un peu de chances, j’aurai peut-être le plaisir d’offrir un lot de consolation à quelques innovateurs solidaires français ? Quelques équivalents-temps plein d’ingénieurs et consultants informaticiens, gratuitement, pour votre projet d’intérêt général, ça vous tente ?

Au passage, je remercie Monsieur D., de Chambéry d’Albertville, qui a bien voulu me signaler cette initiative de Google que j’avais loupée. Monsieur D. est parfois timide alors il m’avait contacté par mail plutôt que via un commentaire sur ce blog. ;-)

150 000 dollars pour l’innovation technologique à vocation sociale ou environnementale

Nokia lance un concours pour développeurs d’applications solidaires pour téléphones portables. 150 000 dollars seront offerts aux développeurs des applications mobiles qui seront les plus susceptibles de rendre le monde meilleur. N’oublions pas que les populations des pays du tiers-monde sont bien plus équipées en téléphones portables qu’en ordinateur, par exemple.

Alors, forcément, ça me donne envie d’en rajouter une couche. C’est pourquoi je propose aux candidats français de ce concours de bénéficier du wecena pour développer leur projet : je vous propose gratuitement les compétences de nombreux ingénieurs et consultants, au titre d’une forme innovante de mécénat, le wecena. Les conditions à remplir sont détaillées dans mon appel à projet. Dans le cas d’un concours comme celui de Nokia, cela veut avant tout dire qu’il faut déclarer en préfecture une association d’intérêt général en France pour porter le projet, ou s’associer à une association existante.

via WorldChanging

Rapid prototyping with microcontrollers ?

I have no clue about micro-electronics and embedded systems. I am a Web application architect and developer, working with very high-level programming languages such as Python (or Perl or Java). I hardly remember assembly language from my childhood experiments with an Apple IIe and almost never touched C or C++. But I have been dreaming lately of rapid-prototyping some advanced non-Web application in an embedded system using my programming skills. So I thought I could share bits of my ignorance here. Please bear with me and give me some hints in order for me to best get out of darkness ! :)

Microcontrollers are now gaining capabilities that are comparable to microprocessors of early personal computers. The two most popular microcontroller (uC) series are Microchip PIC uCs and Atmel AVR uCs. For instance the PIC18F25J10-I/SO costs around 3 or 5 euros per unit at Radio Spares (I am in France: think RS in the UK or Allied Electronics in the USA). It has the following characteristics: 40 MHz, RS-232 capabilities (serial port), a “C compiler optimized architecture”, 48 kB of program memory (Flash mem) and around 4 or 5 kB of data memory (SRAM + EEPROM).

There are nice peripherals available, too. For instance this Texas Instrument CC2500 2.4GHz RF data transceiver (= transmitter + receiver) at around 2 to 3 euros per unit or current sensors approximately at the same price. In fact, periphals possibilities are limitless…

For free software hackers, there was a linux version for such chips : uCLinux. But is it still an active project ? I think I read that the comon linux kernel now includes everything that is required for it to run in embedded sytems. What about GNU utilities ? I know there are things like busybox on bigger but still embedded processors (phones). Anything equivalent on microcontrollers ?

There are simulators that will… let you pretend your desktop computer has a microcontroller inside, or sort of. :)

There is at least one C library for microcontrollers. C is considered as a “high-level programming language” in the embeddeds world ! That is to say that assembly language has been the norm. Some higher-levels languages can be used with microcontrollers, including some exotic-to-me Pascal-like languages like XPlo or PMP or Java-like but living dead things like Virgil and… what about my beloved Python ?

There are at least 2 projects aiming at allowing Python-programming on microcontrollers. pyastra is a “Python assembler translator” that can be used with some PIC12, PIC14 and PIC16 uCs. But it looks dead. Pymite looks sexier but not much more active :

PyMite is a flyweight Python interpreter written from scratch to execute on 8-bit and larger microcontrollers with resources as limited as 64 KiB of program memory (flash) and 4 KiB of RAM. PyMite supports a subset of the Python 2.5 syntax and can execute a subset of the Python 2.5 bytecodes. PyMite can also be compiled, tested and executed on a desktop computer.

At the moment, it seems like Python programming on microcontrollers is a dead end. Nothing worth investing time and efforts unless you want to also have to maintain a Python compiler… Same may be true for Java, not mentioning Perl. In fact, it seems to me that the object-oriented crowds are too far from microcontrollers applications to generate enough interest in initiatives such as Pymite, at the moment. Oh, and I am knowingly ignoring C++ which I did not investigate, having no experience in C++.

So what is left in terms of (open source) programming languages that would be of higher level than C ? The best guess I can make is Great Cow Basic, which is a free software Basic (procedural) language. Example programs look nice to me. It has been active recently. And it supports most of the chips I would consider experimenting with.

Next steps for me, I guess, would be to pick a PIC simulator and an IDE for Great Cow Basic (any eclipse plugin ?). Then I will probably have to figure out how a Basic program can be executed on a simulated PIC. And how a PIC simulator can be useful without all of the electronics that would surround it in any real setup. I’ll see that. When I have time to pursue my investigations and experiments in this micro-world.

And piclist is a great site for beginners.

Alitheia core de SQO-OSS pour mesurer la qualité du code

Un projet de recherche financé par la commission européenne (SQO-OSS) distribue, sous licence open source bien entendu, un logiciel qui analyse la qualité du code source d’un logiciel. Ce logiciel s’appelle Alitheia.

Alitheia parcourt des dépôts de code du style subversion/CVS (et notamment ceux de sourceforge). Des plugins fournissent des mesures du code (nombre de lignes de code, nombre de lignes de commentaires, etc.). Des modules d’Alitheia effectuent des statistiques à partir de ces mesures afin d’estimer la qualité globale du produit analysé. Alitheia se présente soit sous forme d’une application Web, soit, bientôt, sous forme d’un plugin pour Eclipse.

L’intérêt pratique d’Alitheia me semble actuellement limité: il y a peu de mesures disponibles dans la version de démo en ligne, la version pour Eclipse n’est pas encore disponible, les mesures sont effectuées au niveau de chaque fichier source et ne semblent pas encore agrégées au niveau du projet en lui-même (on peut savoir combien de lignes de commentaires il y a dans tel fichier mais pas dans le projet complet). Actuellement, la fonction la plus amusante semble être la mesure de la “productivité” de chaque développeur.

A terme, ce logiciel me semble très prometteur. Son intérêt dépendra essentiellement de la richesse des plugins de mesure disponibles, de l’existence d’un site public permettant de comparer entre eux les projets phare de sourceforge et tigris par exemple, et de la capacité d’Alitheia à produire des indicateurs agrégés significatifs. En ce qui concerne les plugins de mesure, j’espère qu’on va non seulement avoir des plugins mesurant des caractéristiques du code mais aussi (voire même surtout), des plugins mesurant la qualité de la communauté du projet: fréquence et délai des réponses sur les mailing lists, fréquentation du canal IRC de support, nombre et qualité des plugins et modules additionnels, durée de vie d’une version, etc. A suivre !

(via Le Monde Informatique)

Appel à projets informatiques d’intérêt général

Vous connaissez un projet informatique qui pourrait contribuer à rendre le monde meilleur ? A sauver la planète ? A créer une innovation Internet d’utilité publique ? Ou juste à faciliter la vie de votre association ? A faire avancer une grande cause ou une toute petite ? A faire avancer la science ? Alors répondez à cet appel car je pense pouvoir booster ce projet en recrutant pour lui des mécènes informatiques.

En effet, dans le cadre de ma nouvelle entreprise, je propose mes services professionnels à tout projet informatique d’intérêt général: je fournis (à coût zéro, cf plus bas) mes compétences en tant que directeur de projets informatiques innovants ainsi que l’accès aux compétences de très nombreux autres ingénieurs informaticiens, sur leur temps de travail. Vous voulez des compétences d’ingénieurs informaticiens pour rendre le monde meilleur ? En voila !

Notez que je ne place, a priori, aucune limitation de thème ou de domaine : lutte contre la pauvreté, recherche scientifique, défense de l’environnement, santé, handicap, protection de l’enfance, etc. peu importe du moment que ce projet va vraiment dans le sens de l’intérêt général et de l’utilité publique (cf. ci-dessous).

Les conditions à remplir

Pour que mon entreprise puisse intervenir, votre projet informatique doit absolument :

  • être “d’intérêt général”, c’est-à-dire être porté par un organisme ayant le droit, en France, d’émettre des reçus fiscaux en échange des dons reçus (mécénat)
  • ne pas être un tout petit projet: il doit nécessiter, de la part des mécènes, au moins 1 ingénieur à temps plein
  • être porté par une équipe déjà active : je peux fournir entre 2 fois et 5 fois le temps que vous passez déjà sur le projet, en tant que bénévoles ou salariés ; si vous ne travaillez pas déjà sur le projet, je ne peux rien faire (0 fois 2 égal 0 !)
  • être un projet qui en vaut vraiment la peine: avoir un véritable impact social, direct ou indirect, une utilité clairement mesurable et motivante, répondre à un défi de société à petite ou à grande échelle, être source, levier ou moteur de changement pour la société…
  • ne pas nécessiter de présence physique importante en dehors de la région parisienne (je démarre petit et près de chez moi, même si je suis un adepte du travail à distance et des “conf call”), bref être plutôt localisé près de Paris

Qu’est-ce qu’un projet informatique d’intérêt général ?

Un projet informatique est d’intérêt général si il est porté par un organisme bénéficiant du régime fiscal français du mécénat. Ah, ah… mystère, qu’est-ce que c’est que ce truc ? La loi française d’août 2003 sur le mécénat reste mal connue mais elle représente une source de revenus importante pour les organismes d’intérêt général. Plusieurs types d’organismes répondent à ce critère. Pour faire simple, il peut s’agir d’une association loi 1901 :

  • à but non lucratif : elle ne reverse pas de TVA, ne paye pas d’impôts sur les sociétés, a des administrateurs et un bureau bénévoles et désintéressés, ne vient pas concurrencer des entreprises commerciales ou alors elle le fait à des prix beaucoup plus bas que le marché et principalement pour un public défavorisé et sans “pratiques commerciales” (publicité, …) ; demandez l’avis d’un comptable si besoin
  • et dont l’objet est à caractère philanthropique, éducatif, social, humanitaire, sportif, familial, culturel, artistique, environnemental, culturel, littéraire, scientifique…
  • et dont les activités ne bénéficient pas à un cercle restreint de personnes (contrairement aux syndicats ou aux associations d’anciens élèves d’une école par exemple …)

Au besoin, une association loi 1901 peut être facilement créée pour porter ce projet (statuts et déclaration en préfecture) et réunir les conditions de l’intérêt général. Il n’y a pas de condition d’ancienneté ni de taille de l’association. Il n’y a pas non plus forcément besoin d’obtenir un agrément administratif (comme ce serait le cas pour les associations “reconnues d’utilité publique”, ce qui est une reconnaissance très difficile à obtenir de nos jours).

Pour en savoir plus sur la notion d’intérêt général, je vous invite à consulter le site mécénat du ministère de la culture ainsi que les explications de l’Association pour le Développement du Mécénat Industriel et Commercial (ADMICAL).

Comment je peux aider, en pratique ?

Si vous consacrez déjà du temps à votre projet, je peux donc démultiplier cet effort.

Exemple: avec 4 autres bénévoles, vous consacrez au moins, chacun, une journée par semaine à votre projet (soit un équivalent temps plein, 5 jours de travail par semaine), alors je peux vous fournir, en complément, l’équivalent de 2 ingénieurs à temps plein (10 jours de travail par semaine), voire plus si votre projet est très simple à gérer.

Cette aide prendra la forme de:

  • un accompagnement permanent par mon entreprise : au moins une demi-journée d’assistance et de conseil par semaine, en fonction du volume de votre projet ; plus un service de représentation et de suivi de votre projet auprès des entreprises mécènes,
  • des interventions individuelles d’un grand nombre (50, 100, 200…?) de professionnels de l’informatique, ingénieurs, techniciens ou consultants, pour des durées variables et parfois courtes (par exemple une semaine), sur leur temps de travail,
  • la possibilité de renforcer votre équipe bénévole par les contributions ultérieures de certains de ces intervenants sur leur temps libre (constitution éventuelle d’une communauté à la mode open source si votre projet s’y prête)
  • l’accès à un système d’information sécurisé sur le Web pour gérer votre projet, vos intervenants, vos relations avec les mécènes et automatiser la gestion de toute la paperasse administrative qui va avec (contrats, convention de mécénat, reçus fiscaux, …)

Comment ça marche ?

Je créé actuellement une entreprise à vocation sociale dont l’objectif est de fournir aux innovateurs sociaux les mêmes moyens informatiques que ceux dont disposent les entreprises les plus modernes. Mon activité s’appuie sur le mécénat de sociétés de services en informatique (SSII) qui s’engagent dans des démarches de “développement durable” (ou, plus exactement, de “responsabilité sociale de l’entreprise”). Elles souhaitent faire du mécénat de compétences en informatique par mon intermédiaire : faire don du temps de travail de leurs ingénieurs et consultants sous la forme d’une prestation de service gratuite gérée via le Web. J’appelle ça “faire du wecena” (Wecena, c’est le nom de ma boîte !).

Le financement de cette aide est indirectement assuré à 100% par l’Etat français, grâce à la loi sur le mécénat des entreprises. En effet, l’Etat accorde une réduction d’impôts importante à toute entreprise qui décide d’aider concrètement un organisme d’intérêt général (don d’argent, don en nature, don de compétences et temps de travail…). Les SSII mécènes que je rencontre sont prêtes à se lancer dans l’aventure en proposant à leurs ingénieurs de faire avancer votre projet pendant ces périodes de temps que l’on appelle l'”inter-contrat” (ou intercontrat ou “période de stand-by” ou …) : il s’agit de ces périodes de quelques jours à quelques mois qui commencent lorsque l’ingénieur termine un projet pour un client et n’est pas encore affecté à un autre projet pour un nouveau client.

Cela impose une contrainte importante dans la gestion de votre projet: les ingénieurs réalisant la prestation de service vont se relayer à un rythme très rapide, certains ne seront présents que 48H tandis que d’autres seront disponibles 2 ou 3 mois dans l’année. La durée moyenne d’intervention individuelle se situe quelque part entre une semaine et un mois (selon le métier de l’intervenant et l’état du marché de l’informatique, et aussi selon la politique du mécène). C’est le rôle de mon entreprise que de vous aider à gérer cette contrainte. Notez que cette contrainte a également quelques avantages : si votre projet est suffisament simple et “découpable” en petites tâches (à l’aide de méthodes et d’outils de gestion adaptées, que je vous fournis), vous aurez ainsi l’occasion de proposer votre cause à une multitude d’intervenants que vous pourrez recruter en autant de bénévoles potentiels une fois leur mission de wecena terminée. C’est par exemple le cas de projets portant sur de l’initiation à l’informatique, de l’animation d’atelier informatique auprès de personnes défavorisées, d’interventions multiples d’installation de PC ou de réseau local… Pour des projets plus complexes (développement, conseil, …), votre implication est plus importante et le wecena ne peut pas représenter plus de 2 fois le temps que vous y consacrez déjà.

Quelques exemples de projet

Pour vous aider à vous faire une idée du type de projet qui peuvent bénéficier du wecena, voici quelques exemples de projets que j’ai déjà présenté à des mécènes :

  • conception et réalisation d’un logiciel innovant pour faciliter l’utilisation du clavier et de la souris par des personnes ayant un handicap moteur
  • amélioration de l’infrastructure informatique d’une ONG travaillant dans la lutte contre l’exclusion: remplacement d’un parc de postes de travail, interventions d’administration système sur des serveurs de fichiers et d’application, …
  • déploiement d’un progiciel de reporting financier sur des prestations de services en mode projet pour une association recevant d’importantes subventions publiques
  • refonte d’applicatifs Web pour la gestion documentaire, la gestion des relations et contacts et la gestion des adhésions pour une association Internet dans le domaine de la famille et de la protection de l’enfance
  • création d’un blog par un écrivain public d’une ONG franco-africaine pour sensibiliser des étudiants français au problématiques du développement Nord-Sud
  • assistance à la webisation d’un système de gestion d’établissements de santé pour une association du secteur sanitaire et social
  • initiations informatiques et formation aux logiciels internes pour des bénévoles retraités d’une association humanitaire

Ce ne sont que quelques exemples pour vous donner le ton. Aucun de ces projets n’a encore démarré.

Avertissement

Mon entreprise en est encore à une phase de démarrage et d’expérimentation. Je ne peux actuellement vous garantir ni que votre projet en particulier sera sélectionné par un mécène (les projets les plus solides et les plus ambitieux auront plus de chances bien entendu) ni même de pouvoir démarrer mon accompagnement tout de suite. En effet, l’aide que je peux vous apporter est en soi un projet (créer une entreprise…) : j’y crois énormément puisque j’ai quitté mon employeur précédent pour me lancer dans cette aventure, et j’y consacre tout mon temps et mes compétences. Mais, ceci dit, démarrer ce genre d’entreprise sociale innovante prend du temps et représente aussi une part de risque, d’incertitude, bref d’aventure… Le premier projet que j’accompagnerai pourrait démarrer fin 2008 (si les étoiles s’alignent comme prévu) ou au plus tard début 2009 (si j’ai moins de chance). Les mécènes que je rencontre sont déjà sur le pied de guerre et ont déjà commencé à examiner les projets informatiques que je leur présente. Certains ont déjà exprimé leur préférence et se mettent en ordre de bataille… En croisant les doigts, j’espère qu’un premier projet pourrait démarrer peu après la rentrée scolaire 2008.

Pour participer à l’aventure…

Vous connaissez une équipe qui porte un projet informatique d’intérêt général et a besoin de temps d’informaticiens pour aller plus loin et plus vite ? Faites-lui suivre l’adresse de cet article !

Votre projet répond aux conditions présentées ci-dessus ?  Pour vous en assurer, posez la question via un commentaire ci-dessous ou contactez-moi directement par email à l’adresse suivante: projets (chez) wecena (point) com ou bien encore à mon adresse de blogueur: sig (chez) akasig (point) org. Le site Web de mon entreprise ne devrait pas ouvrir ses portes avant le démarrage du premier projet. En attendant, c’est ici que ça se passe. Vous avez des conseils à me donner, des avis ou des contacts à partager ou des suggestions à faire ? Ils seront bienvenus: je vous invite également à utiliser la fonction commentaires de ce blog.