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

Physique Discussion :

Création d'un moteur physique : les bases


Sujet :

Physique

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Février 2006
    Messages
    396
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2006
    Messages : 396
    Points : 230
    Points
    230
    Par défaut Création d'un moteur physique : les bases
    Bonjour,

    J'aimerais créer un moteur physique 3D assez basique.
    J'ai lu quelques articles sur Internet et j'ai essayé de comprendre le code source du moteur Bullet (pas facile ). Je me pose deux questions:

    Structure:
    J'aimerais executer la simulation physique dans une thread autre que celle du rendu 3D afin d'utiliser mon CPU de façon optimale. J'ai pensé à deux façons de faire:
    * Au début de ma boucle de rendu, je réveil ma thread physique pour faire un step de simulation physique. A la fin de mon rendu, je récupère les nouvelles positions/orientations calculées par la thread physique (une fois terminé) afin de les utiliser au prochain rendu.
    Désavantage: si mon step de simulation physique est très lent, il risque de faire descendre mon framerate de rendu.

    * Avoir une thread de simulation physique qui calcule toutes les x millisesondes un step de simulation physique. A chaque boucle de rendu: on va lire les dernières positions/orientations calculées par la thread physique (avec utilisation des mutex pour éviter les accès concurrents).

    Y a-t-il une solution meilleure que l'autre et si oui: pourquoi ?

    Performance:
    Sur Internet, on peu lire dans pratiquement tous les articles qu'il faut exécuter un step de simulation physique environ 60 fois par seconde pour éviter qu'un petit objet à pleine vitesse traverse un mur.

    Est-ce vraiment la solution idéale en terme de performance ?
    Si on connait la taille de l'objet et sa vitesse: on peut facilement déterminer à quel fréquence il faut exécuter les calcules de physiques, non ?
    Je me doute bien que ça se complique quand on a deux objets qui bougent en même temps.
    Qu'en pensez vous ? Existe t-il des algorithmes pour ce genre de problème ?

    Merci d'avance.

  2. #2
    Membre expérimenté
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mars 2011
    Messages
    576
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2011
    Messages : 576
    Points : 1 528
    Points
    1 528
    Par défaut
    Salut,

    Y a-t-il une solution meilleure que l'autre et si oui: pourquoi ?
    Je dirais la 2ème solution. Réveiller un thread est "très" long (plusieurs ms). Alors que si ton thread tourne en permanence, tu as juste à la bloquer avec un mutex (voir même un spinLock, mais à utiliser prudement). De plus, la boucle physique est généralement désinchronisée de la boucle de rendu et est aussi plus rapide (jusqu'a plusieur dizaines de step physique pas frame):
    Si ta boucle physique est synchro avec ta boucle de rendu, tes résultats vont varier en fonction de ton affichage. Par ex., dans une scène visuellement très lourde à quelque fps, tes objets risques de traverser les murs. Problème que tu n'a pas avec un boucle physique non synchrone (à moins de mettre ton CPU à genoux )
    La perfection est atteinte, non pas lorsqu’il n’y a plus rien à ajouter, mais lorsqu’il n’y a plus rien à retirer. - Antoine de Saint-Exupéry

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 23/05/2010, 10h58
  2. Création de moteur physique, problème de collision
    Par Jackyzgood dans le forum Débuter
    Réponses: 2
    Dernier message: 09/11/2009, 11h35
  3. Réponses: 0
    Dernier message: 01/10/2009, 22h06
  4. [MySQL] Création d'un tableau avec les données d'une base de données
    Par opeo dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 02/04/2009, 20h29

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