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

Delphi Discussion :

Problème d'équation logarithmique


Sujet :

Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Owner
    Inscrit en
    Décembre 2004
    Messages
    478
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Owner
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2004
    Messages : 478
    Par défaut Problème d'équation logarithmique
    Bonjour,
    Je cherche à calculer une équation logarithmique à partir de points.
    Excel me fait ça très bien, mais je cherche à intégrer cela dans Delphi.
    Les valeurs de x sont:
    2,5
    5
    10
    15
    25
    Les valeurs de Y sont:
    5,032356374
    5,644094649
    6,339403643
    7,02808909
    7,553404206
    La résolution proposée par excel est:
    y=1.1151*Ln(x)+3.9207

    d'avance pour vos idées...
    Phil

  2. #2
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 096
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 14 096
    Par défaut
    Déjà comment tu fais cela en EXCEL ? un opérateur ? une macro ?

    Est-ce que la formule à trouver est toujours de la forme y = a * ln(x) + b ?
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  3. #3
    Modérateur

    Homme Profil pro
    Ingénieur retraité
    Inscrit en
    Octobre 2005
    Messages
    2 396
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur retraité

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 396
    Par défaut
    Bonjour,

    ShaiLeTroll : Est-ce que la formule à trouver est toujours de la forme y = a * ln(x) + b ?
    Si c'est le cas, le problème de PhilLU se ramènerait à calculer a et b via un système de 5 équations à 2 inconnues vu qu'il y a 5 paires de données X,Y
    Et 5 équations pour seulement 2 inconnues ça fait toujours 3 équations de trop qui donnent des résultats qui s'écartent de celui obtenu par l'un des systèmes de 2 équations à 2 inconnues.
    Donc il suffirait de savoir comment procède Excel mais en cherchant "y = a * ln(x) + b" sur Google on trouve par çi et par là des bouts de réponse.

    A.

    EDIT : On trouve ici : http://www.apprendre-en-ligne.net/MA...ATI/STATI2.PDF
    en Page 20 - CHAPITRE 2 "Ajustement par une fonction logarithmique de la forme y = a ln(x) + b" la façon de calculer a et b via un calcul en 3 étapes dont la seconde passe par un calcul des moindres carrés
    N'oubliez pas de consulter les FAQ Delphi et les cours et tutoriels Delphi

  4. #4
    Membre éclairé
    Homme Profil pro
    Owner
    Inscrit en
    Décembre 2004
    Messages
    478
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Owner
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2004
    Messages : 478
    Par défaut
    Citation Envoyé par Gilbert Geyer Voir le message
    Bonjour,


    Si c'est le cas, le problème de PhilLU se ramènerait à calculer a et b via un système de 5 équations à 2 inconnues vu qu'il y a 5 paires de données X,Y
    Et 5 équations pour seulement 2 inconnues ça fait toujours 3 équations de trop qui donnent des résultats qui s'écartent de celui obtenu par l'un des systèmes de 2 équations à 2 inconnues.
    Donc il suffirait de savoir comment procède Excel mais en cherchant "y = a * ln(x) + b" sur Google on trouve par çi et par là des bouts de réponse.

    A.

    EDIT : On trouve ici : http://www.apprendre-en-ligne.net/MA...ATI/STATI2.PDF
    en Page 20 - CHAPITRE 2 "Ajustement par une fonction logarithmique de la forme y = a ln(x) + b" la façon de calculer a et b via un calcul en 3 étapes dont la seconde passe par un calcul des moindres carrés
    Oui, je pense une régression linéaire d'un nuage de points dont l'axe des X est logarithmique.
    La régression linéaire, je maîtrise, mais pour ce coup là, je sèche sur la méthode à utiliser...

  5. #5
    Membre éclairé
    Homme Profil pro
    Owner
    Inscrit en
    Décembre 2004
    Messages
    478
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Owner
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2004
    Messages : 478
    Par défaut
    Citation Envoyé par ShaiLeTroll Voir le message
    Déjà comment tu fais cela en EXCEL ? un opérateur ? une macro ?

    Est-ce que la formule à trouver est toujours de la forme y = a * ln(x) + b ?
    oui, oui

  6. #6
    Modérateur
    Avatar de tourlourou
    Homme Profil pro
    Biologiste ; Progr(amateur)
    Inscrit en
    Mars 2005
    Messages
    3 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Biologiste ; Progr(amateur)

    Informations forums :
    Inscription : Mars 2005
    Messages : 3 938
    Billets dans le blog
    6
    Par défaut
    Peut-être l'utilisation de la librairie DMath de Jean Debord pourrait-elle te convenir.
    Delphi 5 Pro - Delphi 11.3 Alexandria Community Edition - CodeTyphon 6.90 sous Windows 10 ; CT 6.40 sous Ubuntu 18.04 (VM)
    . Ignorer la FAQ Delphi et les Cours et Tutoriels Delphi nuit gravement à notre code !

  7. #7
    Modérateur

    Homme Profil pro
    Ingénieur retraité
    Inscrit en
    Octobre 2005
    Messages
    2 396
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur retraité

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 396
    Par défaut
    Bonjour,

    PhilLU : la formule à trouver est toujours de la forme y = a * ln(x) + b
    Oui, je pense une régression linéaire d'un nuage de points dont l'axe des X est logarithmique.
    La régression linéaire, je maîtrise, mais pour ce coup là, je sèche sur la méthode à utiliser...
    Puisque tu maîtrises déjà la régression linaire tu devrais bien maîtriser les étapes 1 à 3 de l'image ci-jointe.
    Il faudrait dire plus clairement sur quoi tu sèches (sur l'étape 1 ? l'étape 2 ? ou la 3 ?) sinon on n'avancera pas.

    A+.

    EDIT : On peut trouver ici : http://fbegin.profweb.ca/ZEA/RegLog.htm
    un bon exemple de résolution numérique d'une régression logarithmique présentée dans sa plus grande simplicité.
    Images attachées Images attachées  
    N'oubliez pas de consulter les FAQ Delphi et les cours et tutoriels Delphi

  8. #8
    Modérateur

    Homme Profil pro
    Ingénieur retraité
    Inscrit en
    Octobre 2005
    Messages
    2 396
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur retraité

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 396
    Par défaut
    Re-salut,

    En fait c'est bête comme chou. Voici un bout de code qui reprend les 7 valeurs numériques de l'exemple d'ici : http://fbegin.profweb.ca/ZEA/RegLog.htm
    sauf qu'au lieu de faire les calculs via les Log-Base-10 je passe directement en Logs-Népériens et j'obtiens les mêmes résultats

    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
    procedure TForm1.bRegLogClick(Sender: TObject);
    var x, y: array[1..7] of Extended; i: integer;
      SigX, SigY, SigLnX, SigYLnX, SigLnX2, b0, b1: Extended;
    begin
      for i := 1 to 7 do x[i] := 2 * i;
      y[1] := 8.9;
      y[2] := 10.9;
      y[3] := 12;
      y[4] := 12.8;
      y[5] := 13.4;
      y[6] := 13.9;
      y[7] := 14.3;
      SigX := 0.0; SigY := 0.0; SigLnX := 0.0; SigYLnX := 0.0; SigLnX2 := 0.0;
      for i := 1 to 7 do begin
        SigX := SigX + x[i];
        SigY := SigY + y[i];
        SigLnX := SigLnX + ln(x[i]);
        SigYLnX := SigYLnX + y[i] * ln(x[i]);
        SigLnX2 := SigLnX2 + sqr(ln(x[i]));
      end;
      b1 := (SigYLnX - SigLnX * SigY / 7) / (SigLnX2 - sqr(SigLnX) / 7);
      b0 := (SigY / 7) - (b1 * SigLnX / 7);
      RichEd.clear;
      RichEd.Lines.Add('y = ' + FloatToStr(b0) + ' + ' + FloatToStr(b1) + ' * Ln(x)');
      // Résultat : y = 7,01664538270682 + 2,77214256629099 * Ln(x)
    end;
    A+.
    N'oubliez pas de consulter les FAQ Delphi et les cours et tutoriels Delphi

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

Discussions similaires

  1. Problème d'équation
    Par irarref dans le forum Maple
    Réponses: 6
    Dernier message: 03/06/2012, 16h22
  2. [Débutant] Petit problème d'équations
    Par Trotterata dans le forum MATLAB
    Réponses: 1
    Dernier message: 06/04/2012, 11h57
  3. problème ode équation différentielles
    Par jamal.obito dans le forum MATLAB
    Réponses: 1
    Dernier message: 26/07/2011, 12h52
  4. Problème simplification équation booléenne
    Par Metallic-84s dans le forum Algorithmes et structures de données
    Réponses: 9
    Dernier message: 09/02/2006, 14h52
  5. Problème d'équations dans l'espace (perspective -> 3D)
    Par Rémiz dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 19/12/2005, 17h43

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