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

Python Discussion :

Trouver le milieu d'un polygone rapidement ?


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Invité
    Invité(e)
    Par défaut Trouver le milieu d'un polygone rapidement ?
    Bonjoir !

    Quel rapport avec python ? Peu voire pas du tout, j'avoue...

    Dans une image contenant des polygones de 3, 4 ou 5 côtés (triangle équilatéral, carré, octogone équilatéral) à la rotation aléatoire, j'aimerais trouver rapidement le centre de celui sur lequel je clique.

    J'ai songé à une méthode (et très certainement réinventé la roue) qui me semble facile à mettre en œuvre en python :

    Nom : midle-octogone.gif
Affichages : 715
Taille : 11,5 Ko

    Le premier point noir (en bas du polygone) est l'endroit où j'ai hypothétiquement cliqué, ensuite avec PIL (pix = im.load()) je peux obtenir un tableau 2D des pixels et donc établir ma première droite verticale (while pixel is blue y+1 / idem avec y-1), je peux calculer facilement le centre de cette droite (second point noir) et recommencer à l'horizontale pour déterminer le centre du polygone.

    Mon raisonnement vous parait juste ? Y a-t-il plus mieux en terme pythonesque (plus rapide que PIL par ex) ou algorithmique ?

    (Vive photoshop)

    Merci et bonne joirée !

  2. #2
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par LeNarvalo Voir le message
    Quel rapport avec python ? Peu voire pas du tout, j'avoue...
    Ben oui, ton topic est un topic d'algo...

    Citation Envoyé par LeNarvalo Voir le message
    Dans une image contenant des polygones de 3, 4 ou 5 côtés (triangle équilatéral, carré, octogone équilatéral)
    Oui, l'octogone, bâtiment à 5 côtés bien connu abritant le QG du Ministère de la Défense américaine...

    Citation Envoyé par LeNarvalo Voir le message
    ou algorithmique ?
    Pour les octogones impairs ce serait le point d'intersection des médianes (et 2 suffisent) et pour les octogones pairs le point d'intersection des diagonales. Reste les octogones à 1 côté...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  3. #3
    Invité
    Invité(e)
    Par défaut
    Ben oui, ton topic est un topic d'algo...
    Oui je sais. C'est un petit entracte !

    Pour les octogones impairs ce serait le point d'intersection des médianes (et 2 suffisent) et pour les octogones pairs le point d'intersection des diagonales...
    C'est surement pas facile ni rapide à calculer depuis une image... Faudrait que je me fasse quelques croquis avec des rotations différentes pour voir si ma proposition tiens la route.


    Vive la république ! Vive l'octogone !

  4. #4
    Membre Expert
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    1 539
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 1 539
    Par défaut
    je croyais qu'un octogone avait toujours 8 côtés (étymologiquement 8 angles, donc 8 sommets) donc un nombre pair de côtés

  5. #5
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par umfred Voir le message
    je croyais qu'un octogone avait toujours 8 côtés (étymologiquement 8 angles, donc 8 sommets) donc un nombre pair de côtés
    C'était une moquerie sur le premier post, où le PO cites des figures à 3, 4 et 5 côtés qu'il nomme respectivement triangle, carré et octogone...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  6. #6
    Membre Expert
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    1 539
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 1 539
    Par défaut
    j'ai pas bien tilté sur le comique de répétition

  7. #7
    Expert confirmé
    Avatar de Mat.M
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2006
    Messages
    8 527
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 8 527
    Par défaut
    Citation Envoyé par LeNarvalo Voir le message
    je peux obtenir un tableau 2D des pixels et donc établir ma première droite verticale (while pixel is blue y+1 / idem avec y-1
    oui je pense qu'il faut partir sur cette méthode là.
    La méthode serait la suivante:
    *parcourir chaque point de l'écran ligne par ligne afin de définir les sommets x,y des polygones en testant si chaque pixel PixelX,PixelY est bleu : une ligne d'écran c'est la largeur de l'image mettons 640 pixels.
    Le premier sommet sera donc la première ligne horizontale ne comprenant qu'un seul point bleu
    *les sommets suivants seront la ligne comprenant le plus de points bleus
    *le sommet le plus bas sera la dernière ligne ne comprenant qu'un seul point
    *ranger ces sommets dans un tableau.
    *avec ces points définir les droites /vecteurs entre ces points.
    *en obtenant ces points on peut avoir le milieu de ces droites.


    Sinon la méthode la plus simple c'est de définir les sommets du polygone.
    En obtenant les sommets du polygone trouver l'équation du cercle passant par ces sommets.
    Au boulot

  8. #8
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Mat.M Voir le message
    Sinon la méthode la plus simple c'est de définir les sommets du polygone.
    En obtenant les sommets du polygone trouver l'équation du cercle passant par ces sommets.
    Euh... pour trouver l'équation d'un cercle, équation de type (x-xC)²+(y-yC)²=r² (avec xC et yC les coordonnées du centre C), n'est-il pas nécessaire de connaitre au préalable le centre du cercle (donc ici le centre du polygone)?
    Donc en résumé, la méthode la plus simple pour trouver le centre du polygone c'est d'avoir le centre du polygone. Ca se tient...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  9. #9
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 738
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 738
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Donc en résumé, la méthode la plus simple pour trouver le centre du polygone c'est d'avoir le centre du polygone. Ca se tient...
    Pour les polygones réguliers (convexe)s l'intersection des médianes de 2 côtés donnera le centre du cercle inscrit.
    Et pour avoir ces côtés, il faut avoir les coordonnées des points qui en sont les sommets.

    Et si on prend le problème de départ, si à partir de la médiane d'un côté on récupère le segment qui va du milieu du coté au point opposé du cercle inscrit.
    Si le milieu de ce segment était le centre de ce cercle, le cote serait de longueur nulle (et le prétendu polygone: un cercle).

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  10. #10
    Invité
    Invité(e)
    Par défaut
    Euh vous êtes gentils mais c'est un truc prise de tête que vous me proposez là les pros !

    Je rajoute à mon énoncé que le centre peut être approximatif.

    Ma proposition n'est malheureusement pas aussi précise que je l'espérais mais ça n'est pas trop éloigné de la réalité :
    Nom : pentagone.jpg
Affichages : 587
Taille : 114,1 Ko
    Vive Geogebra !
    Dernière modification par Invité ; 15/11/2022 à 18h51.

  11. #11
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 738
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 738
    Par défaut
    Citation Envoyé par LeNarvalo Voir le message
    Ma proposition n'est malheureusement pas aussi précise que je l'espérais mais ça n'est pas trop éloigné de la réalité
    Reste à calculer les erreurs de cette méthode pour voir si sa précision est intéressante (et dans quels cas).

    Citation Envoyé par LeNarvalo Voir le message
    Euh vous êtes gentils mais c'est un truc prise de tête que vous me proposez là les pros !
    ah ben... mais si vous voulez de l'aide on a déjà mentionné que ce n'était pas (ici) le bon forum.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

Discussions similaires

  1. Collection et pointeur : trouver le milieu sans connaître la taille de la collection
    Par sebxid dans le forum Algorithmes et structures de données
    Réponses: 3
    Dernier message: 24/01/2017, 20h58
  2. Trouver le centre d'un polygone
    Par gregtw29 dans le forum Requêtes
    Réponses: 2
    Dernier message: 26/07/2012, 16h27
  3. Clic dans un polygone et trouver l'objet
    Par Zoons dans le forum Windows
    Réponses: 1
    Dernier message: 06/07/2006, 23h01
  4. Trouver les polygones
    Par Mucho dans le forum Algorithmes et structures de données
    Réponses: 9
    Dernier message: 07/03/2006, 10h04
  5. Algo le plus rapide pour trouver une répétition ?
    Par AsmCode dans le forum Algorithmes et structures de données
    Réponses: 3
    Dernier message: 28/07/2005, 00h26

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