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

Mathématiques Discussion :

Algo Calcul integrale methode des trapezes.


Sujet :

Mathématiques

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    1 124
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 1 124
    Points : 193
    Points
    193
    Par défaut Algo Calcul integrale methode des trapezes.
    Bonjour tout le monde

    Je dois faire un algo sur le calcu integrale en utilisant la methode des trapezes, en java avec la fonction.

    Mon probleme est que je n'ais pas de connaissance avancé en Maths

    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
     
    float resultat = 0;//initialisation résultat a 0
     
    int i,n;//déclaration de i et de n
     
     
    float a,b,x,s,r;
     
     a=1;//bord superieur
     
     b=7;//bord inferieur
     
     n=ep;
     
      r= b-a /n;
      s= a+b;
     
     
     
    for(i=0;i<=n-1;i++)
    {
    x=a+i*r;
     
     
    s = s + 2* somme;
     
     
    resultat=s * r/2
    J' ai deux variables Somme et epsi

    somme est la valeur entré depuis l'interface.

    Epsi est le critere d'arret que j'ai placé à la boucle.

    Je suis un peut perdue là.

    Pouvez vous m'aider un peut?

    Merci

    Cordialement

    A bientôt

  2. #2
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 6
    Points : 7
    Points
    7
    Par défaut
    Bonjour,
    Oui votre code n'est pas tres clair.
    Je me permet d'en ecrire un vite fait. Pour les fonctions croissantes uniquement.


    Code C : 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
    // A vous de decider de l'interval de calcul, j'ai choisi [0,max], mon pas est de 1
    main {
     
      double tmp = 0; //dans tmp je vais additionner toutes les aires de trapezes :)
      double pas = 1;
      for (double i=0; i<max; i += pas) {
          tmp += function(i) * (max / pas); //aire du rgand rectangle
          tmp += (max /(pas * 2)) (function(i+pas) - function(i)) // aire du petit triangle
      }
    }
     
    // Et voila l'aire sous la courbe est dans tmp.
     
     
     
    double function(int x) {
     // ma fonction
     return x*x; //par exemple pour le fonction carre
    }

    Bonne continuation

  3. #3
    Membre éprouvé
    Avatar de rostomus
    Homme Profil pro
    Doctorant électronique et traitement du signal
    Inscrit en
    Décembre 2006
    Messages
    791
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Doctorant électronique et traitement du signal

    Informations forums :
    Inscription : Décembre 2006
    Messages : 791
    Points : 1 205
    Points
    1 205
    Par défaut
    Citation Envoyé par fdelhaye59
    Je me permet d'en ecrire un vite fait. Pour les fonctions croissantes uniquement.
    Salut,

    Je pense que ton code est valable même pour les fonction décroissantes.

  4. #4
    Débutant  
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    1 124
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 1 124
    Points : 193
    Points
    193
    Par défaut
    Bonsoir tout le monde

    J'ai fais quelque moddification.

    Car il faut l'imité les pas d'erreur à ce que j'ai compris.

    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
     
    class Fonction {
     
     
     
    public double calculinteg(double somme, float BorneMax){
     
     
    Constante = 0;
     
    double tmp = 0;
    double pas = 1;
     
    while (pas > Constante)
    {
     
    n+=1;
     
    pas = (BorneMax-BorneMin)/n;
     
    }
     
    for (double i=0; i<=BorneMax -pas; i += pas) {
      somme += ((function(i)*i)) + ((function(i)*(i+pas)))/2;
     
     
     
     
     
    }
     
     
     
    }
     
     
    double function(double x) {
     
     return x*x;
     
    }
     
    }
    En testant j'obtiens le même résultat.

    Est normal.

    Merci.

    Cordialement

    A bientôt

  5. #5
    Débutant  
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    1 124
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 1 124
    Points : 193
    Points
    193
    Par défaut
    Bonjour tout le monde

    Je dois ajouter un polynome dans le calcul de l'integrale.


    p(x) = (n0 x^n) + (n1 x^(n-1)) + (n2 x^(n-2)) + (n3 x^(n-3)) + ..... + (nm x^(1)) + n(m+1)
    Comment puis je ajouter le résultat du calcul du polynome dans le calcul de l'integrale.

    Voici le code du polynome

    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
     
    public double calculpolynome(double ax, double ay, double az, double expo){
     
    double resu = 0;
     
    float tp;
     
    int i;
     
     
     resu = Math.pow(ax, expo) + 2 * Math.pow(ay, expo-1) + 3 * az;
     
     
     
    return resu;
    }

  6. #6
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 77
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Points : 1 913
    Points
    1 913
    Par défaut
    Citation Envoyé par rostomus
    Salut,

    Je pense que ton code est valable même pour les fonction décroissantes.
    Et même pour les fonctions non monotones

Discussions similaires

  1. Algo Calcul integrale
    Par argon dans le forum Algorithmes et structures de données
    Réponses: 3
    Dernier message: 30/04/2007, 10h53
  2. LIMIT calcul mal avec des JOIN
    Par FMaz dans le forum Requêtes
    Réponses: 21
    Dernier message: 12/07/2006, 04h37
  3. calculs mathématiques avec des "racines)
    Par emmanuel4945 dans le forum Access
    Réponses: 1
    Dernier message: 30/01/2006, 22h40
  4. [algo et C] Jeu des dés en C
    Par bosz28 dans le forum C
    Réponses: 10
    Dernier message: 12/10/2005, 12h48
  5. Réponses: 2
    Dernier message: 28/09/2005, 18h08

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