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 :

Point dans un polygone 3D


Sujet :

Algorithmes et structures de données

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 46
    Points : 65
    Points
    65
    Par défaut Point dans un polygone 3D
    Salut,
    J'ai fais des recherches sur google ainsi que sur votre site et j'ai trouvé beaucoup de reponse.
    Je recherche juste quelques explications sur la maniere de determiner si un point (x,y,z) se trouve dans un polygon3D de type triangle, le but final et de l'utiliser pour un Z-Buffer.
    Merci de bien m'aider.

  2. #2
    Expert éminent
    Avatar de PRomu@ld
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Avril 2005
    Messages
    4 155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Ingénieur de Recherche
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2005
    Messages : 4 155
    Points : 6 486
    Points
    6 486
    Par défaut
    Il y a une discussion relativement récente sur le sujet il me semble.

    Une idée comme ça parmis tant d'autres :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    -> Vérifier que le point est dans le plan support du triangle. 
    -> Puis vérifier que le point est dans le triangle :
      * Soit par coordonnées barycentriques
      * Soit en utilisant les coordonnées de Plücker.
    Il existe bien d'autres méthodes.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 46
    Points : 65
    Points
    65
    Par défaut
    Vérifier que le point est dans le plan support du triangle.
    Mon probleme vient de la, comment verifier que le point appartient au plan du triangle?

    Puis vérifier que le point est dans le triangle :
    * Soit par coordonnées barycentriques
    * Soit en utilisant les coordonnées de Plücker.
    Pour cette partie du probleme de prefference je vais utilisé par coordonnées barycentriques, sinon pour les coordonnées de Plücker je vais me documenter.

  4. #4
    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 silfride Voir le message
    Mon probleme vient de la, comment verifier que le point appartient au plan du triangle?
    tu peux verifier si la distance entre le point et le plan est inferieure à un epsilon donné.

    http://fr.wikipedia.org/wiki/Distanc...oint_à_un_plan
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  5. #5
    Membre éprouvé Avatar de cs_ntd
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2006
    Messages
    598
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2006
    Messages : 598
    Points : 1 214
    Points
    1 214
    Par défaut
    Citation Envoyé par pseudocode Voir le message
    tu peux verifier si la distance entre le point et le plan est inferieure à un epsilon donné.

    http://fr.wikipedia.org/wiki/Distanc...oint_à_un_plan
    Tu est sur qu'il n'y a pas plus simlple ?
    Si l'équation cartésienne du plan est ax + by + cz + d = 0, ne suffit il pas de remplacer par les coordonnées x1, y1, z1 du point et de voir si ces coordonnées vérifient la relation?

    The magic of Opera, La magie de l'Opera
    The mysteries of Space Opera, Les mystères de l'Opera Spatial
    Mr. Know-it-all, M. Je-Sais-Tout
    Prelude in C sharp minor, the most beautiful piano song and the best C sharp prelude ever, Prélude en do dièse mineur, le plus beau morceau de piano et le meilleur prélude au C#
    The Mesmerizing Saphir Division for Nerds, L'Hypnotisante Division Saphire pour les Nerds (HDSN)

  6. #6
    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 cs_ntd Voir le message
    Tu est sur qu'il n'y a pas plus simlple ?
    Si l'équation cartésienne du plan est ax + by + cz + d = 0, ne suffit il pas de remplacer par les coordonnées x1, y1, z1 du point et de voir si ces coordonnées vérifient la relation?
    Dans le monde idéal des nombres réels : oui.

    Dans le monde approximatif des nombres flottants: non.

    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  7. #7
    Membre éprouvé Avatar de cs_ntd
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2006
    Messages
    598
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2006
    Messages : 598
    Points : 1 214
    Points
    1 214
    Par défaut
    Moi sûrement un peu trop matheux sur les bords .

    Oui je comprend maintenant le coup du "inferieure à un epsilon donné" .

    Mais ne pourrait on pas envisager la même chose avec l'équation? Si ax1 + by1 + cz1 + d s'approche de zéro c'est bon, non ?

    Je chipote peut-être un peu...

    The magic of Opera, La magie de l'Opera
    The mysteries of Space Opera, Les mystères de l'Opera Spatial
    Mr. Know-it-all, M. Je-Sais-Tout
    Prelude in C sharp minor, the most beautiful piano song and the best C sharp prelude ever, Prélude en do dièse mineur, le plus beau morceau de piano et le meilleur prélude au C#
    The Mesmerizing Saphir Division for Nerds, L'Hypnotisante Division Saphire pour les Nerds (HDSN)

  8. #8
    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 cs_ntd Voir le message
    Mais ne pourrait on pas envisager la même chose avec l'équation? Si ax1 + by1 + cz1 + d s'approche de zéro c'est bon, non ?
    Sauf que la vitesse d' "approche de zéro" dépend des valeurs de a,b,c. Donc ce ne sera pas le meme epsilon suivant les triangles.

    C'est pour cela qu'on normalise en divisant par racine(a²+b²+c²).
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 46
    Points : 65
    Points
    65
    Par défaut
    tu peux verifier si la distance entre le point et le plan est inferieure à un epsilon donné.

    http://fr.wikipedia.org/wiki/Distanc...oint_à_un_plan
    Merci pour vos reponse je commence a identifier une solution.

    Soit le plan P et le point A dans l'espace. On appelle (xA,yA,zA) les coordonnées du point A et ax + by + cz + d = 0 l'équation représentative du plan P
    Que represente le (a,b,c) par rapport au plan p?

  10. #10
    Membre éprouvé Avatar de cs_ntd
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2006
    Messages
    598
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2006
    Messages : 598
    Points : 1 214
    Points
    1 214
    Par défaut
    Hmmm peut-être devrait-tu voire un cours sur la géométrie dans l'espace...

    http://homeomath.imingo.net/equplan.htm, ça m'a l'air pas mal...

    Je précise que le produit scalaire dans l'espace entre deux vecteurs AB(x1,y1,z1) et CD(x2,y2,z2) est donné par la formule x1*x2 + y1*y2 + z1*z2, et que si c'est égal à zéro, les vecteurs sont othogonaux.

    The magic of Opera, La magie de l'Opera
    The mysteries of Space Opera, Les mystères de l'Opera Spatial
    Mr. Know-it-all, M. Je-Sais-Tout
    Prelude in C sharp minor, the most beautiful piano song and the best C sharp prelude ever, Prélude en do dièse mineur, le plus beau morceau de piano et le meilleur prélude au C#
    The Mesmerizing Saphir Division for Nerds, L'Hypnotisante Division Saphire pour les Nerds (HDSN)

  11. #11
    Expert éminent
    Avatar de PRomu@ld
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Avril 2005
    Messages
    4 155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Ingénieur de Recherche
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2005
    Messages : 4 155
    Points : 6 486
    Points
    6 486
    Par défaut
    Que represente le (a,b,c) par rapport au plan p?
    Un vecteur orthogonal à P.

  12. #12
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 46
    Points : 65
    Points
    65
    Par défaut
    Citation Envoyé par cs_ntd Voir le message
    Hmmm peut-être devrait-tu voire un cours sur la géométrie dans l'espace...

    http://homeomath.imingo.net/equplan.htm, ça m'a l'air pas mal...

    Je précise que le produit scalaire dans l'espace entre deux vecteurs AB(x1,y1,z1) et CD(x2,y2,z2) est donné par la formule x1*x2 + y1*y2 + z1*z2, et que si c'est égal à zéro, les vecteurs sont othogonaux.
    Merci tout le monde j'ai compris, je vous tiendrais au courant apres l'implementation et test.

Discussions similaires

  1. [C] présence d'un point dans un polygone
    Par adiiii dans le forum Développement 2D, 3D et Jeux
    Réponses: 15
    Dernier message: 16/11/2019, 09h14
  2. Nombre maximum de point dans un polygon type geography
    Par blairswish dans le forum MS SQL Server
    Réponses: 10
    Dernier message: 13/07/2010, 14h18
  3. Point dans un polygone
    Par kerinel dans le forum Mathématiques
    Réponses: 5
    Dernier message: 17/10/2007, 12h23
  4. Point dans un polygone
    Par titelisette dans le forum ASP
    Réponses: 7
    Dernier message: 03/05/2007, 17h08
  5. Point dans un polygone
    Par titelisette dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 27/04/2007, 11h51

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