# ~*~ encoding: utf-8 ~*~ # ########################### # TRAITEMENT D'IMAGES # ########################### # classes from BMPFile import * from Noise import * from tests import * import random import sys from os import system as sh import time # test par défaut puis quitte # defaultTest(); # exit(); # arrêt si moins de 2 arguments if len(sys.argv) < 3: print "Require 2 args : \n* input image\n* output image" exit() ################" INTERFACE "################### def interfaceLoop(): sh('clear'); print "+---------------------------+" print "| |" print "| TRAITEMENT D'IMAGE |" print "| |" print "+---------------------------+" print "| %s |" % exactLength( sys.argv[1], 21, -1) print "| %s |" % exactLength( sys.argv[2], 21, -1) print "+---------------------------+" print "| %s |" % exactLength("TESTS DE FICHIER", 25, 0) print "| %s |" % exactLength("", 25, 0) print "| 0) %s |" % exactLength("Creation manuelle", 21, -1) print "| 1) %s |" % exactLength("Parse/Unparse", 21, -1) print "| 2) %s |" % exactLength("Afficher palette", 21, -1) print "+---------------------------+" print "| %s |" % exactLength("TESTS DE BRUIT", 25, 0) print "| %s |" % exactLength("", 25, 0) print "| 10) %s |" % exactLength("Salt&Pepper", 21, -1) print "| 11) %s |" % exactLength("Additif (Bernouilli)", 21, -1) print "| 12) %s |" % exactLength("Additif (Gaussien)", 21, -1) print "+---------------------------+" print "| %s |" % exactLength("TESTS DE DIFFERENCES", 25, 0) print "| %s |" % exactLength("", 25, 0) print "| 20) %s |" % exactLength("Difference en %", 21, -1) print "| 21) %s |" % exactLength("SNR (origine/bruit)", 21, -1) print "| 22) %s |" % exactLength("Difference en image", 21, -1) print "| 23) %s |" % exactLength("Fusion d'images (+)", 21, -1) print "| 24) %s |" % exactLength("Fusion d'images (-)", 21, -1) print "+---------------------------+" print "| %s |" % exactLength("TESTS DE FORMES", 25, 0) print "| %s |" % exactLength("", 25, 0) print "| 30) %s |" % exactLength("Reveler une teinte", 21, -1) print "| 31) %s |" % exactLength("Colorer une forme", 21, -1) print "| 32) %s |" % exactLength("Colorer les formes", 21, -1) print "| 33) %s |" % exactLength("Relever les contours", 21, -1) print "+---------------------------+" print "| %s |" % exactLength("TESTS DE FILTRES", 25, 0) print "| %s |" % exactLength("", 25, 0) print "| 40) %s |" % exactLength("Filtre moyen", 21, -1) print "| 41) %s |" % exactLength("Laplace", 21, -1) print "| 42) %s |" % exactLength("Roberts", 21, -1) print "| 43) %s |" % exactLength("Prewitt", 21, -1) print "| 44) %s |" % exactLength("Sobel", 21, -1) print "| 45) %s |" % exactLength("Convolution", 21, -1) print "| 46) %s |" % exactLength("bichrome", 21, -1) print "| 47) %s |" % exactLength("Passe Haut", 21, -1) print "+---------------------------+" print while True: action = int( raw_input("choix: ") ) if action >= 0 and action < 50: break; startStr = "\n+---------------------------+---------+" result = "" execTime = Timer(); execTime.reset(); # fichier if action == 0: w = raw_input("width [100]: ") h = raw_input("height [100]: ") arg1, arg2 = 100, 100 if w != "": arg1 = int(w) if h != "": arg2 = int(h) print startStr testManualCreation(image1, arg1, arg2) # teste la création d'un fichier à partir d'une matrice uniquement elif action == 1: print startStr result = testFileIntegrity(image1) # teste le PARSE/UNPARSE elif action == 2: print startStr result = printIntPalette(image1) # affiche la palette d'une image # bruits elif action == 10: inS = raw_input("seuil bruitage [50]: ") outS = raw_input("seuil débruitage [1] : ") outB = raw_input("borne débruitage [1] : ") s = raw_input("Lissage ? (0-1): ") arg1, arg2, arg3, arg4 = 50, 1, 1, 1 if inS != "": arg1 = int(inS) if outS != "": arg2 = int(outS) if outB != "": arg3 = int(outB) if s != "": arg4 = int(s) print startStr testSaltAndPepper(image1, arg1, arg2, arg3, arg4) # teste le bruitage/débruitage de type "Sel & Poivre" elif action == 11: inS = raw_input("seuil bruitage [10]: ") outS = raw_input("seuil débruitage [5] : ") arg1, arg2 = 10, 5 if inS != "": arg1 = int(inS) if outS != "": arg2 = int(outS) print startStr testAdditiveBernouilliNoise(image1, arg1, arg2) # teste le bruitage/débruitage de type "Additif" elif action == 12: inS = raw_input("sigma [10]: ") outS = raw_input("seuil débruitage [1] : ") arg1, arg2 = 10, 1 if inS != "": arg1 = int(inS) if outS != "": arg2 = int(outS) print startStr testAdditiveGaussianNoise(image1, arg1, arg2) # teste le bruitage/débruitage de type "Additif" # performances elif action == 20: print startStr printImageQuality(image1, image2) # compare 2 images et donne le pourcentage de ressemblance/différence elif action == 21: print startStr printSNR(image1, image2) # compare 2 images et retourne le SNR elif action == 22: print startStr imageForImageQuality(image1, image2) # crée une image correspondant aux différences de 2 images elif action == 23: print startStr mergeImagesAdditive(image1, image2) # crée une image étant la fusion (addition) de 2 images elif action == 24: print startStr mergeImagesSubstractive(image1, image2) # crée une image étant la fusion (soustractive) de 2 images elif action == 30: r = raw_input("rouge [0]: ") g = raw_input("vert [0]: ") b = raw_input("bleu [0]: ") s = raw_input("seuil [50]: ") arg1, arg2, arg3, arg4 = 0,0,0,50 if r != "": arg1 = int(r) if g != "": arg2 = int(g) if b != "": arg3 = int(b) if s != "": arg4 = int(s) print startStr revealShapes(image1, arg1, arg2, arg3, arg4) # révèle la couleur spécifiée elif action == 31: x = raw_input("abscisses(x) [0]: ") y = raw_input("ordonnées(y) [0]: ") arg1, arg2 = 0,0 if x != "": arg1 = int(x) if y != "": arg2 = int(y) print startStr colorShape(image1, arg1, arg2) # colorie la forme contenant le pixel de coordonnées donné elif action == 32: print startStr colorAllShapes(image1) # colorie la forme contenant le pixel de coordonnées donné elif action == 33: print startStr testStroke(image1) # trace les contours uniquement à partir de formes pleines # filtres elif action == 40: print startStr testAverageFilter(image1) # teste le lissage elif action == 41: print startStr testLaplace(image1) # teste le filtre de Laplace elif action == 42: print startStr testRoberts(image1) # teste le filtre de Roberts elif action == 43: print startStr testPrewitt(image1) # teste le filtre de Prewitt elif action == 44: print startStr testSobel(image1) # teste le filtre de Sobel elif action == 45: print startStr testConvolution(image1) # teste le filtre de Convolution elif action == 46: print startStr testBichrome(image1) # teste le passage au bichromatique elif action == 47: print startStr testHighPass(image1) # teste le filtre passe haut else: print "Wrong choice" exit(); print "+---------------------------+---------+" print "| EXECUTION TIME | %s |" % execTime.get() print "+---------------------------+---------+" print print result print '- [PRESS ANY KEY TO CONTINUE] -'; print '- [ BUT PRESS "Q" TO QUIT ] -'; print '- [ OR PRESS "R" TO RELOAD ] -'; print '- [ OR PRESS "S" TO SAVE ] -'; loopKey = raw_input(': '); if( loopKey == 'q' or loopKey == 'Q' ): exit(); elif( loopKey == 'r' or loopKey == 'R' ): loadFiles(); elif( loopKey == 's' or loopKey == 'S' ): out = raw_input("out file: "); image1.unparse(); image1.write(out); interfaceLoop(); ################" EXECUTABLE "################### sh('clear'); print "+---------------------------+" print "| |" print "| CHARGEMENT... |" print "| |" print "+---------------------------+" # ON CREE LES IMAGES image1, file1 = BMPFile(True), ""; image2, file2 = BMPFile(), ""; with open( sys.argv[1] ) as file: file1 += file.read(); try: with open( sys.argv[2] ) as file: file2 += file.read() except Exception as e: print e; def loadFiles(): image1.parse( file1 ); for line in image1.content.map: for pix in line: image1.drawer.setPixel( pix ); image1.drawer.refresh(); if( file2 != "" ): image2.parse( file2 ); loadFiles(); interfaceLoop();