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 :

Couleurs fractales de Mandelbrot


Sujet :

Python

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juin 2013
    Messages : 3
    Points : 1
    Points
    1
    Par défaut Couleurs fractales de Mandelbrot
    Bonjour à tous,

    alors voilà, je travaille avec python 2.7 win32 et j'aurais voulu réussir à mettre en couleur la fractale de Mandelbrot sur Tkinter, pour cela il faudrait que je puisse récupérer la valeur d'itération de h à laquelle ma boucle for s'arrête (je m'excuse pour les indentations, le copier coller ne les a pas conservées):

    from Tkinter import *
    from random import randrange

    def mandel2(c):
    z=0
    for h in range(0,50):
    z = z**2 + c
    if abs(z) > 2:
    break
    if abs(z) >= 2:
    return False
    else:
    return True

    root = Tk()
    w = Canvas(root, width=600, height=600, background='white' )
    w.pack()

    for hx in range(0,600,50):
    w.create_line(0,hx,600,hx,fill="blue")

    for hy in range(0,600,50):
    w.create_line(hy,0,hy,600,fill="blue")


    print ("Initializing...")

    for x in range(0,600):
    real = x / 200.0 -2
    for y in range(0,600):
    img = y / 200.0 -1.5
    c = complex(real, img)
    if mandel2(c):
    w.create_line(x,600-y,x+1,601-y,fill="black")
    w.pack()

    print ("Complete!")

    root.mainloop()

    J'aurais voulu utiliser ceci pour mettre en couleur en fonction de la valeur de h:

    pal = ['purple', 'red', 'yellow', 'blue', 'green', 'maroon', 'pink', 'orange']
    d = randrange(8)
    couleur = pal[d]

    Auriez vous des propositions ?

    Merci d'avance,

    Onurbi

  2. #2
    Membre éclairé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2013
    Messages
    388
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2013
    Messages : 388
    Points : 692
    Points
    692
    Par défaut
    Salut,
    Tu n'auras pas beaucoup d'aide si le code n'est pas indenté (les balises code sont crées avec le bouton #).
    As-tu regardé cet ancien fils ? Le code fonctionne très bien.

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juin 2013
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Le voici, non je n'avais pas vu mais je ne cherche pas le rendement et le code le plus court, en fait c'est pour une présentation (NB: débutant) donc j'essaye d'utiliser du code que je saurais expliquer mais ça ne m'empêche pas de me documenter pour trouver à quoi sert une partie du code



    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
    36
    def mandel2(c):
        z=0
        for h in range(0,50):       #nombre d'iteration
            z = z**2 + c
            if abs(z) > 2:          #abs(z) correspond au module de z
                break               #arrête l'execution du for si la condition est remplie
        if abs(z) >= 2:
            return False
        else:
            return True
     
    root = Tk()
    w = Canvas(root, width=600, height=600, background='white' )
    w.pack()
     
    for hx in range(0,600,50):
        w.create_line(0,hx,600,hx,fill="blue")
     
    for hy in range(0,600,50):
        w.create_line(hy,0,hy,600,fill="blue")
     
     
    print ("Initializing...")
     
    for x in range(0,600):
        real = x / 200.0 -2
        for y in range(0,600):
            img = y / 200.0 -1.5
            c = complex(real, img)
            if mandel2(c):
                w.create_line(x,600-y,x+1,601-y,fill="black")
                w.pack()
     
    print ("Complete!")
     
    root.mainloop()

  4. #4
    Membre éclairé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2013
    Messages
    388
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2013
    Messages : 388
    Points : 692
    Points
    692
    Par défaut
    Pour avoir la valeur de h à la sortie de la boucle, on peut définir une variable globale h_out.
    Elle est affectée dans mandel2 lorsque le critère de sortie est vérifié, et est ensuite utilisée dans le programme principal pour générer la couleur de remplissage.
    J'aurais voulu utiliser ceci pour mettre en couleur en fonction de la valeur de h:

    pal = ['purple', 'red', 'yellow', 'blue', 'green', 'maroon', 'pink', 'orange']
    d = randrange(8)
    couleur = pal[d]
    Pour ne pas être limiter à 8 classes, il est possible de créer ses propres couleurs en fixant les composantes RGB.

  5. #5
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juin 2013
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Merci beaucoup, je n'avais pas du tout penser à faire ça

Discussions similaires

  1. calcul des zooms le la fractale de Mandelbrot
    Par Invité dans le forum Télécharger
    Réponses: 4
    Dernier message: 16/07/2013, 21h29
  2. Numpy et fractale de Mandelbrot
    Par Pierre Levy dans le forum Calcul scientifique
    Réponses: 0
    Dernier message: 08/01/2013, 10h31
  3. [2D/3D] Fractale de Mandelbrot
    Par Invité dans le forum Qt
    Réponses: 1
    Dernier message: 28/10/2010, 20h39
  4. Fractales de mandelbrot 3D
    Par sarosto dans le forum Composants VCL
    Réponses: 2
    Dernier message: 29/11/2007, 16h09
  5. Fractales de Mandelbrot
    Par LAS_184 dans le forum Delphi
    Réponses: 3
    Dernier message: 20/12/2006, 20h26

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