Fonction dichotomie Python

carryPAR Messages postés 8 Statut Membre -  
 Utilisateur anonyme -
bonjour !!
je dois écrire un programme en python et je galère car je ne suis pas très forte en informatique...
voici la consigne....
Écrire une fonction dichot(a,b,f) qui prend en entrée deux réels a < b et une fonction f tels que f(a)f(b) < 0, et qui retourne deux réels a0,b0 vérifiant a ? a0 < b0 ? b tels que f(a)f(a0)>0,f(b)f(b0)>0etb0?a0 minimal.
Cette fonction procèdera par répétition de dichotomie : selon le signe de f (c) où c = (a + b)/2, elle remplace a ou b par c.
pourriez vous m'aider à écrire le programme ?
je vous remercie

8 réponses

  1. carryPAR Messages postés 8 Statut Membre
     
    d'accord je comprends.
    je vous dit ce que j'ai mais après vous me laisser pas tomber s'il vous plait parce que j'ai vraiment besoin d'aide.

    def dichot(a,b,f):
    while b-a>f:
    t=(a+b)/2,0
    if f(a)*f(t)<0:
    b=t
    else
    a=t
    print (a,b)

    voila mercii
    0
  2. carryPAR Messages postés 8 Statut Membre
     
    def
    dichot(a,b,f):
    .....
    while
    b-a>f:
    .....t=(a+b)/2,0
    .....
    if
    f(a)*f(t)<0:
    ............b=t
    .....
    else
    :
    ............a=t
    print
    (a,b)

    voila j espère que c'est bon maintenant :)
    0
    1. dsy73 Messages postés 9003 Date d'inscription   Statut Contributeur Dernière intervention   2 547
       
      Soit j'ai raté qqchose soit tu ne veux pas lire :
      "Détaillez précisément le ou les point(s) qui vous pose(nt) un problème dans votre exercice."
      "Si un message d'erreur apparait, recopiez-le en intégralité, précisez la ligne ou il apparait et le contenu des variables."
      De plus je crois que l'énoncé a un problème de format.
      0
  3. carryPAR Messages postés 8 Statut Membre
     
    Tout d'abord, merci pour ton aide.

    Revoici l'énoncé :
    Écrire une fonction dichot(a,b,f) qui prend en entrée deux réels a < b et une fonction f tels que f(a)f(b) < 0, et qui retourne deux réels a0,b0 vérifiant a ? a0 < b0 ? b tels que f(a)f(a0)>0,f(b)f(b0)>0etb0?a0 minimal.
    Cette fonction procèdera par répétition de dichotomie : selon le signe de f (c) où c = (a + b)/2, elle remplace a ou b par c.

    Bon je vais cibler plus mon problème.
    J'ai casi écrit tout le code il ne me manque plus qu'une ligne à écrie.
    celle ci consiste à dire "tant que il existe un x tel que a<x<b et que f(x) différent de 0 alors..."
    je sais qu'il faut utiliser while le problème c'est que je ne sais pas comment traduire "il existe un x tel que" j'ai pensé à utiliser la fonction range seulement je ne veut pas me limiter à des valeurs entières...`
    pouvez vous m'aider ?
    merci
    0
    1. dsy73 Messages postés 9003 Date d'inscription   Statut Contributeur Dernière intervention   2 547
       
      Non je ne peux pas t'aider. Je n'arrive pas à comprendre l'énoncé que tu as inscris.
      0
  4. Vous n’avez pas trouvé la réponse que vous recherchez ?

    Posez votre question
  5. carryPAR Messages postés 8 Statut Membre
     
    ou t'ou simplement un moyen de trouver le maximum d'une fonction dans un intervalle (a,b)
    mais je ne sais pas le programmer
    0
  6. carryPAR Messages postés 8 Statut Membre
     
    l'ennoncé est clair pourtant je ne l'ai pas inventé et je l'ai recopié mot à mot. il faut voir ça en quelque sorte comme le théorèmes des valeurs intermédiaires.
    en gros vous m'avez demandé plein de choses. j'ai fait de mon mieux pour répondre à vos attentes et à celle du forum pour au final recevoir aucune aide.
    0
    1. dsy73 Messages postés 9003 Date d'inscription   Statut Contributeur Dernière intervention   2 547
       
      Que comprends tu de cet extrait de l'énoncé ?
      deux réels a0,b0 vérifiant a ? a0 < b0 ? b tels que f(a)f(a0)>0,f(b)f(b0)>0etb0?a0 minimal
      0
  7. carryPAR Messages postés 8 Statut Membre
     
    Autant pour moi il y a eu un problème de format:
    j'espère que maintenant ça sera lisible
    Écrire une fonction dichot(a,b,f) qui prend en entrée deux réels a < b et une fonction f tels que f(a)f(b) < 0, et qui retourne deux réels a0,b0 vérifiant a < a0 < b0 < b tels que f(a)f(a0)>0,f(b)f(b0)>0 et b0-a0 minimal.
    Cette fonction procèdera par répétition de dichotomie : selon le signe de f (c) où c = (a + b)/2, elle remplace a ou b par c.
    0
  8. Utilisateur anonyme
     
    Salut,

    Est-ce que, déjà, tu comprends la méthode de la dichotomie ?
    0