AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Code-Bibliothek Library: Algorithmen Delphi Linear Curve Fitting
Thema durchsuchen
Ansicht
Themen-Optionen

Linear Curve Fitting

Ein Thema von mschnell · begonnen am 25. Jul 2007
Antwort Antwort
mschnell

Registriert seit: 13. Sep 2006
27 Beiträge
 
#1

Linear Curve Fitting

  Alt 25. Jul 2007, 09:17
Im Rahmen eines Praktikums haben wir eine Unit mit Funktionen für lineare Kurven-Intepolation und Ausgleichsrechnung erstellt.

Kurve-Fitting ist "Ausgleichsrechnung". d.h. die (mehreren) konstanten Parameter einer Funktion y=f(x) (= f(x, ai) mit i=0..N-1)) werden so bestimmt, dass die Kurve y=f(x) "möglichst nah" an vorgegebenen Punkten (xj/yj, j := 0...M-1 vorbeigeht. Hierbei heiß "möglichst nah vorbei" dass die Summe der Quadrate der Differenzen (yj-f(xj) (für j := 0...M-1 ) minimiert wird.

Das lässt sich für lineare Konstanten ("Koeffizienten") der Funktion auf ein lineares Gleichungssystem zurückführen und deterministisch lösen ("lineare Ausgleichsrechnung" Beispiel: Polynom-Approximation). Das macht diese Unit.

Für nichtlinear verwendete Parameter ("nicht lineare Ausgleichsrechnung" Beispiel: Exponential-Approxmation) wird ein rekursives Verfahren benötigt. (Haben wir schon programmiert, lade ich hoch, wenn diese Unit soweit klar ist).

Ausgleichsrechnung / Kurven-Approximation braucht man immer, wenn man eine Menge von Werte-Paaren durch eine Funktion, von der man die Struktur, nicht aber das genaue Aussehen kennt, repräsentieren will um weitere Werte (Extrapolation oder Interpolation) zu bestimmen. Die Güte (Sigma) der Approximation gibt einen Hinweis darauf, wie richtig das Modell ist und/oder wie fehlerbehaftet die Messwerte sind.


Es wird die unit "Matrix" verwendet, die sich ebenfalls in der "Algorithmen"-Kategorie der Library befindet.

-Michael

Delphi-Quellcode:
unit LinApprox;

// Copyright: Julian und Michael Schnell, Krefeld, Germany, [email]mschnell@bschnell.de[/email]


interface
  uses Matrix;

type
  TFuncI = function(x: extended; i: Integer): extended;

function LinInterpolation(V: TMatrix; FuncI: TFuncI): TVector;
// interpolates the points given in V by a linear combination of functions
//
// N-1
// y = Sum (a[i] * Funci(x, i)
// i = 0
//
// V: matrix containing N points (Xi/Yi)
// Funci: Functions fi to be fitted
//
// Result: vector containing the linear factors a[i]

function LinApproximation(V: TMatrix; N: Integer; FuncI: TFuncI): TVector; overload;
function LinApproximation(V: TMatrix; N: Integer; FuncI: TFuncI;
         out Sigma: Extended): TVector; overload;
// performs a linear approximation of the points given in V by a linear combination of functions
//
// N-1
// y = Sum (a[i] * Funci(x, i)
// i = 0
//
// using least square analysis
//
// V: matrix containing M points (Xi/Yi)
// N: Count of functions to be used
// Funci: Functions fi to be fitted
// Sigma: (optional) Standard deviation of the Model
// (requesting Sigma adds a considerable calculation)
//
// Result: vector containing the linear factors a[i]
//
// if N=M the result is the same as with LinInterpolation and Sigma is 0
[edit=Matze]Beschreibungstext aus einem anderen Beitrag ergänzt. MfG, Matze[/edit]
Angehängte Dateien
Dateityp: zip linapprox_215.zip (4,5 KB, 156x aufgerufen)
  Mit Zitat antworten Zitat
Antwort Antwort

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:51 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz