Objekt entlang eines Funktionsgraphens bewegen

Hallo,

momentan versuche ich ein kleines 2D-Spiel zu programmieren, wo man mit nem Raumschiff durchs Weltall fliegt. Jetzt versuche ich umzusetzen, dass sich das Raumschiff entlang einer Route bewegt, die durch eine ganzrationale Funktion definiert ist.

Mein Ansatz bis jetzt:

Das Raumschiff hat eine gewisse Geschwindigkeit. Jetzt möchte ich wissen, wo genau das Raumschiff nach einer bestimmten Zeit ist. Dazu habe ich die Länge des Funktionsgraphen (s = v*t) gegeben. Daraus muss ich jetzt den x-Wert der Funktion bestimmen. Ich habe herausbekommen, dass die Länge des Graphens folgendermaßen definiert ist:
Integral[Länge des Graphen] = Integral[(sqrt(1+f'(x)^2) dx]

Die Funktion beschreibe ich mit einem Array der Faktoren, ein Beispiel:
f(x) = 2x^2 + 0.5 --> factors[0] = 0.5 ; factors[1] = 0 ; factors[2] = 2
Die Faktoren sind also für die jeweiligen Exponenten gespeichert: factors * x ^ i
Ich habe bereits die Methoden zum Ableiten, Stammfunktion (mit c = 0) bilden, den y-Wert berechnen und Funktionsterm quadrieren geschrieben und diese scheinen zu funktionieren. Jetzt habe ich das Problem, dass ich keine Ahnung habe, wie ich die Wurzel aus einem Funktionsterm ziehe. Dazu bräuchte ich soweit ich weiß sowas wie ne quadratische Ergänzung für Polynome. Ich dachte, dass mir hier vielleicht jemand von euch helfen könnte.

Falls ihr euch die Klasse mal anschauen wollt:
Java:
public class PolynominalFunction extends Function{
	
	double[] factors;
	
	public PolynominalFunction(double[] factors) {
		this.factors = factors;
	}
	
	@Override
	public double getY(double x) {
		double result = 0;
		for (int i = 0 ; i < factors.length ; i++){
			if (factors[i] == 0)
				continue;
			if (i == 0)
				result += factors[i];
			else
				result += factors[i]*Math.pow(x, i);
		}
		return result;
	}

	@Override
	public PolynominalFunction derive() {
		if (factors.length == 0)
			return new PolynominalFunction(new double[]{});
		double[] newFactors = new double[factors.length-1];
		for (int i = 1 ; i < factors.length ; i++)
			newFactors[i-1] = factors[i]*i;
		return new PolynominalFunction(newFactors);
	}

	@Override
	public PolynominalFunction antiderive() {
		if (factors.length == 0)
			return new PolynominalFunction(new double[]{});
		double[] newFactors = new double[factors.length+1];
		for (int i = 0 ; i < factors.length ; i++)
			newFactors[i+1] = factors[i]/(i+1);
		return new PolynominalFunction(newFactors);
	}
	
	public String serialize(){
		String s = null;
		for (int i = factors.length-1 ; i >= 0 ; i--){
			if (factors[i] == 0)
				continue;
			if (s == null)
				s = factors[i]+"*x^"+i;
			else{
				if (factors[i] > 0)
					s += "+";
				s += factors[i]+"*x^"+i;
			}
		}
		return s;
	}

	@Override
	public PolynominalFunction square() {
		if (factors.length == 0)
			return new PolynominalFunction(new double[]{});
		double[] newFactors = new double[factors.length*2];
		for (int i = 0 ; i < factors.length ; i++){
			newFactors[i*2] += factors[i]*factors[i];
			for (int k = i+1 ; k < factors.length ; k++){
				newFactors[i+k] += 2*factors[i]*factors[k];
			}
		}
		return new PolynominalFunction(newFactors);
	}

Ist mein Ansatz vielleicht Falsch? Gibt's da was einfacheres?
Ich bin für Vorschläge offen :D

Falls es Probleme damit gibt meinen Ansatz zu verstehen sag bescheid, dann werde ich das versuchen zu illustrieren.
 
Zuletzt bearbeitet:

DrZoidberg

Top Contributor
Wenn du Java 8 verwendest, kannst du das ganze mit Lambda Ausdrücken deutlich kürzer formulieren.
z.B. mittles java.util.function.DoubleUnaryOperator

Java:
static double integrateLength(DoubleUnaryOperator f, double x1, double x2, double dx) {
  double result = 0;
  double lastX = x1, lastY = f.applyAsDouble(lastX);
  for(double x = x1+dx; x <= x2; x += dx) {
    double y = f.applyAsDouble(x);
    result += Math.sqrt((x - lastX) * (x - lastX) + (y - lastY) * (y - lastY));
    lastX = x; lastY = y;
  }
  return result;
}

public static void main(String[] args) {
  DoubleUnaryOperator f = x -> 2*x*x + 3*x - 7;
  System.out.println(integrateLength(f, 0, 10, 0.1));
}
 
Zuletzt bearbeitet:

DrZoidberg

Top Contributor
Du könntest übrigens auch deine selbst definierte Function Klasse zu einem Interface machen und dieses dann als @FunctionalInterface deklarieren. Dann packst du da "integrateLength " als default Methode rein und überschreibst das in der PolynominalFunction Klasse. Denn für Polynome ist deine Klasse schneller und genauer als die allgemeine Lösung, die ich gepostet habe. Dafür funktioniert meine Methode aber mit jeder beliebigen Funktion.
 
So, ich habe mir den Code jetzt mal nach einer längeren Pause angesehen (davor nur überflogen). Mein Problem damit ist (falls ich es richtig verstanden habe), dass es nur eine Nährung ist, welche für eine größere Genauigkeit mehr Rechenzeit braucht. Ich halte sowas einfach für suboptimal. Man kann ja auch die Fläche unter einer Funktion exakt per Integralrechnung bestimmen und muss nicht mit der Streifenmethode arbeiten.
Scheinbar ist ja die Methode die ich suche diese hier:

Integral[Länge des Graphen] = Integral[(sqrt(1+f'(x)^2) dx]

Dabei habe ich soweit jedes Problem gelöst, bis auf eins: die Wurzel aus einem Polynom zu ziehen. Kann mir da vielleicht jemand einen Tipp geben, welchen Ansatz ich verfolgen muss? Mein Kopf kommt nicht mehr mit, wenn ich die quadratische Ergänzung auf beliebig viele Polynomglieder ausweiten möchte. Das erscheint mir einfach extrem kompliziert, aber wahrscheinlich gibt es dafür einen relativ einfachen Algorithmus. Wenn das quadrieren so einfach ist (s. Methode oben) muss das Wurzelziehen auch machbar sein.
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Lwjgl 3d Objekt wird schmaler, wenn es sich dreht Allgemeine Java-Themen 0
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
T Objekt Array Aufgabe mit Busdatenbank Allgemeine Java-Themen 2
Maxi-JOO Klassen Dummy Objekt in anderen Constructor übergeben Allgemeine Java-Themen 5
el_niiinho13 Objekt auf der Konsole ausgeben lassen Allgemeine Java-Themen 8
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
A Objekt aus anderen Objekten machen Allgemeine Java-Themen 8
SaftigMelo In einem Winkel Objekt bewegen Allgemeine Java-Themen 2
E Datentypen Wie kann ich die Längen der unterschiedlichen Ebenen aus einem Objekt lesen von dem ich weiß, dass es ein mehrdimensionaler Array ist? Allgemeine Java-Themen 3
H Objekt speichern und laden Allgemeine Java-Themen 1
H Objekt speichern und laden Allgemeine Java-Themen 1
J Objekt in Bytestream umwandeln Allgemeine Java-Themen 12
J Wie kann ich von Vornherrein einen Fokus auf ein Objekt entfernen? Allgemeine Java-Themen 3
J Information von getSource() Objekt auslesen Allgemeine Java-Themen 1
Drachenbauer Wie stelle ich fest, ob ein Objekt in meinem Array vorkommt? Allgemeine Java-Themen 5
S Variable als Objekt Name Allgemeine Java-Themen 3
D Input/Output Zwischen zwei ID-Räumen unterscheiden und Objekt löschen Allgemeine Java-Themen 16
L Objekt aus Objekt-array "löschen" Allgemeine Java-Themen 2
T Objekt mit String und Int aus TxT Datei erstellen Allgemeine Java-Themen 23
T Objekt in Array packen Allgemeine Java-Themen 6
K Methodenaufruf mit String / String zu Objekt konvertieren Allgemeine Java-Themen 8
S Neues Objekt darstellen Allgemeine Java-Themen 4
J Best Practice Objekt an alle Klassen verteilen ( Discord Bot ) Allgemeine Java-Themen 7
D Objekt-Suche mit mehreren optionalen Parametern Allgemeine Java-Themen 6
M Klassen Objekt weiter geben Allgemeine Java-Themen 1
B Klassen Objekt erzeugen und Konstruktor aufrufen - Welche Lösung ist besser? Allgemeine Java-Themen 2
L Variablen Eigenes Objekt wie z.B. einen Integer zuweisen Allgemeine Java-Themen 3
D Konstruktor - jedes Objekt einzeln erzeugen - alternative? Allgemeine Java-Themen 8
S Applet Überprüfen ob ein Objekt angeklickt wurde Allgemeine Java-Themen 2
RalleYTN 3D Objekt Translation basierend auf Rotation (Probleme mit Z Rotation) Allgemeine Java-Themen 0
B Von String zu <Objekt> ||Speichern/Laden Allgemeine Java-Themen 17
G Neues Objekt aus List<JsonObject> mit Stream Allgemeine Java-Themen 4
P Threads Objekt im Konstruktor anders wie im Run()-Block Allgemeine Java-Themen 10
R Objekt funktioniert nicht auf iOS Allgemeine Java-Themen 15
K Textdatei als Objekt Allgemeine Java-Themen 4
Viktim Classenname zu Objekt Allgemeine Java-Themen 4
P Entity Objekt Methoden vs Service methoden Allgemeine Java-Themen 2
D Datentypen Klassenattribut aus Objekt in generischer Liste Allgemeine Java-Themen 15
O Klassen Bruch im gleichen Objekt Speichern Allgemeine Java-Themen 1
P Liste zu Objekt umwandeln Allgemeine Java-Themen 4
C Liste checken auf MINDESTENS ein Objekt | Bukkit Allgemeine Java-Themen 3
K Best Practice JFrame Objekt allgemein zugänglich machen Allgemeine Java-Themen 8
B ArrayList in ein Objekt legen Allgemeine Java-Themen 1
M Objekt serialisieren/deserialisieren und in einer SQLite-Datenbank speichern Allgemeine Java-Themen 3
D Java Objekt als Service in Runtime registrieren Allgemeine Java-Themen 1
S Interaktion mit einer website (website als Objekt?) Allgemeine Java-Themen 3
J OOP Überwachen, ob ein Objekt erzeugt wird Allgemeine Java-Themen 9
S Byte Array welches in Laufzeit aufgelöst wird // Objekt Array Allgemeine Java-Themen 3
Thallius Hash über serialisiertes Objekt? Allgemeine Java-Themen 3
Developer_X Input/Output Serialisiertes Objekt speichern und laden Allgemeine Java-Themen 1
C Generics Objekt in ArrayList Allgemeine Java-Themen 2
L Klassen Konstruktor soll Objekt anderer Klasse erzeugen Allgemeine Java-Themen 2
F Neues Objekt aus .CSV definition Allgemeine Java-Themen 3
K Methoden Objekt wird nicht erkannt Allgemeine Java-Themen 11
P Objekt mit verschiedenen Datentypen Allgemeine Java-Themen 5
T Objekt kontaktiert seinen "erzeuger" Allgemeine Java-Themen 5
S Objekt orientierte Programmierung Allgemeine Java-Themen 7
C Objekt Datenverlust nach Methodenaufruf Allgemeine Java-Themen 9
H JavaFX Von einer Methode auf stage-Objekt zugreifen Allgemeine Java-Themen 3
T WeakReference/PhantomReference: Mitbekommen WELCHES Objekt nun GC'ed wird Allgemeine Java-Themen 2
T Class-Objekt mit URLClassloader Allgemeine Java-Themen 7
P Konsoleneingabe übernehmen und Objekt instanzieren. Allgemeine Java-Themen 5
E Auf Java-Objekt aus anderer Instanz zugreifen Allgemeine Java-Themen 26
L Klassen Polymorphie:2 Attribute gleichen Namens in einem Objekt Allgemeine Java-Themen 6
P Objekt Array in Datei Speichern Allgemeine Java-Themen 3
F Dynamisch ein Objekt einer bestimmten Subklasse erstellen Allgemeine Java-Themen 7
D Player Objekt - Frame über Server anzeigen lassen. Allgemeine Java-Themen 3
V Objekt löschen Allgemeine Java-Themen 7
A OOP Wie auf Objekt der Superklasse zugreifen? Allgemeine Java-Themen 6
S Datei in File-Objekt mit UTF-8 einlesen Allgemeine Java-Themen 2
M neues Objekt speichern, nicht Referenz Allgemeine Java-Themen 10
B synchronisierter zugriff auf Objekt Allgemeine Java-Themen 6
F Objekt einer Datei verschieben, aber Verzeichnispfad fehlt Allgemeine Java-Themen 6
C Objekt Typ herausfinden Allgemeine Java-Themen 5
E Objekt beim Erzeugen in ArrayList Allgemeine Java-Themen 9
M Objekt prüfen auf null ->Invocation Target Exception??? Allgemeine Java-Themen 2
M Objekt aus Liste in Liste suchen/löschen Allgemeine Java-Themen 6
D Eigenen Objekt Pool Allgemeine Java-Themen 15
C blueJ: Objekt wird nicht in Objektleiste angezeigt Allgemeine Java-Themen 8
T Objekt 2x deserialisieren, aber nur 1x im Heap haben? Allgemeine Java-Themen 4
sambalmueslie Benachrichtigung bei neuer Objekt-Instanz Allgemeine Java-Themen 5
U Konstante in Objekt definieren Allgemeine Java-Themen 6
D this mit Objekt überschreiben Allgemeine Java-Themen 17
R Synchronized - auf welchem Objekt Allgemeine Java-Themen 16
E Objekt erstellen Allgemeine Java-Themen 7
M Timer von nicht existiertem Objekt stopen Allgemeine Java-Themen 5
M Swing-Frontend abhängig von ausgewähltem Objekt Allgemeine Java-Themen 4
J Lebt das Objekt noch?? Allgemeine Java-Themen 12
K Objekt einer konkreten Implementierung eines Interfaces durch übergebenen String Allgemeine Java-Themen 2
K Objekt-Austausch zwischen zwei Programmen über System-Clipboard Allgemeine Java-Themen 5
S Performance Frage: Objekt oder static? Allgemeine Java-Themen 33
B Speicherverbrauch Objekt-Referenz Allgemeine Java-Themen 11
D Browser-Objekt erzeugen Allgemeine Java-Themen 8
B FileWriter / FileReader testen / Mock-Objekt für Unit Tests? Allgemeine Java-Themen 6
A Iterationen einer XML-Datei in einem Objekt sichern Allgemeine Java-Themen 5
R Objekt zur Laufzeit zerstören? Allgemeine Java-Themen 12
hdi Frage zur Objekt Initialisierung Allgemeine Java-Themen 4
X Prozess-Objekt nach Ausführung der destroy-Methode null oder nicht null ? Allgemeine Java-Themen 10
T Serialisiertes Objekt über Socket nachladen Allgemeine Java-Themen 8
G Entity Objekt Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben