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

Langage PHP Discussion :

Opérateurs : et ? dans un calcul arithmétique binaire


Sujet :

Langage PHP

  1. #1
    Membre confirmé
    Homme Profil pro
    amateur
    Inscrit en
    Octobre 2007
    Messages
    731
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur

    Informations forums :
    Inscription : Octobre 2007
    Messages : 731
    Points : 460
    Points
    460
    Par défaut Opérateurs : et ? dans un calcul arithmétique binaire
    Hello,

    J'ai la fonction suivante :

    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
    function crc64($string)
    {
    	$poly = (0xC96C5795 << 32) | 0xD7870F42;
    	$crc = 0;
    	for ( $i=0 ; $i<strlen($string) ; $i++ )
    	{
    		$byte = ord($string[$i]); // valeur ASCII du caractère
    		for( $bit=0 ; $bit<8 ; $bit++, $byte>>=1 $byte=$byte/2 )
    		{
    			$crc = (( $crc>>1 )& ~( 1<<63 )) ^ ((( $crc ^ $byte )&1 )?poly:0 );
    		}
    	}
    	return $crc;
    }
    Je n'arrive pas à trouver ce que font les opérateurs : et ? dans cette ligne. Concrêtement que réalise ?poly:0 ( Est-ce que poly vaut 0 ? )

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $crc = (( $crc>>1 )& ~( 1<<63 )) ^ ((( $crc ^ $byte )&1 )?poly:0 );
    J'ai transformé certaines opérations pour que ça soit un peu plus lisible.
    Il s'agit d'une énigme à résoudre en réalité et j'ai besoin de connaitre les entrées qui vont générer un certain CRC.
    En principe, j'ai une matrice de 20*20 qui contient des valeurs hexa représentées sur 1 octet.
    L'entrée de la matrice est M(1,1) et la sortie M(20,20), il s'agit juste de signalisation.
    Le but étant de trouver la ou les chaines d'octets partant de l'entrée de la matrice et arrivant à la sortie ( en concaténant chaque octet traversé pour atteindre la sortie ) dont le CRC vaut 0x4242424242424242.
    La méthode naïve voudrait que je calcule toutes les CRC pour trouver l'entrée qui correspond et ne plus avoir qu'à la chercher dans la matrice. ( Probablement très long ). Ou arrêter le calcul du CRC dès qu'il diffère du résultat attendu et passer au suivant.
    A savoir que j'ai 5 secondes entre le moment où la matrice est générée et le moment où je dois envoyer la réponse.
    Je trouve étonnant que le polynôme générateur vaille 1*x^0 = 1 mais je suppose que c'est pour nous faciliter la tâche.
    Avant de m'y atteler, je voulais comprendre un peu ce qu'il se passait là dedans.
    Je vais probablement recoder ceci en C.

    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
    function crc64($string)
    $poly = (0xC96C5795 << 32) | 0xD7870F42
    $poly = 1;
    $crc = 0;
    for ( $i=0 ; $i<strlen($string) ; $i++ )
    {
    	$byte = ord($string[$i]); // valeur ASCII du caractère
    	for( $bit=0 ; $bit<8 ; $bit++, $byte>>=1 )
            for( $bit=0 ; $bit<8 ; $bit++, $byte=ENT($byte/2) )
            {
    		$crc = (( $crc>>1 )& ~( 1<<63 )) ^ ((( $crc ^ $byte )&1 )?poly:0 );
                    $crc = ( ENT($crc/2) & 0x0FFFFFFF ) ^ ((( $crc ^ $byte )&1 )?poly:0 );
    	}
    	return $crc;
    }
    Merci d'avance. Cordialement.

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    il s'agit de l'opérateur ternaire (voir : Opérateurs de comparaison).

    L'expression (expr1) ? (expr2) : (expr3) est évaluée à expr2 si expr1 est évaluée à TRUE, et expr3 si expr1 est évaluée à FALSE.

    Depuis PHP 5.3, il est possible d'omettre la partie centrale de l'opérateur ternaire. L'expression expr1 ?: expr3 retourne expr1 si expr1 vaut TRUE, et expr3 sinon.

  3. #3
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Salut,

    lis ceci surtout la partie sur l'opérateur ternaire

    une version avec quelques micro-optimisations :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    function crc64($string) {
        $poly = (0xC96C5795 << 32) | 0xD7870F42;
        $crc  = 0;
        $len  = strlen($string);
        for ($i = 0 ; $i < $len ; ++$i) {
            $byte = ord($string[$i]); // valeur ASCII du caractère
            for ($bit = 0 ; $bit < 8 ; ++$bit, $byte >>= 1) {
                $crc = (($crc >> 1) & ~(1 << 63)) ^ ((($crc ^ $byte) & 1) ? $poly : 0);
            }
            return $crc;
        }
    }

  4. #4
    Membre confirmé
    Homme Profil pro
    amateur
    Inscrit en
    Octobre 2007
    Messages
    731
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur

    Informations forums :
    Inscription : Octobre 2007
    Messages : 731
    Points : 460
    Points
    460
    Par défaut
    Merci beaucoup pour ces réponses rapides =)

  5. #5
    Expert éminent Avatar de CosmoKnacki
    Homme Profil pro
    Justicier interdimensionnel
    Inscrit en
    Mars 2009
    Messages
    2 910
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Justicier interdimensionnel

    Informations forums :
    Inscription : Mars 2009
    Messages : 2 910
    Points : 6 703
    Points
    6 703
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        for ($i = 0 ; $i < $len ; ++$i) {
            $byte = ord($string[$i]); // valeur ASCII du caractère
            for ($bit = 0 ; $bit < 8 ; ++$bit, $byte >>= 1) {
                $crc = (($crc >> 1) & ~(1 << 63)) ^ ((($crc ^ $byte) & 1) ? $poly : 0);
            }
            return $crc;
        }
    Le return est bizarrement placé. Plutôt:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        for ($i = 0 ; $i < $len ; ++$i) {
            $byte = ord($string[$i]); // valeur ASCII du caractère
            for ($bit = 0 ; $bit < 8 ; ++$bit, $byte >>= 1) {
                $crc = (($crc >> 1) & ~(1 << 63)) ^ ((($crc ^ $byte) & 1) ? $poly : 0);
            }
        }
        return $crc;

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

Discussions similaires

  1. [JTree]recherche dans un arbre (non binaire ?)
    Par biozaxx dans le forum Composants
    Réponses: 3
    Dernier message: 07/05/2013, 13h32
  2. Problème dans le calcul d'éléments d'un tableau
    Par vidocq dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 28/04/2006, 13h14
  3. Erreur dans le calcul d'un score
    Par GLDavid dans le forum C++
    Réponses: 7
    Dernier message: 21/04/2006, 09h09
  4. [VB6]écriture dans un fichier: mélange binaire string.
    Par méphistopheles dans le forum VB 6 et antérieur
    Réponses: 16
    Dernier message: 28/12/2005, 12h29
  5. Problème dans le calcul des normales moyennes,
    Par MaxPayne dans le forum OpenGL
    Réponses: 1
    Dernier message: 12/04/2005, 17h50

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