IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

OpenGL Discussion :

C/C++ half (16 bit float) charger dans un VBO


Sujet :

OpenGL

Mode arborescent

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2009
    Messages
    219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2009
    Messages : 219
    Par défaut C/C++ half (16 bit float) charger dans un VBO
    Bonjours a tous.

    Je travaille sur une optimisation mémoire, en l'occurrence d'un gazon encore en conception fait par des bilboards. Et je voulait m'essayer aux chargeant des half au lieu des float pour les normals. Je me suis donc référé a la norme en vigueur pour coder ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
     
    typedef unsigned short int half ;
     
    namespace math
    {
     
    	namespace half
    	{
     
    		inline unsigned short int packf (const float Value)
    		{
    			const unsigned int FloatImage = * (const unsigned int *) &Value ;
    			unsigned short int Packed ;
     
    			Packed = (FloatImage >> 13) & 0x03FF ;
    			Packed |= ((((FloatImage & 0x7F800000) >> 23) - 112) << 10) & 0x7C00 ;
    			Packed |= (FloatImage & 0x80000000) >> 16 ;
     
    			return Packed ;
    		}
     
    		inline float unpackf (const ::half Value)
    		{
    			unsigned int UnPacked ;
     
    			UnPacked = (Value & 0x03FF) << 13 ;
    			UnPacked |= (((Value & 0x7C00) >> 10) + 112) << 23 ;
    			UnPacked |= (Value & 0x8000) << 16 ;
     
    			return * ((float *) &UnPacked) ;
    		}
     
     
    	}
    }
    j'ai fait beaucoup, de test, vérifié des valeurs, et cela fonctionne sur le CPU, mais lorsque je charge ces half dans les VBO, il semble y avoir des problème : illustration en image :

    Premiere image, le rendu est fait avec des normal codé sur 3 float


    Seconde image, le rendu est fait avec des normal mais codé sur 3 half


    On voit alors qu'il y a belle et bien un problème de signe sur celle ci ... Sur la première images, très peut des bilboard sont enclairé, car on est face au soleil ... logique ... mais pas sur le rendu avec les half Comme si le bit de signe n'était pas au placé au même endroit sur le GPU.

    Quel qu'un a t'il déjà rencontrer ce problème ?
    Images attachées Images attachées   

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 1
    Dernier message: 01/06/2007, 11h48
  2. Réponses: 2
    Dernier message: 07/04/2007, 12h29
  3. Problème de rendu 16 bits float + MSAA
    Par gybe dans le forum DirectX
    Réponses: 10
    Dernier message: 10/08/2006, 17h24
  4. Réponses: 2
    Dernier message: 17/05/2006, 19h34
  5. [MFC] *.txt charger dans une CRichEditView
    Par hiko-seijuro dans le forum MFC
    Réponses: 2
    Dernier message: 24/06/2005, 16h27

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo