Lineare Interpolation mit zwei Arrays

at0m

Mitglied
Hallo zusammen,

ich möchte eine lineare Interpolation für zwei Arrays, mit einer unterschiedlichen Länge durchführen.

Beispiel:
array1 hat 17 double-Werte, array2 hat 49 double-Werte. Nun möchte ich ein array3 erzeugen, welches ebenfalls 49 double-Werte enthält, die aus array1 interpoliert wurden.

Die allgemeine, mathematische Formel für die lineare Interpolation lautet ja wie folgt:

y=y1+((y2-y1)/(x2-x1))*(x-x1)

wenn x1/y1 der erste, x2/y2 der zweite und x/y der zu interpolierende Punkt ist, wobei x frei gewählt wurde. Das leuchtet auch ein aber wie interpoliere ich, wenn ich keine Koordinaten, sondern eindimensionale Arrays habe? Stehe da etwas auf dem Schlauch.

Kann mir jemand mit einem Tipp auf die Sprünge helfen?
 

Sogomn

Bekanntes Mitglied
Ohne jetzt groß die Formel zu kennen, würde ich meinen, dass 'x' der Index im Array und 'y' der Wert im Array ist.
 

JStein52

Top Contributor
Also ich würde mal sagen deine x sind zunächst mal tatsächlich die Indizes des Arrays und die y sind die Werte darin. Und jetzt stellst du dir das ganze mal als Graph aufgemalt dar. der Wertebereich geht ja dann von 0 .... 17. Du möchtest aber dass er von 0 ... 49 geht. D.h. du musst den Wertebereich ein bisschen dehnen d.h. mit einem Faktor multiplizieren und zwar so dass aus 17 eben 49 wir, also Faktor 49/17 = 2.882. Der punkt der vorher bei 0 war bleibt dort. Der Wert der vorher bei 1 war gehört jetzt zu 2.882 usw. Mit diesem Wissen rechnest du dir jetzt nach deiner obigen Interpolationsformel sämtliche Werte für alle ganzzahligen Werte von x von 1... 48 aus (0 bleibt ja wie er war, 49 auch) und schon hast du den Inhalt des neuen Arrays. Ich hoffe das war einigermassen verständlich und du verstehst was ich meine. Man müsste das mal an einem einfachen Beispiel per Hand durchrechnen !!
 

JStein52

Top Contributor
Ich weiss ja nicht ob meine Beschreibung verständlich war. Deshalb das ganze mal eben in Java formuliert :):):

Code:
public class LineareInterpolation {

    private double[] array = null;

    public LineareInterpolation(double[] array) {
        this.array = new double[array.length];
        for (int i = 0; i < array.length; i++) {
            this.array[i] = array[i];
        }
    }

    public double[] interpol(int newDimension) {
        double[] newArray = new double[newDimension];
        double faktor = (double) (newDimension-1.0) / (double) (this.array.length-1);

        //speichere kleinsten Wert
        newArray[0] = this.array[0];

        int k = 1;
        for (int i=1; i < this.array.length; i++) {
            // y=y1+((y2-y1)/(x2-x1))*(x-x1)
            while (k <= (i) * faktor) {
                newArray[k] = this.array[i - 1] + ((this.array[i] - this.array[i - 1]) / (faktor)) * (k - (i - 1) * faktor);
                k++;
            }
        }
        return newArray;
    }

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) {
        double[] anArray = {38.0, 41.1, 46.1, 55.4, 81.9};

        LineareInterpolation myInterpol = new LineareInterpolation(anArray);
        double[] interpoliertesArray = myInterpol.interpol(13);
        System.out.println("\nErgebnis: ");
        for (int i = 0; i < interpoliertesArray.length; i++) {
            System.out.print(" (" + i + "," + interpoliertesArray[i] + ")");
        }

    }

}

Mitsamt Testprogramm das ein double(5) auf double(13) interpoliert.
Ein bisschen schwierig ist evtl. die Zeile wo newArray[k] berechnet wird weil da ein Term schon vereinfacht ist und einfach "faktor" übrigbleibt !
 

at0m

Mitglied
Hallo Sogomn und JStein52,

herzlichen Dank für die ausführlichen Antworten!
Tatsächlich. Durch die Erläuterung das das Beispiel leuchtet es ein! Ich bedanke mich vielmals! :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M lineare Sondierung löschen Allgemeine Java-Themen 2
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
A lineare funktionen und winkel Allgemeine Java-Themen 4
C Prüfen ob sich ein Punkt innerhalb einer Kugel befindet (Java3D,nicht-lineare GLS) Allgemeine Java-Themen 5
Guybrush Threepwood Lineare Diskriminanzanalyse Allgemeine Java-Themen 5
R Frage zu einfügen in generische lineare Liste Allgemeine Java-Themen 7
Meeresgott 2D-Grafik Bilinear interpolation Allgemeine Java-Themen 1
D Monotone Cubic Interpolation Allgemeine Java-Themen 4
RalleYTN 2D-Grafik Bild mit bilinearer Interpolation skalieren Allgemeine Java-Themen 31
O Text aus einer Textdatei rausholen, der zwischen zwei Schlüsselworten steht Allgemeine Java-Themen 4
D Zwei Listen vergleichen Allgemeine Java-Themen 7
Tobero Wie berechnet man ob zwei Linien sich schneiden? Allgemeine Java-Themen 2
kodela Zwei gleichzeitig gedrückte Steuertasten Allgemeine Java-Themen 10
X Bedingung zwei mal überprüfen Allgemeine Java-Themen 4
Zrebna Random Number - Generische Formel zwischen zwei INKLUSIVEN Werten Allgemeine Java-Themen 16
D Input/Output Zwischen zwei ID-Räumen unterscheiden und Objekt löschen Allgemeine Java-Themen 16
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
S Wenn eine Klasse zwei Interfaces mit derselben Methodensignatur implementiert: welche wird aufgerufen? Allgemeine Java-Themen 15
S Kann man Variablen oder Felder definieren deren Typ zwei Interfaces ist..? Allgemeine Java-Themen 9
K Aus String zwei Jahreszahlen auslesen Allgemeine Java-Themen 18
M Wie kann man eine void Methode mit Variablen von zwei verschiedenen Objekten ausführen? Allgemeine Java-Themen 15
VfL_Freak Double mit zwei festen NK-Stellen ausgeben Allgemeine Java-Themen 9
Neoline Methoden Zwei Arrays abwechselnd zusammenführen Allgemeine Java-Themen 15
J Zwei Wavdateien gleichzeitig mit SourceDataLine abspielen Allgemeine Java-Themen 0
D Best Practice Die niedrigste Differenz zwischen zwei Listen ermitteln. Allgemeine Java-Themen 10
J Fahrroute zwischen zwei Punkten finden Allgemeine Java-Themen 1
J Kollision von zwei Kreisen Allgemeine Java-Themen 15
J Transfer von Integer zwischen zwei Clients - RMI Allgemeine Java-Themen 4
S Variablen split-Funkton mit zwei Variabeln verwenden? Allgemeine Java-Themen 4
T Alle Kombinationen aus zwei Arrays Allgemeine Java-Themen 8
G Liste zwischen zwei Kalenderdaten erstellen Allgemeine Java-Themen 3
AssELAss Zwei Arrays / ArrayLists inhaltlich vergleichen Allgemeine Java-Themen 2
H RegularExpression zwischen zwei Strings Allgemeine Java-Themen 2
P Zwei Applikationen mit einem Job Allgemeine Java-Themen 0
E Berechnung des Schnittpunktes von zwei Geraden Allgemeine Java-Themen 1
S Zwei String vergleichen, Fehler markieren Allgemeine Java-Themen 3
G Matrix reduzieren zwei Methoden Allgemeine Java-Themen 2
Dechasa Vergleichen von zwei Arrays Allgemeine Java-Themen 4
P Zwei ArrayLists: Ohne die eine überhaupt anzurühren, wird sie verändert Allgemeine Java-Themen 2
S Anwendung zum ausrechnen der Differenz von zwei Tagen Allgemeine Java-Themen 9
F Zwei LinkedHashMaps iterieren und vergleichen Allgemeine Java-Themen 2
M Zwei unterschiedliche JAR Dateien mit ANT erstellen Allgemeine Java-Themen 8
B Fehler beim Auslesen von Einstellungen. Zwei ähnliche Blöcke, nur eins geht. Allgemeine Java-Themen 5
L Zwei Files miteinander vergleichen und Grafisch darstellen Allgemeine Java-Themen 1
T Zwei Wortendungen vergleichen ohne .equals Allgemeine Java-Themen 10
F Webstart zwei Java Versionen / aktivieren bzw deaktivieren Allgemeine Java-Themen 2
S Zwei Comparable (compareTo) vergleichen Allgemeine Java-Themen 6
E zwei Gleitkommazahlen durcheinander dividieren Allgemeine Java-Themen 2
X Generic muss zwei Klassen/Interfaces erfüllen Allgemeine Java-Themen 5
turmaline OOP zwei gleiche Methoden mit kleinen Unterschieden Allgemeine Java-Themen 15
C Threads Zwei Threads greifen auf LinkedList zu. Allgemeine Java-Themen 12
T Wie heißt ein Binärbaum, dessen Knoten immer zwei Kinder haben müssen? Allgemeine Java-Themen 2
C ActionListener zwei Buttons zuweisen Allgemeine Java-Themen 11
M Eclipse drei slashs durch zwei ersetzen? Allgemeine Java-Themen 3
1 zwei Strings vergleichen Allgemeine Java-Themen 16
C Buchstaben, die in zwei Wörtern vorkommen Allgemeine Java-Themen 13
J Gleiche Packagestruktur in zwei *.jar Dateien Allgemeine Java-Themen 4
G Zwei bytes vergleichen Allgemeine Java-Themen 2
B zwei-dimensionale Collections bzw. Array mit Indizes Allgemeine Java-Themen 3
C Zwei Arrays vereinen Allgemeine Java-Themen 3
K Objekt-Austausch zwischen zwei Programmen über System-Clipboard Allgemeine Java-Themen 5
H Zwei verschiedene Dateien mittels einem Binärstream übertragen? Allgemeine Java-Themen 13
N hashCode() für zwei ints Allgemeine Java-Themen 5
turmaline Gleichheit von zwei Maps Map <String, Map <String, String>> Allgemeine Java-Themen 30
N Wie Listenabgleich auf zwei CPU Cores auslagern? Allgemeine Java-Themen 6
D Zufall wahr bzw. falsch mit zwei Faktoren Allgemeine Java-Themen 10
H Datenaustausch zwischen zwei Java-Programmen Allgemeine Java-Themen 5
H Ausgabe von zwei Textfeldern Allgemeine Java-Themen 3
H Zwei unabhängige Threads miteinander kommunizieren lassen Allgemeine Java-Themen 3
G zwei mal synchronized Allgemeine Java-Themen 5
Z zwei Daten vergleichen Allgemeine Java-Themen 4
C ArrayList anhand von zwei Attributen sortieren Allgemeine Java-Themen 4
S Alle Elemente von zwei Listen vergleichen Allgemeine Java-Themen 10
T IText: Zwei A4 PDF´s auf ein A3 PDF´s Allgemeine Java-Themen 2
J Verschachtelte ListIteratoren um in zwei Listen hin und herzugehen Allgemeine Java-Themen 5
A Differenz zwischen zwei Uhrzeiten Allgemeine Java-Themen 7
H Shortcut ruft zwei Menu-punkte auf Allgemeine Java-Themen 5
J Zwei konstruktoren? Allgemeine Java-Themen 8
A zwei listen vergleichen und unterschiede anzeigen Allgemeine Java-Themen 3
J Zwei sortierte Listen zusammenfassen Allgemeine Java-Themen 8
G Linked List zwischen zwei Threds übergeben Allgemeine Java-Themen 11
J zwei HashMaps vereinen Allgemeine Java-Themen 3
C Viele Informationen aus zwei Collections vergleichen Allgemeine Java-Themen 2
G Jfreechart zwei charts Allgemeine Java-Themen 2
S Zwei Anwendungen unter Tomcat Allgemeine Java-Themen 4
T Anzahl Tage zwischen zwei Daten - Stunde fehlt? Allgemeine Java-Themen 2
V Zwei ArrayList(s) vergleichen Allgemeine Java-Themen 6
T Überprüfen ob zwei Farben ähnlich sind Allgemeine Java-Themen 14
M zwei main-Methoden Allgemeine Java-Themen 7
P zwei JFrames zusammenhängen Allgemeine Java-Themen 4
A Summe und Produkt von zwei Feldern ( arrays) Allgemeine Java-Themen 9
M HashMap kapselt zwei Objekte aber wie baut man eine Matrix? Allgemeine Java-Themen 2
H zwei Date Variablen überschreiben sich Allgemeine Java-Themen 2
2 Tage zwischen zwei Datumsdaten zählen Allgemeine Java-Themen 2
G Tage zwischen zwei Datumsdaten zählen Allgemeine Java-Themen 3
J Zwei String auf ähnlichkeiten untersuchen? Allgemeine Java-Themen 3
C kürzester weg zwischen zwei Punkten, Koordinaten finden Allgemeine Java-Themen 15
B zwei Bilder miteinander vergleichen Allgemeine Java-Themen 25
L Anzahl Tage zwischen zwei Kalenderdaten Allgemeine Java-Themen 5
P Threadprogrammierung - zwei Threads parallel - einer beendet Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben