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

Calcul scientifique Python Discussion :

Amélioration d'un programme


Sujet :

Calcul scientifique Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2015
    Messages : 2
    Par défaut Amélioration d'un programme
    Bonjour à tous, dans le cadre d'un projet j'ai réalisé un programme python permettant de calculer l'énergie d'intéraction entre dipoles dans un quasi-réseau. Celui-ci permet de calculer cette énergie pour l'ensemble des configurations possibles (en considérant uniquement des moments up et down).

    En ce moment le programme me donne chaque configuration ainsi que l'énergie qui lui est associée or ce qui m'interresse le plus est l'état fondamental (énergie la plus faible). Je voudrais donc savoir comment il serait possible de sortir uniquement l'énergie la plus faible ainsi que les configurations qui lui correspondent.

    J'ai essayé dans un premier temps de calculer Emin = min([Energie(Matrice,C,SpinValues,Points) for C in cl]) qui me permet d'avoir la valeur de l'énergie minimale mais je n'arrive pas à savoir pour quelles valeurs de C j'obtiens celle-ci.


    Voici l'ensemble du code
    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
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    import math 
    import time
    import random
    import itertools
     
    #produit scalaire
    def prodscal(A,B):
        if len(A)==2:    #Si vecteur dans le plan, on rajoute la composante z
            A+=[0]
        if len(B)==2:    #Si vecteur dans le plan, on rajoute la composante z
            B+=[0]
        return A[0]*B[0]+A[1]*B[1]+A[2]*B[2]
     
     
    def convert(S):
        if S[2]==0:  #spins dans le plan => Angle en degres
            return round(math.degrees(math.atan2(S[1],S[0])),2)
        elif S[2]>0:       #spins hors du plan => +1 si mz positive, -1 sinon
            return +1
        else:
            return -1
     
    ###################################################################
    # Calculs d'energie
    ##############################################################
     
    def EnerInteracDip(P1,P2,val1,val2):
        dr=[P1[0]-P2[0],P1[1]-P2[1]]
        r=math.sqrt(dr[0]**2+dr[1]**2)
        return -(3*prodscal(val1,dr)*prodscal(val2,dr)/r**5-prodscal(val1,val2)/r**3)
     
    def MatInterDip(SpinValues,Points):
        q=len(SpinValues)     
        nb_spin=len(Points)   
        #Creation de la matrice de couplage
        Mat=[[[[ 0 for i in range(q)] for j in range(q)] for k in range(nb_spin)] for l in range(nb_spin)]
        for i in range(nb_spin):
            for j in range(nb_spin):
                if i!=j:
                    for k in range(q):
                        for l in range(q):
                            Mat[i][j][k][l]=EnerInteracDip(Points[i],Points[j],SpinValues[k],SpinValues[l])
        return Mat
     
    def Energie(MatCoup,Config,SpinValues,Points):
        "Calcul de l'energie de la Config (energie par spin)"
        nb_spin=len(Points)   
        E=0
        for i in range(nb_spin):
            for j in range(i):              
                E+=MatCoup[i][j][Config[i]][Config[j]]
        return E/nb_spin
     
    #Definition du reseau
     
    Points=[ [0,0], [0,1], [1,1], [1,0], [0.5,(math.sqrt(3)/2)+1], [0.5,-(math.sqrt(3)/2)] ]
     
    #Definition du type de spins
     
    SpinValues =[ [0,0,1], [0,0,-1] ]
     
    #Liste des configurations
    cl = list(itertools.product([0,1],repeat=6)) 
     
    #Creation d'une matrice qui permet ensuite de calculer l'energie
     
    Matrice=MatInterDip(SpinValues,Points)
     
    for C in cl:
        cv = [convert(SpinValues[val]) for val in C]
        E = [Energie(Matrice,C,SpinValues,Points)]
        print("Configuration=", cv,"\tEnergie=",E)
    Je vous remercie de votre aide.

  2. #2
    Membre émérite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2013
    Messages
    388
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2013
    Messages : 388
    Par défaut
    Salut et bienvenu.
    Il faut d'abord calculer l'énergie de chaque configuration et stocker le résultat. Ensuite trier l'ensemble des résultats par énergie croissante.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #Liste des configurations
    config = list()
    for C in itertools.product([0,1], repeat=6):
        cv = [convert(SpinValues[val]) for val in C]
        E = Energie(Matrice,C,SpinValues,Points)
        config.append([E] + cv)
     
    import csv, sys
    from operator import itemgetter as ig
    w = csv.writer(sys.stdout, delimiter="\t")
    w.writerows(sorted(config, key=ig(0)))

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2015
    Messages : 2
    Par défaut
    Ah génial, c'est mon premier code du coup je ne suis pas encore super à l'aise avec ce genre de fonction.
    Je vous remercie pour votre aide !

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

Discussions similaires

  1. Réponses: 41
    Dernier message: 11/07/2012, 09h42
  2. [thread] amélioration d'un programme
    Par ChipsterJulien dans le forum Débuter avec Java
    Réponses: 3
    Dernier message: 06/06/2010, 14h21
  3. programme code cesar amélioré.
    Par m-laure dans le forum C
    Réponses: 4
    Dernier message: 01/04/2007, 16h45
  4. [Tableaux] Améliorer ma façon de programmer
    Par Invité dans le forum Langage
    Réponses: 11
    Dernier message: 28/11/2006, 18h56
  5. Réponses: 2
    Dernier message: 06/05/2006, 16h09

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