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

Algorithmes et structures de données Discussion :

collision entre deux segments


Sujet :

Algorithmes et structures de données

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    620
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2006
    Messages : 620
    Points : 453
    Points
    453
    Par défaut collision entre deux segments
    Bonjour,

    Je me pose une pitite question sur des collisions : dans un espace 3D, pour 2 segments dont les extrémités se déplacent chacune à une vitesse différente (en norme et direction : donc on a 4 vecteurs vitesses), existe-t-il des recettes pour détecter des collisions entre ces segments ? Si vous avez des pistes, je serais très intéressés !!

    Merci beaucoup !

    Marc

  2. #2
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 76
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Points : 1 913
    Points
    1 913
    Par défaut
    Je pense que le problème est résolu dès qu'on a la distance des deux segments. Il suffit de contrôler cette distance à intervalles de temps réguliers.
    Le calcul de cette distance (en 3D) fait à mon avis intervenir la perpendiculaire commune aux deux droites porteuses, que l'on peut avoir par un banal produit vectoriel.
    Après il faut faire une étude de cas suivant la position des deux segments par rapport à cette perpendiculaire commune.
    Ce qu'on trouve est plus important que ce qu'on cherche.
    Maths de base pour les nuls (et les autres...)

  3. #3
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Ne faut-il pas déjà que les 4 points soient coplanaires ?
    Très en forme notre Pseudocode !!!
    Bien sûr on calcule la distance d'une extrêmité par rapport au plan des 3 autres. Si c'est bon on est ramené à un pb plan.
    Excuse moi Pseudocode, par erreur j'ai édité ton post au lieu d'en faire un nouveau.
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    620
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2006
    Messages : 620
    Points : 453
    Points
    453
    Par défaut
    Merci pour vos réponses, toutefois je pense que le problème est un peu plus tordu que cela... et je crois que je ferais bien de préciser, je m'aperçois que j'ai mal formulé mon affaire.
    J'ai 4 points(a, b, c et d), associés 2 à 2 pour former deux segments [ab] et [cd]. Je connais sur un pas de temps la vitesse de chacun de ces points, va, vb, vc et vd. La question est de prévoir si une interstection va se produire pendant le pas de temps et si oui à quel moment ?
    Les 4 vecteurs vitesse sont indépendants, ce qui signifie que la longueur et l'orientation relative des segments va varier pendant le pas de temps et en toute généralité, ils n'ont pas de normale commune.
    Encore une fois, merci pour vos suggestions

    Marc

  5. #5
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par pseudocode Voir le message
    Excuse moi Pseudocode, par erreur j'ai édité ton post au lieu d'en faire un nouveau.
    Il vous en prie . Pseudocode se quote et de se répond a lui-même.

    La question est de prévoir si une interstection va se produire pendant le pas de temps et si oui à quel moment ?
    Meme réponse. Le point D est d'un coté du plan ABC "avant", et de l'autre coté du plan ABC "après". A partir de là, chercher l'instant "t" pour lequel les 4 points sont coplanaires. Et de là retour au cas en 2 dimensions.

    Bon il y a le cas ou le point D reste du meme coté de ABC (la trajectoire de D est tangeante au plan), mais ce cas est indetectable avec une discrétisation du temps.
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    620
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2006
    Messages : 620
    Points : 453
    Points
    453
    Par défaut
    Salut pseudocode,

    Merci de ta patience : mon crâne épais commence à laisser passer l'info que tu distilles si patiemment... Pour dire autrement, je prends les coordonnées de mes 4 points et je regarde si le système va devenir lié sur mon pas de temps (déterminant nul), et si oui, je regarde si collision il y a dans le plan en regardant si mes segments s'intersectent ?
    Pour le cas où D est tangent, on va de toute façon annuler le déterminant, non ?

    Encore merci

    Marc

  7. #7
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par [Hugo] Voir le message
    Merci de ta patience : mon crâne épais commence à laisser passer l'info que tu distilles si patiemment... Pour dire autrement, je prends les coordonnées de mes 4 points et je regarde si le système va devenir lié sur mon pas de temps (déterminant nul), et si oui, je regarde si collision il y a dans le plan en regardant si mes segments s'intersectent ?
    Yes. En cas d'intersection, le déterminant va changer de signe entre "t" et "t+1". On cherche alors le "t+dt" pour lequel le déterminant est égal à zéro. On se retrouve en géométrie plane pour tester s'il y a réellement intersection des 2 segments (= l'intersection des 2 droites de support est comprise dans chaque segment).

    Pour le cas où D est tangent, on va de toute façon annuler le déterminant, non ?
    Ca dépend du pas de discrétisation. Si le déterminant a "t" ou "t+1" est égal à zéro => idem cas précédant. Mais si les déterminants à "t" et "t+1" sont tous les 2 de meme signe, on n'a aucun moyen de savoir s'il s'est annulé entre les 2 instants.
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  8. #8
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    620
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2006
    Messages : 620
    Points : 453
    Points
    453
    Par défaut
    En fait, l'idée à laquelle on pense est plutôt la suivante :
    on connaît les vitesses sur un pas de temps et on paramètre les positions sur le pas de temps, on en tire un polynôme de degrés 3 en temps et on cherche ses racines et on voit si la ou les racines réelles tombent dans le pas de temps : si oui, l'intersection a lieu à ce moment... du coup, il me semble qu'on ne peut pas rater les intersections...

    Merci tout plein !!

    Marc

  9. #9
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 76
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Points : 1 913
    Points
    1 913
    Par défaut
    Le point générique du segment [AB] est donné par:
    x(t)=txA+(1-t)xB
    y(t)=tyA+(1-t)yB
    z(t)=tzA+(1-t)zB
    avec 0 <= t <=1
    De la même façon le point générique du segment [CD] est donné par:
    x(s)=sxC+(1-s)xD
    y(s)=syC+(1-s)yD
    z(ts=szC+(1-s)zD
    avec 0 <= s <=1
    De sorte que l'existence d'une intersection revient à l'existence d'un couple solution (s,t) avec 0 <= t <=1 et 0 <= s <=1
    au système surdéterminé.
    (xA-xB)t+(xD-xC)s=xD-xB
    (yA-yB)t+(yD-yC)s=yD-yB
    (zA-zB)t+(zD-zC)s=zD-zB
    On extrait s et t des deux premières par les formules de Cramer, et on porte le résultat dans la troisième, ce qui nous donne une équation entre les 12 variables
    f(xA,xB,xC,xD,yA,yB,yC,yD,zA,zA,zC,zD)=0
    qui doit exactement correspondre à la coplanarité des 4 points A,B,C,D.
    On fait donc comme suggère Pseudocode surveillance du signe de f entre deux instants t et t+1, s'il y a changement de signe on peut supposer qu'il y a eu intersection (condition nécessaire). Il suffit alors de vérifier que les deux solutions données par les formules de Cramer sont bien toutes les deux dans l'intervalle [0,1]
    Ce qu'on trouve est plus important que ce qu'on cherche.
    Maths de base pour les nuls (et les autres...)

  10. #10
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    620
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2006
    Messages : 620
    Points : 453
    Points
    453
    Par défaut
    Merci Zavonen
    Je viens de sortir s et t, ça fait des fomules jolies tout plein .
    Je me pose une petite question : selon toi, y a-t-il besoin de se préoccuper de la troisième relation si on s'est déjà assuré de la coplanarité des 4 points via la nullité du déterminant ? ça m'a l'air redondant...

    Encore un grand merci !

    Marc

  11. #11
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 76
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Points : 1 913
    Points
    1 913
    Par défaut
    Je me pose une petite question : selon toi, y a-t-il besoin de se préoccuper de la troisième relation si on s'est déjà assuré de la coplanarité des 4 points via la nullité du déterminant ? ça m'a l'air redondant...
    Je le pense aussi ...
    Ce qu'on trouve est plus important que ce qu'on cherche.
    Maths de base pour les nuls (et les autres...)

Discussions similaires

  1. Fonction pour tester la collision entre deux objets
    Par izissie dans le forum Newton
    Réponses: 1
    Dernier message: 22/09/2010, 20h56
  2. collision entre deux mobiles
    Par Bastuccio dans le forum Général JavaScript
    Réponses: 17
    Dernier message: 24/09/2009, 08h36
  3. Calcul d'angle entre deux segments pour algo de Jarvis
    Par Niko_de_bordo dans le forum Mathématiques
    Réponses: 14
    Dernier message: 25/06/2009, 23h36
  4. Collision entre deux rectangle
    Par Ouaibou dans le forum Mathématiques
    Réponses: 4
    Dernier message: 15/04/2007, 15h16
  5. Detection de collision entres deux cylindres.
    Par Sandro Munda dans le forum Algorithmes et structures de données
    Réponses: 9
    Dernier message: 07/11/2006, 14h36

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