Funktionswert einer Reihenentwicklung

ocsme

Top Contributor
Guten Tag,

ich hatte gerade mal etwas Zeit und habe meine Formelsammlung versucht weiter aufzubessern. Hab schon einige Funktionen selbst Programmiert.
Nun sitze ich vor einem Problem und komme nicht ganz zurecht :(
Die Funktion ist: f(x)=(1/Math.sqrt(1+x)) Für alle |x| < 1
Die Potenzreihe sieht wie folgt aus:
1-(1/2)*x+(3/8)*x*x-(15/48)x*x*x+...
Wie man sieht stehen im Nenner alle ungeraden (n*2-1) Produkte und im Zähler die geraden also (n*2) Produkte.

Das ganze hab ich so Programmiert:
Java:
public static double f(double x) {
        double basis=x;
        int k=0;
        double product=1;
        int n=1;
        double an=1;
        double sn=1;
        while(Math.abs(an)>EPSILON*Math.abs(sn)) {
            k=n;
            while(k>0) {
                product*=basis;
                k--;
            }
            an*=-(2*n-1)*product/(2*n);
            sn+=an;
            n++;
        }
        return sn;
    }

Problem ist:
bei der Eingabe von:
Java:
System.out.println(f(.9));
        System.out.println(1/Math.sqrt(1+.9));
bekomme ich eine abweichung von 0.01...
0.7147474611281968
0.7254762501100117
Und das ganze wird nicht besser bei anderen Zahlen :(

Ich finde den Fehler leider nicht.

Vielleicht hat ja jemand eine Idee :)

LG
 

ocsme

Top Contributor
huppsi das ist ganz oben in der Klasse definiert und gleich vergessen worden :D
Java:
public final static double EPSILON = 1E-16;

Ich weiß auch dass, das Potenzieren in meiner Funktion nicht so schön ist denn wenn man das Nachfolgeglied der Reihe berechnen würde wäre es eleganter.
Doch leider habe ich mich dabei noch mehr verrechnet :( deswegen hab ich es so gemacht :)
 

ocsme

Top Contributor
Hatte es falsch da Zähler und Nenner falsch waren oben.
Jetzt stimmt es zwar annähernd doch leider bekomme ich bei Epsilon 1e-9 und größer nan raus :(
Java:
public static double f(double x) {
        int n=1,k,l,m;
        boolean plus=false;
        double nachfolger=0, abstand=1, vorgaenger=x, result=1;
        double tmp, productzaehler=1, productnenner=1,potenz=1;
       
        while(abstand>EPSILON) {
            abstand=vorgaenger-nachfolger;
            if(abstand<0)
                abstand=-abstand;
            vorgaenger=nachfolger;
           
            k=n;
            l=n;
            m=n;
            while(k>0) {
                potenz*=x;
                k--;
            }
            while(l>0) {
                productzaehler*=2*l-1;
                l--;
            }
            while(m>0) {
                productnenner*=2*m;
                m--;
            }
           
            tmp=productzaehler*potenz/productnenner;
            if(!plus)
                tmp=-tmp;

            result+=tmp;
            nachfolger=result;
            System.out.println(abstand);
            plus=!plus;
            n++;
            productzaehler=1;
            productnenner=1;
            potenz=1;
           
        }
        return result;
    }
 

mihe7

Top Contributor
Ohne jetzt auf etwaige Fehler Deines Codes einzugehen (das ist mir zu kompliziert :)) ist das grundsätzliche Problem, dass die Zahlen relativ zügig den Wertebereich verlassen, wenn Du Zähler und Nenner separat ausrechnest.

Ich würde mir einfach mal anschauen, ob ich die Folgeglieder nicht rekursiv angeben kann... Wie entsteht denn das n-te Folgeglied aus dem (n-1)-ten?
 

ocsme

Top Contributor
Interessante Idee :)
Denke das werde ich mir mal überlegen :)
Noch eine andere Frage wo kann ich den vernünftig etwas über UML nachlesen? Vor allem zu den Klassendiagrammen was das Thema Vererbung (Interface, ABC und extends (vererbten) Klassen) angeht?
Ich weiß zwar wie eine Klasse aussehen muss im UML etc. doch die Begriffe: Assoziationen, Aggregationen, Kompositionen oder Spezialisierungen z. B. wollte ich mal nachschlagen. Im Internet habe ich nichts wirklich auf Anhieb brauchbares gefunden :(

LG
 

mihe7

Top Contributor
In der Spezifikation, die ist aber nichts für schwache Nerven :)
https://www.omg.org/spec/UML/About-UML/#docs-normative-supporting

Ansonsten: Assoziation ist eine einfache Beziehung. Aggregation und Kompositionen beschreiben Ganzes-Teile-Beziehungen, wobei Komposition die stärkere ist, die ausdrückt, dass ein Teil zu einem Zeitpunkt immer nur zu einem Ganzen zugehörig sein kann und das dieses Teil ohne das Ganze nicht sinnvoll existieren kann.

Typisches Beispiel für eine Komposition wäre die Beziehung zwischen Rechnung und Rechnungsposition. Eine Rechnungsposition (hier ist das Objekt gemeint) ist klar Teil einer Rechnung, kann nicht zugleich Teil einer anderen Rechnung sein und auch nicht ohne eine Rechnung (sinnvoll) existieren.

Wenn Du dagegen in einem Grafikprogramm eine Gruppe aus grafischen Elementen bildest, dann ist es zwar auch eine Ganzes-Teile-Beziehung, aber nur eine Aggregation: die Elemente können auch gut ohne ihre Gruppe existieren.

Eine Assoziation ist dagegen eine einfach Beziehung. Für den Kunden existieren Rechnungen.

Der Rest (Interfaces, Spezialisierung) sollte relativ einfach zu verstehen sein.
 

mihe7

Top Contributor
Inhaltlich steht da nicht mehr drin als in der FAQ (im Gegenteil, in der FAQ wird noch auf die Zahl der signifikanten Stellen eingegangen). In der Diskussion geht es schlicht um die Ungenauigkeit der binären Darstellung dezimaler Nachkommastellen mittels Gleitkommazahlen. Natürlich summiert sich ein Fehler auf. Aber nicht zu ein paar Zehnteln nach ein paar Schritten.

Bei seinem Code ist das größte Übel das faktorielle Wachstum von Zähler und Nenner. Da ist nach ein paar Iterationen Schluss mit lustig. Daher sollte er Zähler und Nenner nicht separat ausrechnen, sondern sich die Beziehung der Folgeglieder überlegen. Bildet man die Summe, erhält man als Ergebnis:
Code:
0.7254762501100119 (Näherung)
0.7254762501100117 (1/Math.sqrt(1.9))
Diese Differenz dürfte sich tatsächlich durch Fehlerfortpflanzung erklären lassen.
 

ocsme

Top Contributor
genau.
Das habe ich bei cos, sins, quadratwurzel etc. auch hin bekommen. Doch bei dieser Aufgabe habe ich es irgendwie falsch berechnet das Folgeglied.
Es ist ja eigentlich nur a_n+1/a_n doch irgendwas ist falsch deswegen dachte ich mir "EGAL" ich schreibe es einfach so aus :D
Das ist/war aber ja ein Satz mit X man sieht es ja an der Fehlerfortpflanzung :( echt übel!
LG
 

ocsme

Top Contributor
Mein Fehler ist beim Rechnen nicht das Rechnen sondern ich bin schon zu doof die Reihe richtig auf zu schreiben.
Wie schreibt man denn 1 - 1/2*x + 1*3/2*4*x^2 - ....
als Summe auf? Ich hatte einfach (-1)^n ((2*n-1)*x^n)/(2*n) doch das ist ja quatsch. Dann ist das 3te Glied ja nicht mehr (1*3)/(2*4)*x^2 sondern 3/4*x^2 !!!!
 

mihe7

Top Contributor
Du brauchst die Summe nicht aufschreiben, Du musst dir lediglich die Folgeglieder ansehen: was musst Du tun, um von "3/8 x^2" auf "15/48 x^3" zu kommen?
 

mihe7

Top Contributor
Als Summe wäre es, wenn ich mich jetzt nicht vertan habe:
1 + sum_{i=1}^{infty} [(-1)^i * (prod_{j=1}^i 2j-1) / (prod_{j=1}^i 2j) * x^i]
 

ocsme

Top Contributor
ja du hast jetzt in der Summe auf dem Bruchstrich das Produktzeichen benutzt!
Das ist mir vorhin bei meinem letzten Post auch erst aufgefallen das es so sein muss! das Zweite Produktzeichen kannst du aber weg lassen :)
Ich rechne die Sachen vorher aus wie gesagt mit den Folgegliedern dann gehen solche Aufgaben sehr einfach und effizient :)

wenn ich von 3/8 auf 15/48 kommen will rechne ich einfach *= 5/6 das ist ja wieder 2*n-1 und 2*n n=3 da x^n = x^3 :)
das ganze hatte ich versucht dann aufzumultiplizieren doch das hat nicht funktioniert deswegen habe ich die 3 schleifen gemacht was total "schrecklich" ist!

LG
 

mihe7

Top Contributor
wenn ich von 3/8 auf 15/48 kommen will rechne ich einfach *= 5/6 das ist ja wieder 2*n-1 und 2*n
Genau. Wenn Du noch das x dazunimmst, erhältst Du
Code:
f(n) = -f(n-1)*x*(2(n-1)-1)/(2(n-1)), f(0)=1

Code:
f(1) = 1
f(2) = -f(1)*x*1/2 = -1/2 x
f(3) = -f(2)*x*3/4 = 1/2 x^2 * 3/4 = 3/8 x^2
f(4) = -f(3)*x*5/6 = -3/8 x^3 * 5/6 = -15/48 x^3
...
Wenn Du also das Folgeglied mit sn bezeichnest, dann kannst Du in einer Schleife ganz einfach ein neues Folgeglied berechnen und auf Deine Summe zählen.
 

ocsme

Top Contributor
o_O kann das sein das es Rekursiv leichter geht so schön wie du es dort aufgeschrieben hast :) sieht es so aus!
Ich habe mich derzeit leider nicht mehr weiter um die Aufgabe gekümmert deswegen sry!
Werde heute wieder einiges an Übungen machen hoffe ich komme wieder dazu das hier mal FERTIG zu machen.
Meins läuft ja wenn man über die "Fehlerfortpflanzung" hinweg sehen würde :D haha! stellt man sich vor so würden die Ingeniuere arbeiten die Pilotensysteme bauen!!! *Kopfschüttel* <- soll ein Witz sein!!! nicht ernst nehmen ;)

LG
 

mihe7

Top Contributor
Naja, so schlimm sieht das iterativ jetzt auch nicht aus:
Java:
    public static double f(double x) {
        double sum = 0;
        double sn = 1;
        double n = 2;
        while (Math.abs(sn) > 1E-16) {
            sum += sn;
            sn = x*(sn/n - sn);
            n += 2;
        }
        return sum;
    }
 

ocsme

Top Contributor
o_O das hätte ich wieder viel zu umständlich gemacht :( grrr.....!!!
Vielleicht schaffe ich es ja noch alleine Rekursiv :D doch dazu erst später okay :)
Nochmals DANKE :) *DaumenHOCH*
 

ocsme

Top Contributor
Ich sehe grade das ich ein Problem habe wie kommst du denn auf die geniale Formel?
sn = x*(sn/n - sn);

Ich hab es nachgerechnet im dritten Schritt kommt ja raus 1/2/4 also 1/8 - 1/2 dann noch und das gibt dann 3/8 =) Wie kommt man auf sowas? Ich bin zu doof :(!!!
 

mihe7

Top Contributor
Das ist einfach das Ergebnis von -f(n-1)*x*(2(n-1)-1)/(2(n-1))

Hier mal eine Nebenrechnung ohne x. Ich setze mal m := n-1, damit das hier schöner zu lesen ist:
Code:
  -f(m)*(2m-1)/2m
   ^^^^^^^^^^^ ausrechnen
= -(f(m)*2m/2m - f(m)/2m)
         ^^^^^ = 1
= -(f(m) - f(m)/2m)
  ^^ ausrechnen
= -f(m) + f(m)/2m
  ^^^^^   ^^^^^^^ umstellen
= f(m)/2m - f(m)
Danach wieder mit x multiplizieren und gut ists.

Das führt im Code zunächst zu
Java:
sn = x*(sn/(2*n) - sn)
n++;

Da der Spaß in einer Schleife läuft und Multiplikation ja nur das wiederholte Anwenden der Addition ist, lasse ich n gleich um 2 hochzählen und kann damit die Multiplikation im Teiler streichen. Übrig bleibt also:
Java:
sn = x*(sn/n - sn)
n+=2;
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
TimoN11 Quadratwurzel mittels Funktionswert der Quadratfunktion Java Basics - Anfänger-Themen 9
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
ixChronos Letzten 4 Ziffern einer großen Zahl ausgeben Java Basics - Anfänger-Themen 3
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
Shadowrunner Variablen Gibt es eine Möglichkeit die Ziffern/Stellen einer Zahl fest zu legen? Java Basics - Anfänger-Themen 3
D remove Object von einer Liste von Obejcts Java Basics - Anfänger-Themen 3
FunkyPhil94 Wert in einer Lambda Funktion erhöhen Java Basics - Anfänger-Themen 3
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
B Kommunikation mit Seriellen Schnittstellen + Integration einer lib Java Basics - Anfänger-Themen 1
A Daten aus einer HashMap aus einer DB speichern und mit neuen Werten vergleichen Java Basics - Anfänger-Themen 8
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
D Länge einer Liste aufrufen. Java Basics - Anfänger-Themen 19
J Klassen Instanzen einer Klasse in einer anderen unabhängigen Klasse nutzen Java Basics - Anfänger-Themen 4
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
M Radius von einer ellipse bestimmen Java Basics - Anfänger-Themen 7
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
M Zufallszahl generieren mit einer linken und rechten Grenze Java Basics - Anfänger-Themen 3
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
S Best Practice Fragen zu Projektstruktur einer Datenbank-Abfrage-App (MVC) Java Basics - Anfänger-Themen 13
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
nelsonmandela Problem bei Ausgabe einer Switch - Case Funktion Java Basics - Anfänger-Themen 5
S Textausgabe in einer For-Schleife Java Basics - Anfänger-Themen 12
M Spezifischen Wert einer Zeile aus .txt Datei entnehmen Java Basics - Anfänger-Themen 15
B Popups mit Klicksabfangen zumAusfüllen einer .ods Datei Java Basics - Anfänger-Themen 0
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
E Suchfunktion in einer Liste Java Basics - Anfänger-Themen 39
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
FireHorses Einen Command erst nach einer Chateingabe aktivieren Java Basics - Anfänger-Themen 1
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
F wie kann ich die Position des letzten Vokals innerhalb einer Zeichenkette ermitteln? Java Basics - Anfänger-Themen 5
H Kapselung protected aber in einer Kindklasse nicht zugänglich Java Basics - Anfänger-Themen 5
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
Saiko Zeilen einer Datei einlesen Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
sserio Prüfziffer einer ISBN Nummer herrausfinden. Java Basics - Anfänger-Themen 14
J Benennung einer mir unbekannten Java - Ausdrucksweise Java Basics - Anfänger-Themen 5
LFB In einer For-Schleife alles in einer Zeile ausgeben Java Basics - Anfänger-Themen 14
sserio Wie kann man nach einer Klasse fragen? Java Basics - Anfänger-Themen 12
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Wie gebe ich den Pfad zu einer Datei an, die in einem Ordner in Eclipse ist? Java Basics - Anfänger-Themen 1
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
J int innerhalb einer Datei ändern Java Basics - Anfänger-Themen 1
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
Neuling47 Ich zerbreche mit den kopf an einer Aufgabe Java Basics - Anfänger-Themen 61
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
J Zelleninhalt einer Jtable löschen Java Basics - Anfänger-Themen 2
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
stormyark 4 Bit in einer for-schleife funktioniert nicht Java Basics - Anfänger-Themen 3
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
A Ein Array bearbeiten und in einer anderen Methode nutzen Java Basics - Anfänger-Themen 6
A Ergebnis einer Methode bei einer anderen verwenden Java Basics - Anfänger-Themen 13
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
M Interface als Parameter einer Klasse Java Basics - Anfänger-Themen 8
I Liste von Infos von einer eigenen Annotation in Liste speichern Java Basics - Anfänger-Themen 0
M Wie kann ich den Index i von einer LinkedList überprüfen? Java Basics - Anfänger-Themen 36
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
javapingu Jeglichen Inhalt einer Textdatei nach Zeile n löschen Java Basics - Anfänger-Themen 8
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
P Iterieren mit einer Foreach in Lambdaschreibweise und Counter. Java Basics - Anfänger-Themen 1
M Methoden Wert einer Variable geht verloren? Java Basics - Anfänger-Themen 6
W Wie ziehe ich von einer bestimmten Zahl, Zahlen ab, bis mein Ergebnis null beträgt? Java Basics - Anfänger-Themen 10
X Was ist der Unterschied zwischen materialisierten und nichtmaterialisierten Attributen einer Klasse? Java Basics - Anfänger-Themen 1
U Wie ein Attribut von einer Klassenmethode in der Klasse speichern= Java Basics - Anfänger-Themen 2
M Wie richte ich eine Diagonale an Robotern in einer World ein? Java Basics - Anfänger-Themen 15
YAZZ BlueJ Bewegung einer Figur im Kreis Java Basics - Anfänger-Themen 4
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
A Verarbeiten einer Excel Datei durch das java-Programm Java Basics - Anfänger-Themen 3
B GUI extension mit einer Liste verbinden Java Basics - Anfänger-Themen 1
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S Hilfe bei Programmierung einer Hotelabrechnung Java Basics - Anfänger-Themen 5
W Verschiedene Methoden in einer Klasse in der Main aufrufen? Java Basics - Anfänger-Themen 8
J if-Schleife innerhalb einer if-Schleife wird in der Konsole nicht gelesen Java Basics - Anfänger-Themen 4
D Grösste Zahl in einer Folge herausfinden. (ULAM) Java Basics - Anfänger-Themen 9
Ameise04 Variablen Inhalt einer Variable im Code verwenden? Java Basics - Anfänger-Themen 9

Ähnliche Java Themen

Neue Themen


Oben