|
|
Kennlinien "addieren"/zusammenfügen |
|
tgraeber |

Forum-Newbie
|
 |
Beiträge: 3
|
 |
|
 |
Anmeldedatum: 03.07.13
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 24.09.2013, 14:54
Titel: Kennlinien "addieren"/zusammenfügen
|
 |
Hallo,
habe folgendes Problem.
Ich möchte vier Kennlinien zu einer "Gesamtkennlinie" addieren, damit ich diese dann invertieren kann. Bei gleicher Anzahl und gleichen Stützstellen wäre das kein Problem, aber das Skript muss allgemeingültig für alle Inputs sein.
Also wenn ich bei x=1 bei Kennlinie 1-3 einen Wert habe, aber die vierte Kennlinie nur bei x=0.5 und x=1.5 definiert ist möchte ich den Wert für x=1 interpolieren.
Beispiel (mit nur 2 Vektoren)
Input:
x_1 = [1 2 3]
y_1 = [10 20 30]
x_2 = [1 2 2.5]
y_2 = [5 10 20]
gewünschtes Ergebnis:
x = [1 2 2.5 3]
y = [15 30 45 60]
bei der 45 wurde x_1 interpoliert, bei der 60 wurde x_2 extrapoliert
Gibt es für dafür schon eine vorgefertigte Funktion? Oder eine ähnliche? Ich würde gerne mit einem Einzeiler auskommen, wenn das nicht geht muss ich ein Skript schreiben.
Danke für jede Hilfe!
|
|
|
|
|
tgraeber |
Themenstarter

Forum-Newbie
|
 |
Beiträge: 3
|
 |
|
 |
Anmeldedatum: 03.07.13
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 24.09.2013, 15:20
Titel: Gute Lösung?
|
 |
Also ich hätte folgende Lösung, wenn ihr was besseres habt sagt bescheid
x = fliplr(unique(sort([x_1,x_2,x_3,x_4])))
y = fliplr(
interp1(x_1,y_1,unique(sort([x_1,x_2,x_3,x_4]))) +
interp1(x_2,y_2,unique(sort([x_1,x_2,x_3,x_4]))) +
interp1(x_3,y_3,unique(sort([x_1,x_2,x_3,x_4]))) +
interp1(x_4,y_4,unique(sort([x_1,x_2,x_3,x_4])))
)
|
|
|
|
|
Einstellungen und Berechtigungen
|
|
Du kannst Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen. Du kannst Dateien in diesem Forum posten Du kannst Dateien in diesem Forum herunterladen
|
|
Impressum
| Nutzungsbedingungen
| Datenschutz
| FAQ
| RSS
Hosted by:
Copyright © 2007 - 2025
goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks
MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.
|
|