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 :

Méthode de classe et copie d'objets


Sujet :

Python

  1. #1
    Candidat au Club
    Inscrit en
    Mars 2004
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 4
    Points : 2
    Points
    2
    Par défaut Méthode de classe et copie d'objets
    Bonjour à tous,

    Je suis débutant en python et j'ai un ptit problème :
    je viens de créer une classe Image et de lui ajouter une méthode qui devrait lisser l'image courante (à l'aide d'une bête moyenne).
    Le problème vient du fait que les modifications faites au sein de la classe ne semble pas être répercutés sur l'instance de celle ci ...
    Voici le code de la méthode :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    def lissage(self):
            res = copy.deepcopy(self)
            for j in range(1, self.height-2):
                for i in range(1, self.width-2):
                    val = self.getPixel(i,j)     + self.getPixel(i+1,j)   + self.getPixel(i-1,j)   +\
                          self.getPixel(i,j+1)   + self.getPixel(i,j-1)   + self.getPixel(i+1,j+1) +\
                          self.getPixel(i+1,j-1) + self.getPixel(i-1,j+1) + self.getPixel(i-1,j-1)
                    res.setPixel(i,j,val/9)
            print "Self : ", self.getPixel(109,100), ", Res  : ", res.getPixel(109,100)
            self = copy.deepcopy(res)
            print "Self : ", self.getPixel(109,100), ", Res2 : ", res.getPixel(109,100)
            self.writeToPGM("moyenne1.pgm")
    et son utilisation :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    img = Image("test.pgm")
    img.lissage()
    print "Img  : " , img.getPixel(109,100)
    img.writeToPGM("moyenne2.pgm")
    Le problème est donc que le programme me produit la sortie suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Self :  108 , Res  :  109
    Self :  109 , Res2 :  109
    Img  :  108
    on voit donc que les modifications faites au sein de la méthode ne sont pas effectives (ceci est confirmé par le fait que l'image moyenne1.pgm est bien lissée alors que moyenne2.pgm ne l'est pas ...).

    Voilà d'où pensez vous que le problème peut venir ?
    Sans doute des copies ?

    Merci d'avance

  2. #2
    Candidat au Club
    Inscrit en
    Mars 2004
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    Voici le code de ma classe Image en entier si besoin :
    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
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
     
    import string
    import copy
     
    class Image:
        """ Représente une image."""
     
        def __init__(self, w, h):
            self.width  = w
            self.height = h
            size = self.width * self.height
            for i in range(0, size - 1):
                self.data.append(255)
     
        def __init__(self, fileName):
            self.readPGM(fileName)
     
        def getId(self, i, j):
            return (self.width*i + j)
     
        def setPixel(self, i, j, val):
            self.data[self.getId(i,j)] = val
     
        def getPixel(self, i, j):
            return self.data[self.getId(i,j)]
     
        def writeToPGM(self, fileName):
            f = open(fileName,'w')
            f.write("P2\n")
            f.write("# Created with Python !\n")
            f.write(str(self.width) + " " + str(self.height) + "\n")
            f.write("256\n")
            size = self.width * self.height
            for i in range(0, size - 1):
                f.write(str(self.data[i]) + "\n")
            f.close()
     
        def readPGM(self, fileName):
            f = open(fileName, 'r')
            f.readline() # Le magic number
            f.readline() # Les commentaires        
            line = f.readline() # Les dimensions de l'image
            l = string.split(line)
            self.width  = int(l[0])
            self.height = int(l[1])
            line = f.readline()
            # Les données
            size = self.width * self.height
            self.data = []
            for i in range(0, size - 1):
                line = f.readline()
                self.data.append(int(line))
            f.close()
     
        def lissage(self):
            res = copy.deepcopy(self)
            for j in range(1, self.height-2):
                for i in range(1, self.width-2):
                    val = self.getPixel(i,j)     + self.getPixel(i+1,j)   + self.getPixel(i-1,j)   +\
                          self.getPixel(i,j+1)   + self.getPixel(i,j-1)   + self.getPixel(i+1,j+1) +\
                          self.getPixel(i+1,j-1) + self.getPixel(i-1,j+1) + self.getPixel(i-1,j-1)
                    res.setPixel(i,j,val/9)
            print "Self : ", self.getPixel(109,100), ", Res  : ", res.getPixel(109,100)
            self = copy.deepcopy(res)
            print "Self : ", self.getPixel(109,100), ", Res2 : ", res.getPixel(109,100)
            self.writeToPGM("moyenne1.pgm")

  3. #3
    Expert éminent sénior
    Avatar de Guigui_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Août 2002
    Messages
    1 864
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Août 2002
    Messages : 1 864
    Points : 10 067
    Points
    10 067
    Par défaut
    A mon avis, l'"erreur" vient de la ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    self = copy.deepcopy(res)
    self n'est plus après cette instruction égale à img (je n'en suis pas sûr du tout). Mais je regarderais plutôt de ce côté-là.

    essaie en créant toi-même la fonction copy du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    def copy(self, img):
        for i in range(img.height):
            for j in range(img.width):
                self.SetPixel(i,j,img.getPixel(i,j))
    ou plus simple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    def copy(self, img):
        self.data=list(img.data)

    puis de remplacer la ligne par:
    au passage:
    au lieu d'écrire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     for i in range(0, size - 1):
    tu peux faire
    et au lieu
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
            for i in range(0, size - 1): 
                self.data.append(255)
    tu peux faire

  4. #4
    Candidat au Club
    Inscrit en
    Mars 2004
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    Merci ça fonctionne bien.
    Je vais continuer à regarder pour essayer de bien comprendre pourquoi la copie ne fonctionnait pas.

    Merci également pour les petites astuces pour les boucles .

  5. #5
    Expert éminent sénior
    Avatar de Guigui_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Août 2002
    Messages
    1 864
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Août 2002
    Messages : 1 864
    Points : 10 067
    Points
    10 067
    Par défaut
    Citation Envoyé par Duloup
    Je vais continuer à regarder pour essayer de bien comprendre pourquoi la copie ne fonctionnait pas.
    C'est pas que la copie ne fonctionne pas, c'est que faire
    self = ... en gros recrée un objet self (donc à une nouvelle adresse mémoire), ce qui fait que lorsque tu quittes la fonction, ton objet est en fait inchangé

    Edit:
    il ne faut pas mettre le "-1" => for i in range(0, size), la borne supérieure est exclue du range. Dans tes images de test, il doit manquer une ligne à priori quand tu as sauvegardé

  6. #6
    Candidat au Club
    Inscrit en
    Mars 2004
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 4
    Points : 2
    Points
    2
    Par défaut
    Ok merci beaucoup maintenant c'est clair !

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

Discussions similaires

  1. Thread dans une classe et copie
    Par Markand dans le forum SL & STL
    Réponses: 5
    Dernier message: 31/05/2013, 23h50
  2. class qui copie un fichier vers un dossier...
    Par dimitrimm972 dans le forum Entrée/Sortie
    Réponses: 1
    Dernier message: 06/04/2006, 22h21
  3. [VB6] Copie d'objet
    Par preverse dans le forum VB 6 et antérieur
    Réponses: 12
    Dernier message: 23/08/2004, 10h04
  4. [Struts][classe Action]Mettre un objet en parametre (suite)
    Par julienOriano dans le forum Struts 1
    Réponses: 6
    Dernier message: 16/06/2004, 15h54
  5. [VB6] Copie d'objets
    Par austin49 dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 19/05/2003, 18h05

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