Modifications entre les versions 7 et 9 (s'étendant sur 2 versions)
Version 7 à la date du 2013-12-11 12:47:30
Taille: 2406
Éditeur: 178
Commentaire:
Version 9 à la date du 2013-12-11 13:44:36
Taille: 3356
Éditeur: 178
Commentaire:
Texte supprimé. Texte ajouté.
Ligne 9: Ligne 9:
 * [[attachment:pinklady-petit.ppm]], le même en petit format (20 par 20 pixels);
Ligne 45: Ligne 46:

== Exercice 1: rotation de 180° ==

Écrire une fonction '''retourner''' qui prend en argument une image décrite selon la structure ci-dessus et renvoie une nouvelle image qui est la même mais retournée à 180 degrés. On pourra donc voir la pomme retournée en faisant:

{{{#!highlight python
import pnm
avant = pnm.lire_pnm("pinklady-ascii.ppm")
apres = retourner(avant)
pnm.afficher_ppm(apres)
}}}

== Exercice 2: écriture au format PPM ASCII ==

Écrire une fonction '''ecrire_ascii''' qui prend en argument une image et un nom de fichier et produit un fichier au format PPM textuel pour cette image. Pour tester, vous pouvez vérifier que ceci affiche la pomme:

{{{#!highlight python
import pnm
avant = pnm.lire_pnm("pinklady-ascii.ppm")
ecrire_ascii(avant, "test.ppm")
apres = pnm.lire_pnm("test.ppm")
pnm.afficher_ppm(apres)
}}}

TP : structures de données et images

C’est la séance 1B2 de la formation 2013-2014.

Il s'agit de manipuler à la main (en Python) des structures de données pour représenter des images. On va suivre le format d'image PNM, qui est assez simple pour tout faire soi-même.

Pour référence:

  • pinklady-ascii.ppm, un fichier d'exemple;

  • pinklady-petit.ppm, le même en petit format (20 par 20 pixels);

  • pnm_v2.py, une implémentation de toutes les opérations sur ce format que l'on évoque dans la suite (mais le but est de le faire vous-mêmes).

Vous pouvez utiliser les fonctions définies dans ce fichier en le renommant pnm.py et en commençant par importer le module:

   1 import pnm

Structure de donnée utilisée

On va tout représenter avec les structures de données élémentaires de Python: nombres, chaînes de caractères, listes, dictionnaires.

Une image est représentée par un dictionnaire contenant les entrées suivantes:

  • format est une chaîne de caractères, dont la valeur peut être

    • couleur pour une image en couleurs (on utilisera principalement ce cas-là)

    • gris pour une image en niveaux de gris

    • bitmap pour une image en noir et blanc

  • largeur est un entier qui indique le nombre de pixels en largeur

  • hauteur est un entier qui indique le nombre de pixels en hauteur

  • donnees est une liste contenant les valeurs des pixels, en fonction du format

    • pour couleur, chaque pixel correspond à 3 valeurs, pour les trois composantes rouge, vert, bleu; le pixel de coordonnées (x,y) commence donc à l'indice (largeur×y+x)×3

    • pour gris, chaque pixel correspond à une valeur qui est son niveau de gris

    • pour bitmap, huit pixels consécutifs correspondent à une valeur du tableau (un bit par pixel)

Le module pnm fournit en particulier les fonctions suivantes:

  • pnm.lire_pnm(nom_fichier) lit un fichier et renvoie la structure de données associée

  • pnm.afficher_ppm(image) affiche une image (supposée être au format couleur) dans une fenêtre Tkinter

Le programme suivant doit afficher l'image d'exemple, en supposant que les deux fichiers sont dans le même répertoire:

   1 import pnm
   2 i = pnm.lire_pnm("pinklady-ascii.ppm")
   3 pnm.afficher_ppm(i)

Exercice 1: rotation de 180°

Écrire une fonction retourner qui prend en argument une image décrite selon la structure ci-dessus et renvoie une nouvelle image qui est la même mais retournée à 180 degrés. On pourra donc voir la pomme retournée en faisant:

   1 import pnm
   2 avant = pnm.lire_pnm("pinklady-ascii.ppm")
   3 apres = retourner(avant)
   4 pnm.afficher_ppm(apres)

Exercice 2: écriture au format PPM ASCII

Écrire une fonction ecrire_ascii qui prend en argument une image et un nom de fichier et produit un fichier au format PPM textuel pour cette image. Pour tester, vous pouvez vérifier que ceci affiche la pomme:

   1 import pnm
   2 avant = pnm.lire_pnm("pinklady-ascii.ppm")
   3 ecrire_ascii(avant, "test.ppm")
   4 apres = pnm.lire_pnm("test.ppm")
   5 pnm.afficher_ppm(apres)

WikISN: TP format PNM (dernière édition le 2016-03-01 13:25:51 par LionelVaux)