Approximation von Meßwerten durch eine beliebige Funktion



  • Hallo Leute, gibt es schon irgendwo Quellcode, womit ich eine gegebene Reihe von Messpunkten
    (mit äquidistantem zeitlichen Abstand) durch eine benutzerdefinierte Funktion der Zeit t sowie mehrerer
    / beliebig vieler Parameter a1 ... an annähern kann? Oder muß ich mir sowas erst selbst schreiben? Habe
    schon eine Zeit lang gegoogelt, bin jedoch leider nicht fündig geworden.
    Zur Erklärung:
    Ich habe eine Reihe von Meßwerten y_mess(t), die ich durch folgende Ansätze annähern möchte:
    (1) y(t) = a1 * exp(-t / a2) + a3
    (2) y(t) = a1 * exp(-t / a2) + a3 - a4 * t
    (3) y(t) = a1 * exp(-t / a2) + a3 * exp(-t / a4)
    (4) y(t) = ...
    "Annähern" bedeutet, daß - ähnlich wie bei linearer Regression - die Summe der Residuenquadrate
    (y(t) - y_mess(t))^2 minimiert wird.
    Meine Idee ist, s(a1 ... an) := Summe[alle t]((y(a1 ... an, t) - y_mess(t))^2) als Skalarfunktion des
    Vektors a1 ... an aufzufassen, wobei man dann benutzt, daß der Gradient von s in Richtung des stärksten
    Anstiegs von s zeigt. Um das Minimum zu finden, braucht man daher "bloß" noch dem Gradienten entgegen
    zu gehen. Jedoch wird das Ganze sicher einen erklecklichen Aufwand benötigen, und wenn es nicht sein
    muß, möchte ich das Rad nicht neu erfinden.


    Anmelden zum Antworten
     


  • Ich verstehe nicht, was deine y(x1,...,x_n,t) da sollen. Sind jetzt die x_k die Stützstellen, oder was? Msn kann auch den Eindruck bekommen, dass das bei dir die t's sind. Drück dich bitte ein wenig klarer aus. Danke.



  • Ich habe meinen ersten Beitrag präzisiert:
    Stützstellen sind die y_mess(t)
    Gegeben habe ich die Funktion y(t) = a1 * exp(-t / a2) + ... mit der Variablen t (Zeit) und den Parametern a1 ... an. Gesucht ist diejenige Kombination von a1 ... an, die die Summe [über alle vorhandenen t] der Residuenquadrate minimiert.



  • Krösus schrieb:

    Ich habe meinen ersten Beitrag präzisiert:
    Stützstellen sind die y_mess(t)
    Gegeben habe ich die Funktion y(t) = a1 * exp(-t / a2) + ... mit der Variablen t (Zeit) und den Parametern a1 ... an. Gesucht ist diejenige Kombination von a1 ... an, die die Summe [über alle vorhandenen t] der Residuenquadrate minimiert.

    Hier ist nichts präzise! OK, zur Erklärung. Du hast Messwerte, sagst du. Das sind i.A. Punkte (xk, yk). Dabei heißen die xk Stützstellen und nicht die yk. Also, was sind deine Stützstellen, was deine y-Werte dazu? Und was sind die ak?



  • Wie schon gesagt, ich habe eine gegebene Reihe von N Meßpunkten mit jeweils äquidistantem zeitlichen Abstand dt.
    Meßunkte sind die (ti | y_messi) mit i = 1 ... N, N ~ 9000, Stützstellen sind daher die ti mit ti = i * dt.
    Die ak mit k = 1 ... n, n = 3 oder 4, sind die gesuchten Parameter der Funktion y(t); und zwar sind diese so zu bestimmen, daß die Summe der Residuenquadrate minimiert wird.



  • OK, ich finde es ziemlich blöde, dass du nicht selber merkst, dass das hinten und vorne Murks ist, aber bitte...

    s(a1 ... an) := Summe[alle t]((y(a1 ... an, t) - y_mess(t))^2)

    Was soll das sein? Etwa

    s(a\_1,\dots,a\_n) := \sum_{i=0}^N (y(a1,\dots,a\_n,t\_i) - y_i)^2???

    Dabei sollen jetzt die yi deine y_mess(ti) sein. So schreibt man das auch normalerweise.

    (1) y(t) = a1 * exp(-t / a2) + a3
    (2) y(t) = a1 * exp(-t / a2) + a3 - a4 * t
    (3) y(t) = a1 * exp(-t / a2) + a3 * exp(-t / a4)
    (4) y(t) = ...

    Die Punkte unten sind schön und gut, aber ich wüsste beim besten Willen nicht, wie es weitergehen sollte. Und warum nimmst du grade diese Funktionen? Kannst du das hier irgendwie noch begründen?



  • Bevor ich antworte, eine Zwischenfrage:

    Der Latex-Tag funktioniert nicht, bei mir (InternetExplorer 6.0) sieht das alles so aus:
    [latx]s(a_1,\dots,a_n) := \sum_{i=0}^N (y(a1,\dots,a_n,t_i) - y_i)^2[/latex]

    Welche Einstellungen muß ich machen, um Latex korrekt angezeigt zu kriegen?
    Auch der Tieferstellungs-Tag funktioniert bei mir nicht.



  • also ich denk ich seh was du machen moechtest.
    also die methode ist ein nichlinearer Solver nach Levenberg-Marquardt (google)



  • @Krösus:http://www.c-plusplus.net/forum/viewtopic.php?t=56799&start=0 gleich im ersten Beitrag steht's... zumindest vermute ich, daß es daran liegt 😉



  • Ich kann WebFritzi verstehen, denn ich verstehe auch nicht wirklich was Du beabsichtigst...

    Also ich beiße mich schon an der Betreffzeile, denn "Approximation von Meßwerten durch eine beliebige Funktion" schließt sich in sich schon aus, denn Du möchtest ja eigentlich durch eine Approximation "Meßwerte" berechnen, die wohl anscheinend "zwischen" den gemessenen Meßwerten oder "auf" der Zeit Koordinate liegen - und das geht ja nicht mit einer "beliebigen Funktion" ?!

    Präsesieren wir weiter... in der Numerik gibt es die Approximation und die Interpolation.

    Approximation - Entwicklung einer Funktion die möglichst glatt (differenzierbar möglichst), mit einer möglichst kleinen Abweichung von den gemessenen Werten, verläuft. Und dadurch einem möglichen Abbild der unbekannten Funktion entspricht auf die die Meßwerte beruhen.
    Da gibt es die:

    1. Fourierreihen, Verfahren von Runge
    2. Orthogonale Polynome, Tschebyscheff oder Legendre Polynome

    Interpolation - Entwicklung einer Funktion die Werte zwischen Meßwerten möglichst genau widergeben, ohne dabei die eigentliche Funktion zu kennen auf die die Meßwerte beruhen.

    1. Lagrange Interpolation
    2. Newton Interpolation
    3. Rationale Interp.
    4. Spline
    5. Bezier

    Spontan würde ich Dir eher zu der Interpolation raten, da die Approximation mit steigender Anzahl von Meßwerten komplexer wird, das gilt sicherlich auch für die Interpolation, aber aus einem Bauchgefühl herraus traue ich der Interpolation mehr und das auch, weil sie wesentlich einfacher in einer Programmiersprache umzusetzen ist. Jedem aber so wie es einem gefällt 😉



  • Winn schrieb:

    Da gibt es die:

    1. Fourierreihen, Verfahren von Runge
    2. Orthogonale Polynome, Tschebyscheff oder Legendre Polynome

    Die IMHO alle auf diskreter/kontinuierlicher Gaussapproximation basieren!
    Dabei können die Ansatzfunktionen aber beliebig gewählt werden (Tschebyscheff-, Laguerre- oder Legendre-Polynome [...] bieten halt den Vorteil, daß das Normalgleichngssystem eine sehr einfache Gestalt hat (da die Funktionen orthogonal sind), was übrigens auch für die Fouriertransformation gilt...).

    Winn schrieb:

    Interpolation - Entwicklung einer Funktion die Werte zwischen Meßwerten möglichst genau widergeben, ohne dabei die eigentliche Funktion zu kennen auf die die Meßwerte beruhen.

    Vielleicht sollte man noch dazu sagen, daß bei Interpolation stets f(xi)=yi gilt, was natürlich bei der Approximation nicht der Fall ist!
    Man versucht Polynome zu finden, die die Meßpunkte _genau_ treffen...

    Winn schrieb:

    Spontan würde ich Dir eher zu der Interpolation raten, da die Approximation mit steigender Anzahl von Meßwerten komplexer wird, das gilt sicherlich auch für die Interpolation, aber aus einem Bauchgefühl herraus traue ich der Interpolation mehr und das auch, weil sie wesentlich einfacher in einer Programmiersprache umzusetzen ist.

    Von Interpolation würde ich dir auf jeden Fall abraten:

    Krösus schrieb:

    ... ~ 9000, Stützstellen ...

    Bei so einer "Datenwolke" würde ich auf jeden Fall zu diskreter GA raten!
    Nach Wahl der Anstzfunktionen phii stellst du das NGS auf und berechnest so die Koeffizienten alphai, sodaß deine Gesuchte Funktion y=sum(alphai*phii) herauskommt.



  • fubar schrieb:

    Winn schrieb:

    Interpolation - Entwicklung einer Funktion die Werte zwischen Meßwerten möglichst genau widergeben, ohne dabei die eigentliche Funktion zu kennen auf die die Meßwerte beruhen.

    Vielleicht sollte man noch dazu sagen, daß bei Interpolation stets f(xi)=yi gilt, was natürlich bei der Approximation nicht der Fall ist!
    Man versucht Polynome zu finden, die die Meßpunkte _genau_ treffen...

    Schwachsinn ! Warum soll bei der Interpolation stets f(x_i)=y_i sein ? Spline Funktionen dürften wohl schon per Definition nicht so sein, wie Du behauptet hast...

    fubar schrieb:

    Winn schrieb:

    Spontan würde ich Dir eher zu der Interpolation raten, da die Approximation mit steigender Anzahl von Meßwerten komplexer wird, das gilt sicherlich auch für die Interpolation, aber aus einem Bauchgefühl herraus traue ich der Interpolation mehr und das auch, weil sie wesentlich einfacher in einer Programmiersprache umzusetzen ist.

    Von Interpolation würde ich dir auf jeden Fall abraten:

    Krösus schrieb:

    ... ~ 9000, Stützstellen ...

    Bei so einer "Datenwolke" würde ich auf jeden Fall zu diskreter GA raten!
    Nach Wahl der Anstzfunktionen phii stellst du das NGS auf und berechnest so die Koeffizienten alphai, sodaß deine Gesuchte Funktion y=sum(alphai*phii) herauskommt.

    So ein großes Gleichungssystem möchtest Du lösen ??? Wie möchtest Du das in C/C++ implementieren ?

    Wie auch immer, wenn Krösus eine Funktion berechnen möchte bzw. nachher als analytischen Ausdruck haben möchte, dann ist die Approximation sein Wahl, wenn er eine numerische Annäherung haben möchte, dann ist die Interpolation sicherlich die bessere Wahl. Für Bauanleitungen findet sich hier -> http://www.library.cornell.edu/nr/cbookcpdf.html bestimmt etwas...



  • Winn schrieb:

    fubar schrieb:

    Winn schrieb:

    Interpolation - Entwicklung einer Funktion die Werte zwischen Meßwerten möglichst genau widergeben, ohne dabei die eigentliche Funktion zu kennen auf die die Meßwerte beruhen.

    Vielleicht sollte man noch dazu sagen, daß bei Interpolation stets f(xi)=yi gilt, was natürlich bei der Approximation nicht der Fall ist!
    Man versucht Polynome zu finden, die die Meßpunkte _genau_ treffen...

    Schwachsinn ! Warum soll bei der Interpolation stets f(x_i)=y_i sein ? Spline Funktionen dürften wohl schon per Definition nicht so sein, wie Du behauptet hast...

    Doch, i.A. ist das bei der Interpolation so. Auch bei Splines.



  • WebFritzi schrieb:

    Doch, i.A. ist das bei der Interpolation so. Auch bei Splines.

    Okay, dann frag ich mal anders herum, was versteht ihr unter f(x_i)=y_i ? Bzw. warum sollte das bei der Approximation nicht so sein oder so sein ? Und bei der Interpolation ausschließlich nur f(x_i)=y_i gelten ?

    Okay, generelle Frage... aber ich glaube hier entwickelt sich ein Mißverständnis, entweder vom Niedergeschriebenen oder vom Stoff her...



  • Winn schrieb:

    Schwachsinn ! Warum soll bei der Interpolation stets f(x_i)=y_i sein ?

    Aber das ist doch gerade der Sinn der Interpolation 🙄

    Winn schrieb:

    Spline Funktionen dürften wohl schon per Definition nicht so sein, wie Du behauptet hast...

    Doch per definitionem ist es genau so!

    Winn schrieb:

    So ein großes Gleichungssystem möchtest Du lösen ??? Wie möchtest Du das in C/C++ implementieren ?

    Die Matrix des NGS ist aus IR^Anzahl der Ansatzfunktionen2, also nicht abhängig von der Anzahl der Stützstellen, d.h. problemlos in C/C++ umzusetzen.

    Edit: Sorry, hatte deinen Beitrag noch nicht gelesen. Vielleicht reden wir ja aneinander vorbei.



  • Nehmen wir mal an, wir haben (n+1) paaweise versch. Stützstellen x_0,...,x_n und die zugehörigen Stützwerte y_0,...,y_n.
    Gesucht wir nun ein(/das eindeutig bestimmte) Polynom P n-ten Grades, das die Interpolationsbedingungen P(x_i)=y_i erfüllt!

    Dieses kann man z.B. durch Lagrange/Newton-Interpolation finden.

    Bei mehr als ~7 Stützstellen fangen diese Interpolationspolynome an zu "oszillieren".

    Jetzt könnte man z.B. auf kubische Splineinterpolation umsteigen.

    Hat man aber eine große Anzahl Meßwerte, die natürlich mit Meßfehlern behaftet sind, ist Interpolation nicht sehr sinnvoll. Hier nimmt man dann IMHO Approximation.

    Edit:

    Als (zugegebenermaßen konstruiertes) Bsp.:
    Stützstellen:
    x y
    0 0
    1 2
    2 2
    3 4
    4 4
    5 6
    6 6
    7 8
    8 8
    9 10

    Das interpolierende Polynom P=sum(a_i*x^i, i=0..9) hätte die Koeffizienten:

    3,24840340502144E-6 // a_0
    68,4264735655574
    -166,634400171086
    162,906874766606
    -83,6968066168767
    25,0704576308921
    -4,53133321606725
    0,486557471969308
    -0,0285588171212395
    0,000705156601175834 //a_9

    Stellt man das jetzt graphisch dar, sieht man, daß dieses Polynom zwar die Punkte interploiert, aber nicht den "erwarteten" Verlauf aufweist...



  • fubar schrieb:

    Nehmen wir mal an, wir haben (n+1) paaweise versch. Stützstellen x_0,...,x_n und die zugehörigen Stützwerte y_0,...,y_n.
    Gesucht wir nun ein(/das eindeutig bestimmte) Polynom P n-ten Grades, das die Interpolationsbedingungen P(x_i)=y_i erfüllt!

    gg, okay, dann haben wir uns mißverstanden... das die Interpolationsbedingung f(x_i)=y_i sein muß ist klar, gg... dachte Du meinst damit die interpolierten also die berechneten Werte die die Meßwerte quasi "ergänzen".

    Das die Wahl des Interpolations oder des Approximations Verfahren stark von den Meßwerten abhängt, ist zumindest aus meiner Sicht klar. Eine "ungefähre" Vorstellung über die dahinter liegende Funktion ist unabdingbar für die "richtige" Wahl...

    Bei Deinem Beispiel würde ich z.B. das Differenzenverfahren anwenden (f(x1)-f(x0))/2 😃



  • wenn Ihr die wirkliche Funktion hinter einer Messreihe kennt dann gratuliere ich euch.
    Mag der sachverhalt auch einen gesetz wie y=e^x gehorchen, werden Messwert doch davon abweichen und dass die Fehlerfunktion bekannt oder mit 100% sicherheit zu bestimmen ist bezweifle ich doch stark.
    Approximieren und Interpolieren sind Begriffe aus der glechen Werkzeugkiste, nur schliessen sich beide nicht aus.
    Das Verfahren zur Bestimmung einer gesuchten Funktion ist die Approximation (Parameter Schätzung).
    Das Verfahren zur Werte Berechnung, mit dieser Funktion, innerhalb eines Messwerte Intervalls, ist die Interpolation.



  • .b7f7 schrieb:

    wenn Ihr die wirkliche Funktion hinter einer Messreihe kennt dann gratuliere ich euch.
    Mag der sachverhalt auch einen gesetz wie y=e^x gehorchen, werden Messwert doch davon abweichen und dass die Fehlerfunktion bekannt oder mit 100% sicherheit zu bestimmen ist bezweifle ich doch stark.

    Hat das denn irgendeiner behauptet? 😕

    .b7f7 schrieb:

    Approximieren und Interpolieren sind Begriffe aus der glechen Werkzeugkiste, nur schliessen sich beide nicht aus.

    Könntest du das vielleicht mal etwas genauer erklären, verstehe den Sinn noch nicht so ganz?



  • fubar schrieb:

    .b7f7 schrieb:

    Approximieren und Interpolieren sind Begriffe aus der glechen Werkzeugkiste, nur schliessen sich beide nicht aus.

    Könntest du das vielleicht mal etwas genauer erklären, verstehe den Sinn noch nicht so ganz?

    bei der Approximation bestimmt man die Funktionsparameter welche man zum Interpolieren(einfügen) von Zwischenwerten benutzt.


Anmelden zum Antworten