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

C Discussion :

Optimisation de code


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre émérite
    Avatar de f-k-z
    Homme Profil pro
    Ingénieur sécurité
    Inscrit en
    Juin 2006
    Messages
    403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur sécurité
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2006
    Messages : 403
    Par défaut Optimisation de code
    Bonjour,

    Je code en C au plus proche possible de la machine et à un moment j'utilise l'instruction

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    PC2 |=  1 & ( CD >> ( 56 - PCTab[i] ) )  ;
    sous valgrind, le profiler lui donne un fort taux d'utilisation de temps de calcul.
    Pensez vous que cela soit améliorable ?

    Cordialement,

    F-k-z

  2. #2
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    PC2 |=  1 & ( CD >> ( 56 - PCTab[i] ) )  ;
    Le temps d'exécution est dû aux décalages.
    je suppose que cette instruction est dans une boucle et que CD est un entier long long (64 bits)
    Tu peux envisager de les remplacer par une tabulation préalable. Par exemple, quelque chose du genre (non testé) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    unsigned long long SelectBit[57];
    SelectBit[56] = 1;
    for(i=55; i>=0;i--) SelectBit[i] = SelectBit[i+1]<<1; 
    ....
    if( (SelectBit[PCTab[i]] & CD) !=0) PC2 |= 1;

  3. #3
    Membre émérite
    Avatar de f-k-z
    Homme Profil pro
    Ingénieur sécurité
    Inscrit en
    Juin 2006
    Messages
    403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur sécurité
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2006
    Messages : 403
    Par défaut
    Yop,

    Merci pour ta solution, mais si je ne me trompe pas, la fonction if() est très gourmande en ressources processeur nan ?
    Sinon effectivement CD est sur 64bits et se trouve bien dans la boucle suivante:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    	for (i = 0; i<48; i++){
    		PC2 <<=1;
    		PC2 |=  1 & ( CD >> ( 56 - PCTab[i] ) )  ;
    	}
    Cordialement,

    F-k-z

  4. #4
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    si je ne me trompe pas, la fonction if() est très gourmande en ressources processeur nan ?
    if n'est pas une fonction mais une instruction. Elle n'est pas spécialement gourmande.
    Ce qui te coutes cher c'est, à mon avis, le nombre élevé de décalages opérés à chaque tour de boucle.

  5. #5
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par f-k-z Voir le message
    Merci pour ta solution, mais si je ne me trompe pas, la fonction if() est très gourmande en ressources processeur nan ?
    Non (si l'expression n'est pas complexe).

  6. #6
    Membre Expert Avatar de nicolas.sitbon
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2 015
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2 015
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    Non (si l'expression n'est pas complexe).
    Il parle au niveau processeur, effectivement, les instructions de branchement ont un cout surtout si la prédiction de branche à merder, néanmoins, c'est de la micro optimisation que tu fais, et le fait que tu utilises cachegrind montre que tu n'as pas les compétences pour cela. Oublie ces histoires d'optimisations pour le moment, fais les choses dans l'ordre:
    - apprend l'algorithmie
    - apprend l'architecture des machines
    - apprend l'assembleur
    - apprend le C
    - apprend à utiliser un véritable outil de profilage comme vtune.

    Bon courage.
    Cordialement.

  7. #7
    Membre émérite
    Avatar de f-k-z
    Homme Profil pro
    Ingénieur sécurité
    Inscrit en
    Juin 2006
    Messages
    403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur sécurité
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2006
    Messages : 403
    Par défaut
    Yop,

    @Diogene et Emmanuel Delahaye: Merci pour les informations.

    @nicolas.sitbon :
    - apprend l'algorithmie
    - apprend l'architecture des machines
    - apprend l'assembleur
    - apprend le C
    Sur 5 lignes de codes, qu'est-ce qui te permet de dire que je ne connais, ni l'algorithmie, ni l'architecture des machines, ni l'assembleur, ni le C ???
    - apprend à utiliser un véritable outil de profilage comme vtune.
    Merci pour cette réponse, car j'avais posé la question sur le post suivant afin de savoir quel outil de profilage utiliser: http://www.developpez.net/forums/d76...ons-profilers/

    Cordialement,

    F-k-z

Discussions similaires

  1. optimiser le code d'une fonction
    Par yanis97 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 15/07/2005, 08h41
  2. Optimiser mon code ASP/HTML
    Par ahage4x4 dans le forum ASP
    Réponses: 7
    Dernier message: 30/05/2005, 10h29
  3. optimiser le code
    Par bibi2607 dans le forum ASP
    Réponses: 3
    Dernier message: 03/02/2005, 14h30
  4. syntaxe et optimisation de codes
    Par elitol dans le forum Langage SQL
    Réponses: 18
    Dernier message: 12/08/2004, 11h54
  5. optimisation du code et var globales
    Par tigrou2405 dans le forum ASP
    Réponses: 2
    Dernier message: 23/01/2004, 10h59

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