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

Python Discussion :

Instabilité script Python


Sujet :

Python

  1. #1
    Membre averti
    Homme Profil pro
    Ingénieur Mécanique Fluides
    Inscrit en
    Janvier 2024
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur Mécanique Fluides
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2024
    Messages : 20
    Par défaut Instabilité script Python
    Bonjour à tous,
    Je me suis récemment mis au Python pour des besoins pros (ingénieur en thermohydraulique). Il s’avère en effet que j'ai un grand nombre de simulations à réaliser et j'ai pensé utiliser un script python pour automatiser tout cela. Pour fixer les idées, j'ai un modèle 3D et je dois résoudre quelques 2000 (!!!) simulations thermiques (FEA) sur ce modèle en faisant varier plusieurs paramètres impactant les conditions aux limites. A cet effet, j'utilise un code python, pyNukiyama, qui me fournit les conditions aux limites à imposer aux bords de ma simulation avec un triplet donné (Vitesse_eau, Pression_eau, Temp_eau). Tout marche, donc super ! Oui mais, le code est instable...
    Je veux dire par là, lorsque je lance la simulation (pour 250 calculs à réaliser par exemple), elle plante au bout de quelques calculs (après l'avoir lancé et relancé, le nombre semble varier de manière aléatoire 10 à 80 calculs...). Je pense que personne ici ne sera spécialiste de Ansys Mechanical (enfin peut-être que si avec de la chance !). Cependant, codant sur Python depuis 2024 (et oui un mois déjà !) je me dis qu'il y a peut-être (sans doutes !) de grosses fautes de codage qui peuvent expliquer cette instabilité...

    Voici le 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
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    import os
    import sys
    import logging
    import csv
    sys.path.append(os.getcwd()+"\\pyNukiyama") #Je spécifie le chemin de pyNukiyama afin que le programme le trouve
    import pyNukiyama #j'importe pyNukiyama pour l'utiliser aprés
    #ensuite je vais importer un certains nombre de modules me permettant d'appeler Ansys Mechanical dans le script
    from ansys.mechanical.core import App
    from ansys.mechanical.core.embedding.logger import (Configuration,Logger)
    Configuration.configure(level=logging.WARNING,to_stdout=True)
    app = App(version=232)
    print(app)
    Logger.error("message")
     
    # Extract the global API entry points (available from built-in Mechanical scripting)
    from ansys.mechanical.core import global_variables
    # Merge them into your Python global variables
    globals().update(global_variables(app))
     
    #Ici je charge le fichier sur lequel je travail
    filenameMechDb = r"D14_Cu.mechdat"
    filepath = r"C:\Users\...\Documents\pyNukiNical"
    filepathMechDb = os.path.join(filepath,filenameMechDb)
     
    #Je peux enfin ouvrir le fichier de travail dans l'environnement Ansys Mechanical chargé
    ExtAPI.DataModel.Project.Open(filepathMechDb)
     
    #Je déclare les listes vides dont je vais avoir besoin
    V=[]
    iV=[]
    P=[]
    iP=[]
    T=[]
    iT=[]
    Flux=[]
     
    Tmin = 10 #Je défini ma température min pour pyNukiyama
    Tmax = 350 #Je défini ma température max pour pyNukiyama
    Geom = "s" #s pour tube lisse
    Diam = 0.014 #Diamétre hydraulique en m
     
    #Je charge mes données d'entrées enregistrées dans le document Inputs.csv
    with open('Inputs.csv') as fichier_csv:
        reader = csv.DictReader(fichier_csv, delimiter=';')
        for ligne in reader:
            V.append(float(ligne['Vwater']))
            iV.append(float(ligne['iVwater']))
            P.append(float(ligne['Pwater']))
            iP.append(float(ligne['iPwater']))
            T.append(float(ligne['Twater']))
            iT.append(float(ligne['iTwater']))
            Flux.append(float(ligne['Flux']))
     
    #Je prépare les listes pour les résultats
    Resultats = []
    Resultats.append(["Vitesse eau m/s", "Pression eau Bar", "Temp eau C", "Flux Thermique Impose W/m^2","TC1 C", "TC2 C", "TC3 C", "Flux chaleur max paroi mouillee en W/m²", "Temp surface mouillee max C", "Temp surface chauffee max en C", "Temp surface chauffee min en C"])
    Resultats_final=[]
    Resultats_final.append(["V [m/s]","P [bars]", "T [C]", "Flux [W/m^2]","Max TC1 [C]","Max TC2 [C]","Max TC3 [C]", "Min TC1 [C]","Min TC2 [C]","Min TC3 [C]"])
     
    Compteur = 0
     
    for Vwater, iVwater, Pwater, iPwater, Twater, iTwater, Flux_Thermique in zip(V, iV, P, iP, T, iT, Flux):
        TC1=[]
        TC2=[]
        TC3=[]
        for Veau in [Vwater-iVwater, Vwater+iVwater]:
            for Peau in [Pwater - iPwater, Pwater + iPwater]:
                for Teau in [Twater - iTwater, Twater + iTwater]:
     
                    # je vais charger nukiyama avec les données spécifiées juste avant
                    nuki = pyNukiyama.pyNukiyama(Geom, Diam, 0, 0, 0, 0, 0, 0, Diam, Teau, Peau, Veau, Tmin, Tmax)
                    #On peut réaliser les calculs nécessaires avec nuki bien définie
                    nuki.waterParameters()
                    nuki.siederTate()
                    nuki.berglesRohsenhow()
                    nuki.CHF()
     
                    convData = []
     
                    convData.append([Veau,Peau,Teau]) #On stocke les grandeurs thermohydrauliques en en-tête des données de convection
     
                    for i in range(len(nuki.Tw_cut)):
                        Wall_temperature = nuki.Tw_cut[i]
                        H_value = nuki.hTot_cut[i]
                        Unit = "W m^-1 m^-1 C^-1"
                        convData.append([Wall_temperature, H_value, Unit])
     
                    #On spécifie le nombre de coeurs pour le calcul, attention à ne pas dépasser le nombre dispo sinon ça foire 
                    config=ExtAPI.Application.SolveConfigurations["Mon poste de travail"]
                    config.SolveProcessSettings.MaxNumberOfCores=12
     
                    #D'abord on rentre la température initiale pour le solveur pseudo-transient, je la met égale à la température de l'eau en entrée    
                    Anal = DataModel.Project.Model.Analyses[0]
                    Anal.Children[0].InitialTemperatureValue = Quantity(float(convData[0][2]), "C")
     
                    # On remplit ensuite la partie convection
                    Anal.Children[2].AmbientTemperature.Output.SetDiscreteValue(0,Quantity(float(convData[0][2]), "C")) #Ici on rentre la température moyenne du fluide, idem à la valeur de la température initiale du solveur
     
                    #On commence par initialiser la matrice de convection avec les bonnes dimensions pour la remplir ensuite...
                    #Penser au -1 pour tenir compte du fait que l'en tête contient les données thermohydrauliques
                    #Par ailleurs, j'ajoute 1000 à la valeur entrée pour que le remplissage se passe sans encombres dans la prochaine étape (Mechanical trie automatiquement par ordre T° croissante les valeurs de convection ce qui pose problème au moment du remplissage de manière croissante)
                    Anal.Children[2].FilmCoefficient.Inputs[0].DiscreteValues = [Quantity(i+1000, "C") for i in range(len(convData)-1)] 
     
     
                    #Et on remplit les valeurs la température et le coefficient de convection associé...
                    for i in range(1,len(convData)):
                       Anal.Children[2].FilmCoefficient.Inputs[0].SetDiscreteValue(i-1, Quantity(float(convData[i][0]), "C"))
                       Anal.Children[2].FilmCoefficient.Output.SetDiscreteValue(i-1, Quantity(float(convData[i][1]), convData[i][2]))
     
                    #On rentre la valeur de flux incident 
                    Anal.Children[3].Magnitude.Output.SetDiscreteValue(0, Quantity(float(Flux_Thermique), "W m^-1 m^-1"))
     
                    # On résout leproblème désormais bien posé
                    Anal.Solve()
     
                    Temp_Paroi_Mouillee_Max = DataModel.GetObjectsByName("Temp_Paroi_Mouillee")[0].Maximum
                    Temp_Paroi_Mouillee_Min = DataModel.GetObjectsByName("Temp_Paroi_Mouillee")[0].Minimum
                    Flux_Chaleur_Paroi_Max = DataModel.GetObjectsByName("Flux de chaleur total")[0].Maximum
                    Flux_Chaleur_Paroi_Min = DataModel.GetObjectsByName("Flux de chaleur total")[0].Minimum
                    Temp_Surface_Max = DataModel.GetObjectsByName("Temp Surface")[0].Maximum
                    Temp_Surface_Min = DataModel.GetObjectsByName("Temp Surface")[0].Minimum
     
                    if Flux_Chaleur_Paroi_Max.Value>=nuki.wchf or Temp_Paroi_Mouillee_Max.Value>=nuki.tchf:
                        break
     
                    #On peut ensuite récupérer les données qui nous interessent !
                    TC1.append(DataModel.GetObjectsByName("TC1")[0].MaximumTemperature.Value)
                    TC2.append(DataModel.GetObjectsByName("TC2")[0].MaximumTemperature.Value)
                    TC3.append(DataModel.GetObjectsByName("TC3")[0].MaximumTemperature.Value)
     
     
                    Resultats.append([Veau,Peau,Teau,Flux_Thermique,DataModel.GetObjectsByName("TC1")[0].MaximumTemperature.Value,DataModel.GetObjectsByName("TC2")[0].MaximumTemperature.Value,DataModel.GetObjectsByName("TC3")[0].MaximumTemperature.Value,Flux_Chaleur_Paroi_Max.Value, Temp_Paroi_Mouillee_Max.Value, Temp_Surface_Max.Value, Temp_Surface_Min.Value])
     
                    with open(f'Resultats_Complets.csv', 'w', newline='') as fichier_resultats:
                        writer = csv.writer(fichier_resultats, delimiter=',')
                        writer.writerows(Resultats) 
     
                    Compteur = Compteur + 1
                    print(Compteur)
     
        Resultats_final.append([Vwater, Pwater, Twater, Flux_Thermique, max(TC1), max(TC2), max(TC3), min(TC1), min(TC2), min(TC3)])
     
        with open(f'Resultats.csv', 'w', newline='') as fichier_resultats:
            writer = csv.writer(fichier_resultats, delimiter=',')
            writer.writerows(Resultats_final)
    Code executé avec Spyder 5.5.0 et Python 3.8.10.
    Globalement, lorsque ça plante, deux types de messages apparaissent (pas en même temps !):
    - fatal python error: aborted (puis une référence au kernel de Python)
    - windows fatal exception : access violation


    Merci !
    Pierre

  2. #2
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Bonjour

    Une lecture en diagonale ne me fait pas ressortir de fautes graves. Des maladresses due à un manque de connaissances mais ça ne me parait pas fatal.

    Quelques détail
    • ne pas utiliser "\\" pour tes chemins. Tu as os.path.sep qui contient le séparateur de ton os
    • os.getcwd() c'est l'endroit où tu te trouves, qui n'est pas forcément le même que celui où se trouve le dossier pyNukiyama. Ce dossier semble être placé par rapport au script donc vaut mieux utiliser l'emplacement du script (variable "__file__") pour repérer le dossier pyNukiyama. Et tu as pathlib qui t'offre une gestion de chemins bien plus puissante (moi aussi j'ai hésité au début car ça me semblait fastidieux à apprendre mais ensuite je n'ai pas du tout regretté) => sys.path.append(str(pathlib.Path(__file__).parent/ "pyNukiyama")) (et le "/" n'est pas une erreur, c'est bien une division mathématique mais réécrite dans pathlib pour y associer des chemins selon le séparateur de l'os). Il en ira de même avec filepath qui peut s'écrire comme pathlib.Path.home() / "Documents" / "pyNukiNical".
    • jouer avec les globals c'est bien souvent une solution de facilité qu'on paye au centuple par la suite (peut-être le payes-tu déjà justement)
    • Resultats est un tableau mais il ne contient qu'un élément
    • tu peux remplacer for i in range(len(nuki.Tw_cut)): travail(nuki.Tw_cut[i]) par for x nuki.Tw_cut: travail(x)
    • ton code est monolithique ce qui n'aide pas à identifier l'origine du souci. Le découper en fonctions élémentaires permettrait de mieux trouver (chaque fonction pourrait être testée individuellement). Une hypothèse pourrait être qu'il y a trop de données pour ton système (je pense à ça en voyant Anal.Solve() style "on lui bourre bien la tronche puis on lui demande de digérer le tout et justement il ne digère pas)
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  3. #3
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 736
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 736
    Par défaut
    Citation Envoyé par PierreLCV Voir le message
    Code executé avec Spyder 5.5.0 et Python 3.8.10.
    Globalement, lorsque ça plante, deux types de messages apparaissent (pas en même temps !):
    - fatal python error: aborted (puis une référence au kernel de Python)
    - windows fatal exception : access violation
    Déjà, on lance son code depuis un terminal et pas depuis son IDE (car ça ajoute des problèmes).

    Après côté erreurs, ça semble être des accès mémoire interdits. Du coup, ce n'est pas dans le code Python mais dans les bibliothèques compilées qui sont utilisées (il y a du boulot pour savoir quoi est qui).

    Probable que ce soit Ansys Mechanical. Mais si on fait cette hypothèse, il faudrait trouver un forum où trainent les expertises qui utilisent ce logiciel pour savoir si vous l'utilisez mal ou s'il y a un problème (bug) connu ou a rapporter aux developpeurs.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  4. #4
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 061
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 061
    Par défaut
    Oui je dirais à la vue des erreurs la même chose que wiztricks, voir du côté des forums Ansys Mechanical

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    globals().update(global_variables(app))
    ça c'est dangereux, il est possible qu'on écrase des variables déjà existantes et utiles au bon fonctionnement du code.

    Tu peux aussi utiliser un debugger léger comme pdb pour faire des arrêts sur le programme en cours pour relever des doutes sur certaines valeurs de variables, ou autres questionnement...

  5. #5
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 736
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 736
    Par défaut
    Citation Envoyé par fred1599 Voir le message
    ça c'est dangereux, il est possible qu'on écrase des variables déjà existantes et utiles au bon fonctionnement du code.
    C'est probablement directement recopié d'un tuto Ansys Mechanical (le débutant Python connaît rarement globals()). Ca veut aussi dire un code écrit par un débutant qui n'a aucune idée de ce qui peut être important ou pas côté Ansys Mechanical (d'où l'intérêt d'aller demander de l'aide dans un forum ad hoc...)

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  6. #6
    Membre averti
    Homme Profil pro
    Ingénieur Mécanique Fluides
    Inscrit en
    Janvier 2024
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur Mécanique Fluides
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2024
    Messages : 20
    Par défaut
    Chers Sve@r, wiztricks & fred1599,
    Tout d'abord, merci beaucoup pour vos retours ! Décidément, la communauté developpez.net est très active, c'est d'un grand secours.
    Pour en revenir au sujet, le code que j'ai présenté juste avant se base sur une volonté d'Ansys d'ouvrir ses programmes de simulations à Python. Plus précisément, il utilise pyMechanical (version 0.10) qui permet d'appeler les fonctions de Mechanical depuis un code Python. Comme l'a très bien souligné wiztricks, toute la partie du code appelant les objets Ansys, provient de la documentation de pyMechanical (assez succincte il faut le dire : https://mechanical.docs.pyansys.com/version/stable/)
    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
    from ansys.mechanical.core import App
    from ansys.mechanical.core.embedding.logger import (Configuration,Logger)
    Configuration.configure(level=logging.WARNING,to_stdout=True)
    app = App(version=232)
    print(app)
    Logger.error("message")
     
    # Extract the global API entry points (available from built-in Mechanical scripting)
    from ansys.mechanical.core import global_variables
    # Merge them into your Python global variables
    globals().update(global_variables(app))
     
    #Ici je charge le fichier sur lequel je travail
    filenameMechDb = r"D14_Cu.mechdat"
    filepath = r"C:\Users\...\Documents\pyNukiNical"
    filepathMechDb = os.path.join(filepath,filenameMechDb)
     
    #Je peux enfin ouvrir le fichier de travail dans l'environnement Ansys Mechanical chargé
    ExtAPI.DataModel.Project.Open(filepathMechDb)
    Globalement, le code étant en mesure de réaliser un nombre aléatoire de simulations (globalement de 5 à 80, sans changer les inputs), je pensais qu'il pouvait y avoir quelque chose d'évident pouvant expliquer cette instabilité. Cette hypothèse étant éliminée, je vais pouvoir essayer d'appliquer vos conseils pour améliorer le code. Sait on jamais, peut-être cela suffira t'il à résoudre le problème. J'ai posé la question à Ansys, le seul problème étant que la partie pyAnsys n'est pas supportée et donc nous en sommes réduits à l'utilisation de forums...

    Merci beaucoup de votre aide et bonne journée,
    Pierre

  7. #7
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 736
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 736
    Par défaut
    Citation Envoyé par PierreLCV Voir le message
    Globalement, le code étant en mesure de réaliser un nombre aléatoire de simulations (globalement de 5 à 80, sans changer les inputs), je pensais qu'il pouvait y avoir quelque chose d'évident pouvant expliquer cette instabilité.
    Pas grand monde pratiquant le logiciel...
    Ceci dit en llisant la documentation que vous avez pointée (et sans tout comprendre) ça parle d'une mouture embedded (ça dialogue avec une DLL) et d'une mouture remote (ça dialogue avec un serveur).
    Peut être que trouner la version serceur donnerait des erreurs plus exploitables (ou fonctionnera sans problème).

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  8. #8
    Membre averti
    Homme Profil pro
    Ingénieur Mécanique Fluides
    Inscrit en
    Janvier 2024
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur Mécanique Fluides
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2024
    Messages : 20
    Par défaut
    Cher wiztricks,
    Tout d'abord, merci pour votre retour !
    J'ai suivi vos conseils et j'ai lancé le code depuis ma console windows et il apparait que cette fois ci, j'ai quelques messages d'erreurs :
    Nom : error.png
Affichages : 131
Taille : 81,6 Ko
    Les erreurs que l'on voit dans le fond sont des messages qui apparaissent pendant que le code tourne (est-ce lié au crash final ?? en tout cas, ça doit pas aider). Les numéros (8 - 9 - 10...) indiquent le nombre de calculs réalisés (ici ça a planté à la fin du 12éme calcul...). Ce qui est nouveau c'est cette fenêtre qui apparait pour me dire que le programme AnsysWBU.exe a crashé avec un fichier que j'ai essayé de lire mais qui ne semble pas facilement déchiffrable. J'ai posté tous ces messages d'erreurs sur le forum Ansys, en espérant qu'une bonne âme puisse m'aider...
    Merci encore à vous
    Cordialement,
    Pierre

  9. #9
    Membre averti
    Homme Profil pro
    Ingénieur Mécanique Fluides
    Inscrit en
    Janvier 2024
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur Mécanique Fluides
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2024
    Messages : 20
    Par défaut
    Cher Wiztricks,
    J'ai oublié de répondre à ton message concernant les deux paradigmes possibles dans pyMechanical: Embedded & Server. J'étais au début parti sur la version server mais hélas cela est assez lourd car l'environnement serveur (qui est en fait Ansys Mechanical ouvert) ne supporte par mon code pyNukiyama pour générer les conditions aux limites. Je dois donc tout générer en amont, puis stocker dans des fichiers externes, lancer le serveur (Ansys Mechanical) et récupérer les conditions aux limites dans les fichiers externes générés avant... Bref, sachant que j'ai 2500 calculs à faire, ça oblige d'ouvrir 2500 fois Ansys Mechanical et même si c'est le script qui le fait, c'est assez long (finalement plus long que le calcul en soi).
    Mais en effet, peut-être cela vaudrait il le coup d'essayer la chose si j'obtiens d'autres messages d'erreurs.

    Merci de ton aide
    Cordialement,
    Pierre

Discussions similaires

  1. Réponses: 7
    Dernier message: 18/04/2008, 20h07
  2. Réaliser un install pour un script python
    Par mcarluec dans le forum Déploiement/Installation
    Réponses: 13
    Dernier message: 15/04/2008, 08h14
  3. Accents Command Line depuis un script Python
    Par nicou50 dans le forum Général Python
    Réponses: 6
    Dernier message: 29/12/2006, 10h41
  4. Interpreter un script python dans un prog python
    Par romeo9423 dans le forum Général Python
    Réponses: 3
    Dernier message: 01/12/2005, 16h16
  5. Réponses: 3
    Dernier message: 05/04/2005, 14h26

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