graphical blog 2

Ça ne devrait poser moins de problème sur les autres versions de Linux, mais Ubuntu qui utilise sa propre interface, Unity et qui a décider au moment le plus adéquat de ne le mettre que via le support 3d, risque de se retrouver avec une surcharge de support considérable.

Il est possible depuis longtemps d’avoir plusieurs cartes graphiques fonctionnant ensemble, mais depuis 1 ou 2 ans, des nouvelles technologies, propriétaires, développés par les différents constructeurs sont apparues. Mais voila elles sont devenue la norme sur les ordinateurs portables compatibles IBM PC ou intel cet été.

Concurrence et incompatibilités vs coopération et normes

Comme d’habitude dans le monde des technologies Intel et compatible IBM-PC donc, la concurrence prime sur la collaboration, chaque constructeur de carte graphique à décidé qu’il serait mieux de développer sa propre technologie dans son coin, sans se concerter et sans norme commune, résultat, ça fait perdre du temps et de à tout le monde, des constructeurs, aux utilisateurs en passant par les développeurs et administrateurs système.
* Le coût des cartes mère décuple pour supporter les technologies ATI, nVidia et Intel, comme tout le monde veut comme il est souhaitable pouvoir fonctionner avec les trois normes. Et ça augmente les e-déchets dans le cas des personnes ne trouvant pas de solution.
* Le coût du développement des pilotes augmente ; les constructeur sont obligé de faire des pilotes spécifique pour chaque systèmes, plus tous les cas de cartes mères et de combinaison de matériel qui est également tout récent et donc plein d’autres problèmes. Et les développeurs tiers qui veulent ne pas être bloqués dans les contraintes stupides de ces constructeurs également.
* Les administrateurs systèmes se retrouve avec ces nouvelles incohérences à gérer et d’avantage de chance d’avoir des problèmes d’incompatibilité.

C’est donc ce qui c’est passé hier avec la mise à jour d’un Ubuntu 12.04 vers un Ubuntu 12.10 d’un ami qui avait eu la mauvaise idée d’acheter du matériel trop récent. Au passage, on a pas réussi à comprendre comment Booter sur carte SD : Via lecteur interne pas vu dans le bios et lorsque on branche le lecteur de carte SD externe l’ordinateur fige (le bios fige immédiatement). Asus (un constructeur basé à Taïwan) est pourtant une bonne référence pour le matériel, ils fabriquent les cartes mères parmi les plus fiables, pour eux même et notamment leurs serveurs, mais aussi pour Apple, DeLL et pas mal d’autres.

Carnet d’adresses Thunderbird

Donc, on fait la mise à jour tranquillement tout en regardant d’autres problèmes système mineurs, dont l’importation du carnet d’adresse dans Thunderbird qui est aussi un problème amusant.
* Thunderbird utilise un fichier nommé .thunderbird/XXXXXXXX.default/abook.adb (ou XXXXXXXX est une suite de 8 lettres et chiffres au hasard) pour conserver le carnet d’adresse
* Comme a de l’humour, il peut importer pleins de format, mais pas celui-ci.
* Il faut donc, via l’interface, exporter le carnet actuel au format de son choix, remplacer le abook.adb actuel par l’ancien, puis réimporter le carnet puis exporter de nouveau au cas où ça redevient nécessaire.
l’impossibilité d’importer les carnet d’adresse Thunderbird depuis les fichiers d’une ancienne configuration

Problème et résolution

Lorsque l’installation s’est terminée, on a redémarré, et s’est retrouvé une fois l’identifiant passé, sans environnement de bureau…. Et oui, le double bon chois des constructeurs (technos non standard) + d’Ubuntu, passer coûte que coûte par l’interface 3d, sachant que de nombreux utilisateurs ont des problèmes aléatoires avec les pilotes à donné ça. Donc, là, si on ne connaît rien, on ne sait pas qu’on peut lancer un terminal via ctrl+alt+t ou passer à un des six terminaux texte via ctrl+alt+f1 à f6. On voit un écran avec uniquement la possibilité de modifier le fond.

La technologie qui pose problème étant dans ce cas Optimus (combinaison Intel + nVidia) et la solution, Bumblebee. Pour référence, la solution (en anglais) (Bumblebee sur Ubuntu et autres Linux)

Donc en quatres lignes :

sudo add-apt-repository ppa:bumblebee/stable
sudo add-apt-repository ppa:ubuntu-x-swat/x-updates
sudo apt-get update
sudo apt-get install bumblebee bumblebee-nvidia

Puis un petit redémarrage propre.

Au passage, cet ordinateur ayant un pavé numérique, il y a un problème de verrouillage du pavé numérique avec lightDM, il suffit de suivre ce didacticiel pour résoudre le problème.

La coopération entre la carte mère, les cartes filles et le système se passaient bien mieux et était automatique sur Amiga et pas mal d’autres systèmes il y a 15 ans.

Espérons que dans le monde ARM ou tout semble d’avantage basé sur des normes et de la coopération, et ou ça devient de plus en plus la norme dans le domaine des applications (au moins web) on ne tombe pas dans le même genre de pièges.

Mesa, l’OpenGL libre

En mettant à jour récemment Chromium (la version libre de chrome) sous Ubuntu, je me suis retrouvé avec la version 20 qui supporte enfin WebGL, auparavant, seul Firefox me permettait d’utiliser WebGL. Comme j’utilise le pilote libre Mesa et le processeur graphique (GPU) intégré Intel HD 3000 intégré APU (non commercial pour les SoC mal finis de technologie x86), il y a pour le moment des limitations. Mesa est en retrait des autres pilotes au niveau de la compatibilité OpenGL et OpenGL ES (à l’origine à destination de l’embarqué, ES=Embedded System, signifiant système embarqué).

Dans les versions 7.x la compatibilité OpenGL 2.x était présente.

En Mesa 8.0 sorti le 9 février 2012, on atteignait à peu près la compatibilité OpenGL 3.0, globalement stabilisé en mai après avec la 8.0.3, la 8.0.4 finissant la stabilisation en juillet 2012. En Mesa 9.0 (quasi stable) qui devrait sortir officiellement ce mois ci (septembre 2012) ou en début de mois prochain, on atteint la compatibilité OpenGL 3.1 et presque complète 3.2 et 3.3 avec des bouts d’OpenGL 4.x. Sur la tronc de développement, des bouts d’OpenGL ES 3 commencent également à être implémentés, une évolution d’OpenGL ES reprenant les améliorations d’OpenGL 3 et 4. On a toujours des gros bugs niveaux textures (notamment entre mode textures compressées et non compressées avec le simulateur de vol libre Flightgear) et reconnaissance sur différentes applications (un patch publié aujourd’hui résoudra peut être ce problème ?).

Depuis environ un an ça avance donc beaucoup plus vite, mais il y a encore du retard à rattraper, j’estime au pifomètre (avec une grosse marge d’erreur), en voyant les évolutions, qu’il y en a encore pour environ un an ou un peu plus pour rattraper le retard.

Textures compressées

La mémoire graphique utilisé par le processeurs graphiques (GPU) étant toujours finie et donc limitée, on a intérêt à compresser les textures afin de gagner de la place et d’éviter de transférer les grosses textures depuis la mémoire vive de l’ordinateur, tache longue, d’autant plus que cela ralentie le transfert des données fondamentales, coordonnées des objets, rotation, transformations etc…. et que pour le GPU, la décompression de ces textures est un calcul plutôt léger voir négligeable. Le Taïwanais S3 à mis au point il y a quelques années cette technique et le format de texture compressé DDS (DirectDraw Surface). C’est devenu un standard de fait, mais le logiciel est breveté, obligeant dans les pays ayant eu la mauvaise idée d’autoriser le brevet logiciel (notamment États-Unis d’Amérique et Japon, on y échappe pour le moment en Europe) à en limiter l’utilisation, ralentissant ainsi les progrès techniques. Heureusement, la norme OpenGL 4.x introduit une méthode non-brevetée de compression et compatible.

Voici un exemple de textures compressées, si cela ne fonctionne pas chez vous pour le moment, lisez le reste de l’article :
http://media.tojicode.com/webgl-samples/dds.html

WebGL

WebGL est un standard de représentation 3D dans les pages web au format HTML5, basé sur le standard OpenGL ES 2.0, lui permettant d’être adaptable sur le matériel embarqué, comme les tablettes ou téléphones mobiles. Il y a déjà eu différents essais de normes qui ont eu un succès très limité. Mais aujourd’hui WebGL est relativement mature et supporté par tous les navigateur répandus (Firefox, Chrome et Chromium, Opéra, Safari, …), à l’exception, comme d’habitude, de Microsoft Internet Explorer. Il le supportera probablement, comme à son habitude avec les standards, sans doute plus ou moins bien d’ici 1 ou 2 ans. On y est maintenant habitué et il perds, pour cela jour après jour des parts de marché. Il avait 75 % de part de marché il y a quelques années, et est encore 2e navigateur derrière Chromium (27 %), avec environ 23 % selon les statistiques d’août 2012 de Wikipédia, ce qui est encore trop, suivi par Firefox avec 18 %). Wikipédia étant le 5e site le plus visité au monde, cela donne une bonne idée de la répartition des navigateurs.

Google a également crée Google Chrome Frame qui permet d’utiliser du vrai HTML5 avec Internet Explorer.

WebGL à l’avantage d’être un standard ouvert et libre (sans contraintes d’utilisation), et d’être quasiment similaire à OpenGL ES, OpenGL étant le premier et principal standard de 3d, utilisé par 99% des téléphones et autres matériel, la majorité des consoles de jeux et les ordinateurs (Windows utilise également Direct3D, qui est un peu plus lent et plutôt fermé).

Mozilla Firefox et Google Chromium

Firefox un navigateur ouvert et relativement libre (restriction au niveau du nom ayant poussé à des dérivés IceWeasel et autres), dérivé de Mozilla, lui même dérivé de Netscape fût pendant longtemps le principal navigateur web. détrôné par IE pendant quelques années sous Windows et maintenant par Google Chrome plus généralement.

Google Chrome est le navigateur fermé de Google (qui refile, comme Apple et Microsoft) toutes vos infos confidentiels aux services secrets des États-Unis d’Amérique et a quelques autres sociétés contre un peu d’argent. Google Chromium est quand à lui une version ouverte et libre.

Mozilla Firefox comme Google Chromium ont tous deux pleins d’outils espions (ou fonctionnalités) Google intégrées, Dans Firefox, il suffit de taper dans la barre de navigation : about:config pour nettoyer la majorité, et de désactiver Google dans les moteurs de recherche (et remplacer par une occurrence de votre choix de Seeks) (local ou un des nombreux nœuds existants. Sous Chromium c’est encore plus dur, mais on peut aussi supprimer les moteurs Google et limiter les dégâts.

Sortons du thème du contre-espionnage et venons en à ce qui me motive pour ce billet. Firefox et Chromium se font une guerre effrénées aux meilleurs performances, pour notre plus grand bien. Chromium à toujours était globalement plus gourmand en mémoire, mais à eu l’avantage dès sa sortie d’être multi-thread (se répartissant bien sur les différents processeurs, plus de réactivités lors qu’un des onglets de réagit pas, etc..) et surtout plus rapide. Firefox l’avait largement devancé en performance mono-thread (pour javascript avec le test Sunspider 9.1) en début d’année, mais était toujours moins réactif du fait de son fonctionnement globalement monothread. Il y a quelques mois, il est devenu mono-thread, explosant ainsi Chromium au tests JavaScript. Chromium 20 a comblé son retard et même devancé Firefox. il utilise maintenant autant de cœurs de processeurs en parallèle mais de façon plus légère tout en étant plus rapide. 15 s pour chromium 20 contre 25 s pour firefox 15 au test Sunspider 9.1. Les versions suivantes de Sunspider seront un peu modifiée pour avantager Chromium sur des fonctionnalités non standard{{refnec}} et ne seront donc pas intéressant pour les tests.

Chromium et WebGL avec Mesa et GPU Intel

Chromium 20 supporte enfin WebGL sur mon système mais il pose encore quelques problèmes.

Avec Firefox jusqu’à 15 (paquet Ubuntu ou Mozilla standard) et avec Chromium 20 (paquet ubuntu 12.04 standard) fonctionnent mais ne supportent pas les textures compressées avec Mesa et GPU Intel. il faut pour contourner se problème régler la variable d’environnement force_s3tc_enable=true avant de lancer l’un de ces navigateurs.

Firefox 16 (actuellement beta4) supporte les textures compressées indépendamment, je ne sais pas pourquoi, je soupçonne une décompression soft, il faut que je cherche, dans ce cas, on aurait avantage à également utiliser le flag, plutôt que de le lancer et d’avoir un ralentissement des applications.

Chromium 21 et 22 (récupérés sur des PPA) ne considèrent plus que mon GPU supporte WebGL, il faut donc lui forcer la main avec l’option : --ignore-gpu-blacklist et tout fonctionne bien.

J’ajoute à chrome une autre argument : --no-sandbox qui permet d’éviter que celui-ci soit lancé en SUID (root) et expose ainsi à tout le web des failles de sécurité béantes à mon système.

Donc, pour le côté pratique je réuni tout ça dans un script qui peut être appelé en ligne de commande ou dans l’interface graphique du système :

#!/bin/bash
force_s3tc_enable=true /usr/bin/chromium-browser --no-sandbox --ignore-gpu-blacklist $1


J’appelle ce script /usr/bin/chromium3d et lui donne les droits d’exécution (chmod +x /usr/bin/chromium3d. le $1 lui permet de récuperer le premier argument (l’URL lorsqu’on click sur un lien où l’ajoute sur le ligne de commande).

Maintenant, le FPS Bananabread devrait fonctionner chez vous

Filed under: Blender, WebGL, 3d, network, news, software developement

Version en français
After a first article on WebGL, I come back on this topic for real usage.

Use in dev version of WebGL on Fennec (mobile firefox), go in about:config, fiter webgl, switch webgl.force-enable to true

On Linux plateform, no problem with Nvidia or ATI proprietary driver. On intel you should use Mesa 8.0. It’s available for ubuntu on ppa:xorg-edgers/ppa

* Firefox 11 (beta) and a plugin for older version called Tilt allow to see in 3d web pages structures accelerating vizualisation, interaction and bug finiding for webmasters.

Pyppet – WebGL Streaming blender< =>WebGL allow a realtime WebGL rendered visualisation in web browser of a scene in modelization process pipled from Blender.

minifier of GLSL files allow to comprress the size of a GLSL script, and then to accelerate web transfert and reduce bandwith.

As I thinked of WebGL as a good tool for some vizualisation in Wikipedia, Google, done an anatomic vizualisation tool. It allow in démos to see a human corpse with ZygotBody and a cow with Google Open-3d-viewer. Code source is available at Project page.

Augmented Reality sample from firefox project.

Cloudmach cloud WebGL games plateform

Seriously.js, realtime compositing on a vidéo.

lights.elliegoulding.com a nice demo.

Crazy bugs a nice puzzle.

Using WebGL for vector and 2D bitmap rendering and use fast and energy efficient hardware acceleration in interactve appliactions : WebGL Fundamentals (WebGL is a 2D API!)

Filed under: WebGL, 3d, animation, network, news, software developement

version en français
WebGL is a 3d API for the Web based on OpenGL library. This is a W3C (managing web standard organisation) standard. Already existings applications are already wonderfull and show that web will quickly allow a better interactivity on surf, Here, some examples and links:

* Nokia Maps3d, far better than google earth and open source, you juste have to click on ‘zoom’ on entitled cities or to zoom manually on them (Video if application doesn’t work on your computer).

* “3 dreams of Black” from Rome (and some other demos). Videoclip mixing 2d digital animation, realtime 3d, postprocessing and interactivity. During the clip, mouse allow to lightly move the camera. After the clip you can move around 3 worlds (find youself gates), focus area follow mouse cursor (there is a short depth of field). Clicking mouse button allow to modify wall and grounds.

*WebGL Chrome experiments. This website is a frequently updated set of WebGL fantastic abilities demonstrations, with lot of specific effects around the web.

* Planet WebGL A planet (RSS aggregator) of WebGL ressources. There are lot of examples, tutorials and libraries to develop WebGL applications and integration in web pages.

La solution opensource parfaite ARM Cortex A9 (très basse conso) + mali 400 (pilotes mesa libre dispos, crées par ARM) existe en plusieurs moutures :
* ST-Ericsson U8500 et U9500 et les plateforme Igloo (Snowboard ~200€ TTC max d’ici juin 2011), compatible Android, Linaro/Ubuntu, Meegoo. Il faut peut-être éviter tant que c’est Sarko et Berlu au pouvoir ? ST = franco-italien.
* Samsung Orion s5pv310 (A éviter tant qu’ils taperons sur la Corée du Nord pour rien), out les PowerVR 100% fermé qui étaient dans les Hummingbird, et sont dans les Texas Instrument TI OMAP (Beagleboard), TI sucks.
*AmLogic AML8726-M (éviter tant que USA en guerre, le prétexte de Ben Laden ne tient plus depuis 2009 d’après le président parkisatanais).

On peut trouver tous les CPU supportés par Linaro ici.

Faudrait peut-être carrément éviter d’acheter de l’électronique, sachant que les constructeurs font également toujours plus ou moins dans le militaire… Vivement l’anarchie planétaire organisée et pacifique (Vive Bakounine comme disait Henri Cartier-Bresson), que tout le monde vive en paix (soyons utopiques et virons tous ces vieux croutons de néo-monarchistes rétrogrades). Espérons qu’a ce moment les ingénieurs et ouvriers pourrons reprendre de façon coopérative ces entreprises avant qu’“>elles ne soient coulées par des Arnaud et autres pourris et incapables de la finance.

En attendant, ces solutions, sont moins consommatrices que les Gros-PC équipés de CPU Intel ou ARM, qui en plus d’être peu efficaces, consomme beaucoup d’énergie.

Older Posts »

Powered by WordPress

Switch to our mobile site