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 :

Dérivée et intégrale


Sujet :

Calcul scientifique Python

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Ingénieur GCSTR
    Inscrit en
    Octobre 2023
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur GCSTR

    Informations forums :
    Inscription : Octobre 2023
    Messages : 10
    Points : 6
    Points
    6
    Par défaut Dérivée et intégrale
    Bonjour,

    J'essaye de calculer l'intégrale sur un intervalle [0,L] d'une dérivée seconde d'une fonction.
    J'ai fait le code suivant mais j'obtiens la fonction suivant x grâce à sy.symbols('x') et y = 1-sy.cos(sy.pi*x/(2*L)).
    Quand je fais un print de i3 l'intégrale de y" j'obtiens la primitive de y" mais je souhaite avoir la valeur de l'intégrale de y" sur l'intervalle défini plus haut.
    Comment définir y" comme une fonction pouvant être intégrée sur l'intervalle?
    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
    import pylab as pl
    import numpy as np
    import sympy as sy
    from scipy import integrate
    from scipy.integrate import quad
    from scipy import integrate as intg
    from sympy import *
     
    L = 60
    D = 5
    e = 0.2
    E = 25000
    rho = 2400
    ksi = 0.05
     
    x = np.linspace(0, L, 30)
     
    def moment_quad():
        I = np.pi*((D)**4-(D-2*e)**4)/64
        return I
     
    def masse_cheminee():
        S = np.pi*(((D/2)**2-(D/2-e)**2))
        m = rho*S
        return m
     
    def fonction_deplacement(x):
        psi = 1-np.cos(np.pi*x/(2*L))
        return psi 
     
     
    def masse_generalisee(x):
        m_tilde = (1-np.cos(np.pi*x/(2*L)))**2*m
        return m_tilde
     
    def rigidite_generalisee(x):
        x = sy.symbols('x')
        y = 1-sy.cos(sy.pi*x/(2*L))
        yprime = sy.diff(y, x)
        ysec = yprime.diff(x)
        k_tilde = (ysec)**2*E*I
        return k_tilde
     
    def facteur_excitation(x):
        gamma = (1-np.cos(np.pi*x/(2*L)))*m
        return gamma 
     
    I = moment_quad()
    m = masse_cheminee()
    psi = fonction_deplacement(x)
    m_tilde = masse_generalisee(x)
    k_tilde = rigidite_generalisee(x)
    gamma = facteur_excitation(x)
     
    print("moment quadratique I = ", I, "m4")
    print("masse lineaire ml = ", m, "kg/m")
    print("raideur EI = ", E*I/(16*L**3))
     
    i1 = intg.romberg(fonction_deplacement, 0, L)
    i2 = intg.romberg(masse_generalisee, 0, L)
    i3 = intg.romberg(rigidite_generalisee, 0, L)
    i4 = intg.romberg(facteur_excitation, 0, L)

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    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 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Salut,

    Pour ce qui est de sympy, intégrer une fonction de a à b est relativement simple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    >>> from sympy import *
    >>> x, y = symbols("x y")
    >>> e = 2*x - 1
    >>> diff(e, x)
    2
    >>> integrate(diff(e, x), x)
    2*x
    >>> integrate(diff(e, x), (x, 0, 2))
    4
    >>>
    mais s'il faut comprendre le code que vous avez écrit (je ne dis pas qu'il est "faux" juste qu'il traduit des dimensions métiers qui me sont inconnues) je jette l'éponge.

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

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 03/08/2016, 17h24
  2. [Débutant] Double intégrale et dérivée d'une fonction
    Par samo25 dans le forum MATLAB
    Réponses: 5
    Dernier message: 09/01/2012, 18h04
  3. calcul d'une dérivée et une intégrale
    Par bel_amel dans le forum MATLAB
    Réponses: 0
    Dernier message: 04/03/2011, 17h12
  4. dérivée d'une intégrale : Catastrophe ?
    Par Benjamin.Thomas dans le forum LabVIEW
    Réponses: 0
    Dernier message: 10/06/2010, 09h49
  5. [Sur les dérivées et les intégrales]
    Par hollowdeadoss dans le forum MATLAB
    Réponses: 2
    Dernier message: 01/07/2008, 15h45

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