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

Shell et commandes GNU Discussion :

Optimiser ou changer de langage


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    211
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2007
    Messages : 211
    Par défaut Optimiser ou changer de langage
    Bonjour à tous,

    J'ai réaliser (enfin j'ai plutôt compiler les infos) un petit script avec un hash perceptuelle (Dhash) afin de reconnaitre si une image est semblable à une autre.

    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
    #!/bin/bash
    #passage des variables en dehors de la boucle while
    shopt -s lastpipe
    #recherche des images dans le répertoire
    for image in /tmp/seb/deux/test/*
            do
    #initialisation des variables
            hash=""
            i=0
    #convertir l'image et récupérer la couleur
            convert "$image" -resize 9X8\! -colorspace Gray txt:- |
            tail -n +2 | tr -cs '0-9.\n'  ' ' |
                    while read x y r g junk; do
    #algorythme DHASH
                            case $i in
                                    "0") precedent=$r
                                    ((i++));;
                                    [1-7]) if [ "$precedent" -gt "$r" ]
                                                    then hash=$hash"1"
                                                    else hash=$hash"0"
                                            fi
                                            precedent=$r
                                            ((i++));;
                                    "8") if [ "$precedent" -gt "$r" ]
                                                    then hash=$hash"1"
                                                    else hash=$hash"0"
                                            fi
                                            i=0;;
                            esac
                    done
    #calcul de la distance de Hamming entre 2 images
    distance=0
    left=$hash
    #image à comparer à :
    right="0101110100000000010110000000000000000000000000000000000000000001"
    for ((j=0; j<${#left}; j++));do
            [[ "${left:j:1}" == "${right:j:1}"  ]] || (( "distance++"))
    done
    echo "difference est ${distance}"
    done
    Le code fonctionne mais j'ai un problème de performance. Pour analyser 2800 images (qui se trouvent en mémoire vive "/tmp/ ..." ) cela me prend +/- 1m20 soit 35 images à la seconde.

    Y-a-t-il moyen optimiser cela ou dois-je changer de langage de programmation? Lequel? Le but étant que ce petit script soit le plus rapide possible.

    Bonne soirée

  2. #2
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 654
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 654
    Par défaut
    Bonjour,

    je suis surpris que le code fonctionne, car bash ne sait pas traiter les nombres décimaux.
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 347
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 347
    Par défaut
    Bonjour,

    Non, il ne traite que des entiers, mais déjà convert semble lent, faudrait déjà juste faire la boucle:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    time { for image in /tmp/seb/deux/test/* ; do convert "$image" -resize 9X8\! -colorspace Gray txt:/dev/null ; done ; }
    Et voir le temps que ça dure.

  4. #4
    Expert confirmé
    Avatar de Jipété
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    11 120
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 11 120
    Par défaut
    Citation Envoyé par sebaaas Voir le message
    Pour analyser 2800 images (qui se trouvent en mémoire vive "/tmp/ ..." ) cela me prend +/- 1m20 soit 35 images à la seconde.

    Y-a-t-il moyen optimiser cela ou dois-je changer de langage de programmation ? Lequel ? Le but étant que ce petit script soit le plus rapide possible.
    Dans ma machine il y a des images qui pèsent quelques ko et d'autres plusieurs centaines de Mo. Partant de là, tu comprends instantanément (enfin, j'espère) qu'il est absolument impossible de répondre à ces questions...

    Citation Envoyé par sebaaas Voir le message
    Optimiser ou changer de language
    Tiens, ça me fait penser qu'il faudra que je passe au guarage, j'ai un bruit bizarre dans ma bagnole...

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    211
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2007
    Messages : 211
    Par défaut
    Citation Envoyé par Jipété Voir le message
    Tiens, ça me fait penser qu'il faudra que je passe au guarage, j'ai un bruit bizarre dans ma bagnole...
    J'ai changUé :-)

    Citation Envoyé par disedorgue Voir le message
    Bonjour,

    Non, il ne traite que des entiers, mais déjà convert semble lent, faudrait déjà juste faire la boucle:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    time { for image in /tmp/seb/deux/test/* ; do convert "$image" -resize 9X8\! -colorspace Gray txt:/dev/null ; done ; }
    Et voir le temps que ça dure.
    1 minute mon capitaine, mais la machine était à froid.

    Citation Envoyé par Jipété Voir le message
    Dans ma machine il y a des images qui pèsent quelques ko et d'autres plusieurs centaines de Mo. Partant de là, tu comprends instantanément (enfin, j'espère) qu'il est absolument impossible de répondre à ces questions..
    Les images font toujours la même taille : 1,18 méga (une image BMP de 720 x 576 )

  6. #6
    Expert confirmé Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 041
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 041
    Par défaut
    Citation Envoyé par Jipété Voir le message
    En Pascal il y a les accès bas niveau par pointeur avec Scanline (en Delphi -- avec Lazarus ça s'appelle GetLineStart) , ça existe en Python ?
    difficile à dire (ça a quand même l'air d'un truc très spécifique), mais pour le dire simplement entre Pillow, Numpy, SciPy et autres OpenCV y'a beaucoup de choses qui existent en Python propres à optimiser drastiquement à la fois la longueur du code et sa vitesse d'exécution tout en restant très simple à coder, c'est probablement ce qui fait son succès actuel dans les milieux scientifiques et les domaines comme le traitement d'images et le machine learning, là il me semble qu'avec la distance de Hamming appliquée pour trouver les similarités entre deux images on est plus très loin d'une classification

  7. #7
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 347
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 347
    Par défaut
    Voici un code certainement plus rapide que ton script en shell, mais ce qui est coûteux, c'est la transformation de l'image, donc le gain ne doit pas être énorme.

    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
    #!/usr/bin/env perl
     
    use strict;
    use warnings;
    use Image::Magick;
    my @tabfile=glob("*.bmp");
    my @right=(0,1,0,1,1,1,0,1,0,0,0,0,0,0,0,0,0,1,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1);
    for (@tabfile) {
    	my $image=Image::Magick->new();
    	$image->Read($_);
    	$image->Resize("9x8\!");
    	$image->Colorspace("Gray");
    	my @left;
    	for my $j (0..7) {
    		my $c=0;
    		(my $pre , my @sd)=grep { $c++%3==0 } $image->GetPixels(y=>$j);
    		push @left,map { $c=$pre ; $pre=$_ ; $c > $_ ? "1" : "0" } @sd;
    	}
    	my $c=0;
    	for my $i (0..63) { $left[$i] == $right[$i] || $c++ }
     
    	print "Pour $_ la Différence est $c\n";
    }

  8. #8
    Expert confirmé Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 041
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 041
    Par défaut
    @disedorgue, pour l'effort (motivé de noël )

    @sebaaas, juste par curiosité, c'est vraiment pertinent une image de 8x8 grayscale issue d'une image en couleurs de taille non-spécifiée (présumée beaucoup plus grande) ? j'imagine que l'algorithme de redimensionnement lui-même doit avoir un impact assez important sur la miniature finale. est-ce qu'il y a moyen d'avoir un lot d'images tests variées et leurs miniatures respectives stp ?

    ps: bonnes fêtes de fin d'années à vous tous

  9. #9
    Expert confirmé Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 288
    Par défaut
    Bonjour

    Ne serait-ce pas le principe des empreintes ?
    Empreintes de fichier ou empreintes digitales.
    A partir d'une empreinte, on peut distinguer 2 specimens mais on ne peut pas refabriquer les specimens à partir de leurs empreintes.
    Il suffit d'utiliser une fonction irréversible pertinente.
    Voilà pourquoi il ne faut pas dire que les mots de passe sont chiffrés. On calcule juste une empreinte ...

  10. #10
    Expert confirmé Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 041
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 041
    Par défaut
    salut,

    Citation Envoyé par sebaaas Voir le message
    Y-a-t-il moyen optimiser cela ou dois-je changer de langage de programmation?
    les deux mon capitaine, il y a très certainement moyen d'optimiser, mais tu ne transformeras pas un veau en cheval de course, et si tu as besoin d'aller vite bash est un choix exécrable

    par ailleurs tu fais de drôles de manips, à savoir finalement pour chaque image (donc à minima 35x par seconde) invoquer convert pour transformer une image en sa représentation textuelle, pour au final lire les informations de chaque pixel ligne par ligne, utiliser un langage qui à la fois permet de manipuler des images directement et au niveau pixels me semblerait déjà une optimisation intéressante (à voir...)

    Python est à mon sens une alternative de choix, avis perso.

  11. #11
    Expert confirmé
    Avatar de Jipété
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    11 120
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 11 120
    Par défaut
    'lut,
    Citation Envoyé par BufferBob Voir le message
    utiliser un langage qui à la fois permet de manipuler des images directement et au niveau pixels me semblerait déjà une optimisation intéressante (à voir...)

    Python est à mon sens une alternative de choix, avis perso.
    En Pascal il y a les accès bas niveau par pointeur avec Scanline (en Delphi -- avec Lazarus ça s'appelle GetLineStart) , ça existe en Python ?

Discussions similaires

  1. Changer le language du clavier dans un textbox
    Par Msysteme dans le forum C#
    Réponses: 1
    Dernier message: 28/01/2016, 03h44
  2. Changer de language dans form1
    Par hacker59 dans le forum VB.NET
    Réponses: 6
    Dernier message: 15/09/2014, 13h12
  3. Changer le language Francais à Anglais
    Par 0x44-0x43-0x53-0x43 dans le forum Langage
    Réponses: 1
    Dernier message: 14/10/2010, 23h01
  4. Changer le Language de programmation
    Par BeepBeepVroom dans le forum InfoPath
    Réponses: 1
    Dernier message: 02/10/2009, 14h05
  5. [Migration VBA] Changer de language ou pas ?
    Par Myogtha dans le forum Windows
    Réponses: 3
    Dernier message: 20/01/2006, 14h58

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