Saturday, August 25, 2012

Le premier lancer de rayon... a eu lieu en 1525 !





En 1525, Albrecht Dürer, peintre, graveur et mathématicien allemand expose une méthode pour représenter les perspectives. Il reporte point par point sur une feuille, les contours d’objets à l’aide d’une ficelle tendue entre le point de vue et la scène...

La même méthode est utilisée de nos jours dans les calculs graphiques, la ficelle ayant été remplacé par des vecteurs, et les objets par des ensembles de triangles...

Tuesday, July 10, 2012

Rencontre avec Balthazar Auxietre - Eidolon


Ce weekend, nous avons rencontré Balthazar Auxietre, réalisateur du projet Eidolon, "une installation immersive qui propose de vivre une expérience cinématographique interactive pour un spectateur unique".




Ce type de projet artistique nous intéresse beaucoup, car nous partageons le même but, la même finalité: faire vivre des expériences, des aventures, au travers d'une histoire, d'une technologie.

Pour Eidolon, la technologie de réalité virtuelle utilisée est un casque. A 
l'avenir nous travaillerons probablement avec Balthazar sur un nouveau projet, en utilisant cette fois l'Immersion Engine comme pièce maîtresse, et vous pourrez vivre cette expérience immersive sur n'importe quel équipement de réalité virtuelle.


Stay tuned ;)



Si vous avez aimé l'article n'hésitez pas à laisser un commentaire, ou me suivre sur twitter

Thursday, June 14, 2012

Premiers retours de Gaiagen


Nous avons des nouvelles de Gaiagen, le logiciel de génération de mondes virtuels développé par Julien Lagorsse et ses acolytes, et qui utilise l'Immersion Engine comme moteur de rendu.

Gaiagen est un projet de fin d'étude. Le logiciel doit générer terrains, océans, végétation, et dans le futur des espaces urbains.


Pour l'instant la gestion du terrain et de l'eau est bien avancée, je vous tiendrais au courant des futures nouveautés.




Voici un screenshot de la génération de terrain.










Si vous avez aimé l'article n'hésitez pas à laisser un commentaire, ou me suivre sur twitter

Thursday, June 7, 2012

VIDEO - Immersion Engine dans la presse online!

Ces dernières semaines ont été riches en nouveauté.

Entre autres, #Epitech à publié un article de presse qui a été repris par de nombreux site, dont les très réputés 3dvf.com et afjv.com



Nous sommes très content de l'engouement généré par le projet, cela nous motive encore plus dans notre travail, et de nouvelles surprises sont en préparation pour la rentrée. Stay tuned ;-)

Regardez Camille JAN parler d'Immersion, dans cette courte vidéo de 2 minutes.



Si vous avez aimé l'article n'hésitez pas à laisser un commentaire, ou me suivre sur twitter

Tuesday, June 5, 2012

Comment mettre à jour manuellement un plugin Firefox obsolète?

De temps en temps, avec les nouvelles versions de Firefox, certain de vos plugins peuvent devenir obsolètes.
Pour forcer leur compatibilité, voici un petit hack:


Téléchargez le module sur votre ordinateur (clic droit -> enregistrer le lien sous), puis renommez l'extension .xpi en .zip
Ouvrez l'archive, et modifiez le fichier install.rdf présent à l'intérieur.



Cherchez la balise <em:maxVersion> et changez la valeur par le numéro de votre version.
Sauvegardez le fichier, renommez l'extension de l'archive en .xpi, et ouvrez-là avec Firefox (ctrl+O) pour installer le module.

Si vous avez aimé l'article n'hésitez pas à laisser un commentaire, ou me suivre sur twitter

Friday, May 25, 2012

Compiler Firesheep sur Fedora



Dernièrement, je me suis amusé dernièrement à compiler Firesheep sur ma Fedora.
Voici les commandes tapées:

Installation des dépendances:

yum install autoreconf  xulrunner xulrunner-devel git git-all cpan libpcap libpcap-devel boost boost-devel gcc libtool autoheader

cpan CORBA::XPIDL
cpan CORBA::IDL::Parser

Récupération des sources:

git clone https://github.com/mickflemm/firesheep.git
cd firesheep/

git submodule update --init

Compilation:

./autogen.sh --with-xulrunner-sdk=/usr/lib/xulrunner-2



Pour l'installation de l'extension, il suffit d'ouvrir le .xpi avec Firefox (path du fichier dans la barre d'adresse).
Il vous faudra éventuellement lancer Firefox en root pour certaines permissions.


Si vous avez aimé l'article n'hésitez pas à laisser un commentaire, ou me suivre sur twitter

Saturday, January 28, 2012

Comment normaliser 4 vecteurs rapidement via les instructions SIMD

Une grande partie des performances dégagées par notre moteur sont dues au concept de SIMD; Simple Instruction Multiple Data. Ce sont des instructions processeurs (SSE, SSE2, SSE3, SSE4a, 3dNow!) qui permettent d'accélérer des calculs bas niveau.


L'exemple suivant montre comment faire une addition de vecteur classique


 struct vector  
 {  
   float x,y,z;  
 };  
 vector add(const vector &a, const vector &b)  
 {  
   vector c;  
   c.x = a.x + b.x;  
   c.y = a.y + b.y;  
   c.z = a.z + b.z;  
   return c;  
 }  


Et maintenant la version SIMD:


 # include <xmmintrin.h>  
 struct vector  
 {  
   __m128 m;  
   // Pour acceder aux composantes x, y, z  
   // vous pouvez simplement faire un cast ((float*)&m)[ 0 1 2 ou 3]  
 };  
 vector add(const vector &a, const vector &b)  
 {  
   vector c;  
   c.m = _mm_add_ps(a.m, b.m);  
   return c;  
 }  


Entre les deux versions, le facteur de speedup se situe entre 3 et 4. Si vous développez des applications nécessitants de nombreux calculs 3D, utilisez absolument ces instructions!


Voici maintenant une astuce pour gagner du temps sur les normalisations.


Il est plus performant de multiplier par la sqrt inverse (_mm_rsqrt_ps) que de diviser par la sqrt. En revanche la fonction _mm_rsqrt_ps a une précision moindre. Pour combler ce manque de précision, on fait une nouvelle itération dans le calcul de la racine, appelée "Iteration de Newton-Raphson".

 __m128    fastrsqrt( const __m128 v )  
 {  
       static const __m128 _half4 = _mm_set_ps1( 0.5f );  
       static const __m128 _three = _mm_set_ps1( 3.0f );  
       const __m128 nr = _mm_rsqrt_ps( v ); // Newton-Raphson iteration  
       const __m128 muls = _mm_mul_ps( _mm_mul_ps( v, nr ), nr );  
       return _mm_mul_ps( _mm_mul_ps( _half4, nr ), _mm_sub_ps( _three, muls ) );  
 }  
 void Normalize4(vector p[4])  
 {  
     // Store x, y, and z separately in 3 __m128  
     __m128 x4 = _mm_set_ps(p[3][0], p[2][0], p[1][0], p[0][0]);  
     __m128 y4 = _mm_set_ps(p[3][1], p[2][1], p[1][1], p[0][1]);  
     __m128 z4 = _mm_set_ps(p[3][2], p[2][2], p[1][2], p[0][2]);  
     x4 = _mm_mul_ps(x4, x4); // x * x  
     y4 = _mm_mul_ps(y4, y4); // y * y  
     z4 = _mm_mul_ps(z4, z4); // z * z  
     const vector l = fastrsqrt(_mm_add_ps(z4, _mm_add_ps(y4, x4))); // sqrt(x*x+y*y+z*z)  
     p[0].m = _mm_mul_ps(p[0].m, _mm_set_ps1(l[0])); // load results in packet  
     p[1].m = _mm_mul_ps(p[1].m, _mm_set_ps1(l[1]));  
     p[2].m = _mm_mul_ps(p[2].m, _mm_set_ps1(l[2]));  
     p[3].m = _mm_mul_ps(p[3].m, _mm_set_ps1(l[3]));  
 }  


Si vous avez aimé l'article n'hésitez pas à laisser un commentaire, ou me suivre sur twitter

Immersion Engine dans la presse!

Nous sommes dans le magazine Programmez du mois de Janvier!
A la page numéro 24, vous trouverez une page parlant de notre projet.

Je vous invite à acheter le magazine pour découvrir les autres passionnants projets de fin d'études présenté par les étudiants de notre promotion. Vous pouvez vous le procurer ici.

Bonne lecture!

Si vous avez aimé l'article n'hésitez pas à laisser un commentaire, ou me suivre sur twitter

Monday, October 3, 2011

Les phases communicantes

Il était temps de redorer un peu la communication autour d'Immersion! Ce qui nous as motivé, c'est les cours de business dispensés à Epitech par Gilles Enguehard. En définissant mieux notre cible potentielle, nous avons pu redéfinir notre identité visuelle ainsi que les textes qui l'accompagne.

En bref, nouveau logo, nouvelle typo, nouvelle accroche, nouveau site, nouvelles cartes de visites, nouveaux flyers, etc.... beaucoup de nouvelles choses en préparation!

Voici en avant-première un projet de flyer dans lequel vous pouvez voir entre autres le nouveau logo !
N'hésitez pas à partager vos critiques/commentaires en dessous!

Si vous avez aimé l'article n'hésitez pas à laisser un commentaire, ou me suivre sur twitter

Monday, August 1, 2011

Rencontre avec AMD

La semaine dernière, nous avons eu le plaisir de rencontrer à l'ACSEL un employé de chez AMD! Un entretien très intéressant autour de l'optimisation matérielle, et de l'utilisation du trio CPU / GPU / APU pour lancer des rayons.




Les 5 points à retenir absolument avant de se lancer dans le GPGPU:

  1. Un GPU est très bon pour les calculs parallèles sur de gros blocs de données, si toutefois les calculs ne diffèrent pas trop. Ce qui veut dire qu'il est très bon pour les rayons primaires, beaucoup moins pour les secondaires.
  2. Les algorithmes avec beaucoup de branchements (type parcours d'arbre) sont à BANNIR sur GPU. Le CPU est beaucoup plus à l'aise dessus.
  3. Un APU à environ 1/4 de la puissance d'un GPU. Mais du fait de sa localisation, il sera plus performant pour certains calculs que le GPU.
  4. La taille de la VRAM ne doit pas être un soucis. Des solutions arriveront.
  5. Le temps de transfert ne doit pas être un soucis. Des solutions arriveront.

Nous voilà donc partis dans nos premiers TPs sur OpenCL. Les premiers résultats sont concluants, mais il faudra un gros travail de conception avant de voir le GPGPU d'imposer dans le moteur.



Si vous avez aimé l'article n'hésitez pas à laisser un commentaire, ou me suivre sur twitter