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

Langage Delphi Discussion :

Regression linéaire multiple


Sujet :

Langage Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Juin 2004
    Messages
    157
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 157
    Par défaut Regression linéaire multiple
    Bonjour à tous,

    je soumets la problématique suivante qui se situe à l'intersection des domaines Delphi/analyse numérique.

    j'ai une fonction Y=f(X) définie sur un très grand nombre de points (27000) lorsque je représente cette fonction en Delphi (mais également en
    Excel : plus facile à fournir en illustration) j'obtiens une ligne brisée de quelques segments (entre 5 et 10). Mais ça c'est ce que je constate
    sur mon graphe mais je ne connais pas d'algorithme/fonction en Delphi qui me permettrait de récupérer, à partir de tous ces points, la suite
    des segments décrits par leurs extrémités (Xdébut, Ydébut) --> (Xfin, Yfin).

    Connaissez-vous un code Delphi (pascal objet), ou simplement un algorithme qui me permettrait de faire cela ?

    Merci d'avance
    Fichiers attachés Fichiers attachés

  2. #2
    Membre Expert
    Avatar de Charly910
    Homme Profil pro
    Ingénieur TP
    Inscrit en
    Décembre 2006
    Messages
    2 522
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur TP
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Décembre 2006
    Messages : 2 522
    Par défaut
    Bonjour,

    Je me doute que tu as du y penser : prendre 3 points et regarder s'ils sont alignés, puis 3 points suivants. Mais le traitement risque d'être long ...

    A+
    Charly

  3. #3
    Membre Expert
    Avatar de Charly910
    Homme Profil pro
    Ingénieur TP
    Inscrit en
    Décembre 2006
    Messages
    2 522
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur TP
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Décembre 2006
    Messages : 2 522
    Par défaut
    Bonjour,

    tes points ne sont pas alignés ? il ne s'agit pas de segments ? Il faudrait trouver autre chose : peut être un changement de pente important ?

    A+
    Charly

  4. #4
    Membre Expert
    Avatar de Charly910
    Homme Profil pro
    Ingénieur TP
    Inscrit en
    Décembre 2006
    Messages
    2 522
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur TP
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Décembre 2006
    Messages : 2 522
    Par défaut
    Bonjour,

    méthode très approximative, non scientifique et qui ne s'applique qu'à ton style de nuage de points (en zigzag) :

    En chaque point tu calcules la somme des pentes des 3 vecteurs suivants.

    Les points que tu cherches sont situés aux endroits ou cette somme change de valeur (à 2 décimales près). Si la somme change très rapidement 2 ou 3 points après, il faut éliminer ce point qui duplique l'extrémité du segment)

    Pas terrible, mais je ne trouve rien d'autre de plus satisfaisant après de nombreux tests sur les variations de pente ...

    Il faudrait faire appel à un super matheux !!

    A+
    Charly

  5. #5
    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
    Une piste, peut-être :
    1) déterminer la pente sur quelques points successifs (pour vérifier, car si droite parfaite, 2 points suffisent)
    2) chercher de façon aléatoire si des points à plus ou moins grande distance se trouvent sur le même segment (calcul de leur ordonnée grâce à leur abscisse et cette pente)
    3) si oui, chercher plus loin ; si non, chercher l'extrémité du segment par une méthode où on divise l'intervalle à tester en 2
    4) une fois l'extrémité trouvée, on repart de là pour chercher celle du segment suivant

    Le risque est de ne pas trouver deux (ou plus) courts segments intermédiaires si 2 segments distants sont alignés sur une même droite

    Si les points sont obtenus par mesure, reste à espérer que les segments soient réellement droits.
    S'ils le sont par calcul, les points qui annulent la dérivée seconde sont les points d'inflexion cherchés.
    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 !

  6. #6
    Membre Expert
    Avatar de Charly910
    Homme Profil pro
    Ingénieur TP
    Inscrit en
    Décembre 2006
    Messages
    2 522
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur TP
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Décembre 2006
    Messages : 2 522
    Par défaut
    Les points ne sont pas alignés. chaque segment est en fait une ligne composée de petits zigzag. C'est là la difficulté.

    Ma solution fonctionne à peu près mais cela dépend si tous les jeux de données suivent ce principe !

    je vais simplifier mon programme (en enlevant les essais infructueux) et le poster.

    A+
    Charly

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

Discussions similaires

  1. Regression linéaire multiple
    Par Newenda dans le forum Bibliothèques d'apprentissage automatique
    Réponses: 0
    Dernier message: 12/05/2017, 18h11
  2. Scoring avec une regression linéaire
    Par n3mrod dans le forum SAS STAT
    Réponses: 7
    Dernier message: 10/06/2015, 15h48
  3. régression linéaire multiple
    Par azertyuio dans le forum Méthodes prédictives
    Réponses: 14
    Dernier message: 18/04/2010, 21h53
  4. régression linéaire multiple et contrainte
    Par arthy dans le forum Méthodes prédictives
    Réponses: 21
    Dernier message: 20/02/2010, 11h27
  5. Réponses: 0
    Dernier message: 21/03/2008, 13h51

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