Mit double und BigDecimal rechnen

Status
Nicht offen für weitere Antworten.
P

Purist

Gast
Heyho...Ich hab neu mit Java angefangen und hätte da mal ne Frage:

Und zwar muss ich näherungsweise einen Funktionswert f(x) berechnen, wobei sich das über ne Summenformel ergibt...hier zählt also ne Variable hoch im Prinzip von 0 bis unendlich, aber wir sagen halt dass die Schleife aufhörn soll wenn die Differenz zweier aufeinanderfolgenden Summanden kleiner als ein bestimmter vorgegebener Wert ist.
Die einzelnen Summenden berechne ich durch double-werte, das Problem is nur, dass da stark ansteigende Potenzen und Fakultäten drin sind...deshalb is double wohl nich so gut ^^ ausserdem wird der Näherungswert dann immer viel zu schnell aufgerundet.

Daher meine Frage: Wie kann ich das ganze genauer rechnen? Hab gehört dass BigDecimal wesentlich genauer sein soll, leider weiss ich nur net, wie ich das jetz umschreiben kann und diesen anderen Typ verwenden kann...

Bitte um Hilfe; Dankeschön ^^


...hier nebenbei die genaue Aufgabenstellung:

f(x) = sigma(voni=0 bis unendlich) über: (-1)^i * ( (2^i * x^2i) / (2i)! )

Das ganze soll aufsummiert werden bis sich der Wert der Summe nur noch um weniger als epsilon (hier 1.0E-8) ändert.
Die Funktionen für "hoch" und "Fakultät" hab ich selbst geschrieben; mit return = double.
 
S

SlaterB

Gast
die Grundlagen zu BigDecimal musst du schon in einem Lehrbuch lesen,
anders macht das keinen Sinn
http://openbook.galileocomputing.de/javainsel7/javainsel_05_007.htm

-----

spitzfindig sei noch angemerkt: wenn man durch Potenzen und Fakultät den double-Wertebereich verläßt,
ist es manchmal auch nicht weit bis zum Ende des BigDecimals-Bereichts, welcher nur durch den Arbeitsspeicher begrenzt ist (immerhin grob 64 MB statt 8 Byte)

manchmal ist es zielführender, sparsamer zu rechnen,
Beispielweise läßt sich 400!/395! auch recht genau in double rechnen, wenn man nur kürzt

ist bei deiner Formel etwas schwieriger, aber wollte ich nur allgemein erwähnen ;)
 
G

Guest

Gast
Also das mit dem Runden weiss ich...Hab auch schon versucht mir was zu überlegen wie ich das gescheit kürzen könnte aber mir is einfach nix eingefallen, zumindest nix was nich nen Aufwand von zig zeilen hätte xD

Und das mit den Grundlagen zu lernen versuch ich ja...Aber das is garnet so einfach xD
Ich hab hier z.b. nun:

Code:
BigDecimal ergebnis = new BigDecimal("1");
ergebnis = ergebnis.multiply (x);

das x is double (is ne Eingabe..)
und dann sagt er mir: Cannot find symbol - method multiply (double)


...Was sagt mir das jetzt? Ich weiss echt nich weiter wie ich da vorgehn soll xD Sry
 

Ark

Top Contributor
x müsste vom Typ BigDecimal sein, wenn ich richtig liege. Das steht aber alles genau in der API-Dokumentation.

Ark
 
S

SlaterB

Gast
die Fehlermeldung sagt, dass es keine Methode multiply(double) gibt,
das solltest du zügig verstehen lernen,

tja, der denkende Schritt wäre nun

BigDecimal ergebnis = new BigDecimal("1");
BigDecimal xBig = new BigDecimal(x);
ergebnis = ergebnis.multiply (xBig);

wenn man darauf nicht kommt, dann kann einem das auch niemand beibringen

es gibt speziell bei double noch die Besonderheit,
dass new BigDecimal(double); ungeignet ist,
besser BigDecimal.valueOf(x); wenn ich mich recht erinnere,

oder etwas aufwendiger wie hier:
http://www.3tools.de/2007-11-01/rundungsfehler-bei-bigdecimal
 
G

Guest

Gast
...also kann ich BigDecimal nur mit BigDecimal multiplizieren? :( Oh man...

Naja, kann man dann x (=double) irgendwie in BigDecimal umwandeln? ...Ich kann nich einfach das x anders definieren, das wird vorher schon bei ner anderen Funktion als double verwendet.
 

mahe

Aktives Mitglied
Jup, einfach im Konstruktor übergeben.

Potenzieren geht übrigens über Math.pow(x,y). Das bräuchtest Du also nicht selber schreiben.

Ist die Funktion für irgendwas gut oder lediglich als Übung/Aufgabe?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Output BigDecimal anstatt double / Problem beim Rechnen Java Basics - Anfänger-Themen 16
W Double or Float zusammenrechnen Java Basics - Anfänger-Themen 15
I Review von euch erwünscht, double Rechnung falsch Java Basics - Anfänger-Themen 34
X wie bekomme ich durch Eingabeaufforderung definierte double in einen Befehl, welcher 3 erwartete double braucht? Java Basics - Anfänger-Themen 3
Avalon String in Double bzw. Währung konvertieren Java Basics - Anfänger-Themen 6
MoxMorris Integer.MAX_VALUE und Double.MAX_VALUE Unterschied Java Basics - Anfänger-Themen 3
krgewb Double mit zwei Nachkommastellen Java Basics - Anfänger-Themen 2
B Produkt eines double - streams Java Basics - Anfänger-Themen 3
Lion.King Fehler in double und int Java Basics - Anfänger-Themen 7
F java: incompatible types: possible lossy conversion from double to int Java Basics - Anfänger-Themen 1
J Double Variable und Addition Java Basics - Anfänger-Themen 2
F Double Ausgabe nicht wissenschaftlich Java Basics - Anfänger-Themen 16
S Fragen zu Ausgabe double und float Java Basics - Anfänger-Themen 3
Kotelettklopfer Variablen Double zwingen Ganzzahlen mit 2 Nachkommastellen auszugeben Java Basics - Anfänger-Themen 10
A possible lossy conversion from double to int Java Basics - Anfänger-Themen 5
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18
FelixN Array mit verschiedene Datentypen als Rückgabewert? (Long und Double) Java Basics - Anfänger-Themen 3
J Transformation zweier Integer in ein Double Java Basics - Anfänger-Themen 26
N The method setSaldo(double) in the type Konto is not applicable for the arguments (int, int) Java Basics - Anfänger-Themen 2
C Konvertierung des int typs in den double typ für die Ausgabe mit Nachkommastellen Java Basics - Anfänger-Themen 4
V Erste Schritte Die Nuller bei double NICHT abschneiden Java Basics - Anfänger-Themen 4
Y Datentypen Double Division ungenau Java Basics - Anfänger-Themen 45
L Datentypen Rechnen und abrunden mit double Java Basics - Anfänger-Themen 7
M Writer für unterschiedliche Obj/inbt/double erstellen? Java Basics - Anfänger-Themen 1
F Character umwandeln als Double Werte Java Basics - Anfänger-Themen 8
M Double Wert nach n abschneiden ohne zu runden Java Basics - Anfänger-Themen 1
D Methode mit Übergabe double und Rückgabe String Java Basics - Anfänger-Themen 2
P Hilfe bei Double Java Basics - Anfänger-Themen 1
B Rückgabe von zwei Werten: String und double Java Basics - Anfänger-Themen 14
B HQL / Hibernate, GroupBy und Ausgabe als Double Java Basics - Anfänger-Themen 1
M Konvertierung String -> double Java Basics - Anfänger-Themen 8
A Double Scan eingrenzen Java Basics - Anfänger-Themen 2
O Erste Schritte Potenzmethode per double Java Basics - Anfänger-Themen 11
A Random Double mit Math.round() runden? Java Basics - Anfänger-Themen 1
H Double oder nicht? Java Basics - Anfänger-Themen 7
J int array als double array ausgeben Java Basics - Anfänger-Themen 9
M Int und Double in Array speichern Java Basics - Anfänger-Themen 1
J String, Int und double Array sortieren Java Basics - Anfänger-Themen 16
B Hashing (verkettet/double) Java Basics - Anfänger-Themen 0
L Konvertieren von String zu double?! Java Basics - Anfänger-Themen 6
V Operatoren Warum kommt bei double bei den Nachkommastellen irgendwann eine 2?! (1.20000000000002) Java Basics - Anfänger-Themen 5
geekex Double zu String umwandeln in einer Methode Java Basics - Anfänger-Themen 28
E Bruch erstellen - Von Int zu Double Ergebnis Java Basics - Anfänger-Themen 24
G Probleme beim casten von double zu int Java Basics - Anfänger-Themen 3
I Double.ParseDouble 2 Textfelder Java Basics - Anfänger-Themen 1
M JComboBox feste double Werte zu ordnen Java Basics - Anfänger-Themen 8
P Datentypen Kann ich bei double Komma statt Punkt eingeben? Java Basics - Anfänger-Themen 14
E Von Double zu Long umwandeln Java Basics - Anfänger-Themen 9
L Bei falscher Eingabe soll NaN zurückgegeben werden, Rückgabetyp jedoch double Java Basics - Anfänger-Themen 3
V Variablen Double später deklarieren Java Basics - Anfänger-Themen 7
V double = 1.34823e-300 Java Basics - Anfänger-Themen 5
W double*double error Java Basics - Anfänger-Themen 4
kilopack15 Mehr Nachkommastellen mit double Java Basics - Anfänger-Themen 14
T Input/Output Double und String als Eingabe einlesen Java Basics - Anfänger-Themen 9
J [Rundungsfehler bei Double] Grundkurs Java: Checke Lösungsweg nicht Java Basics - Anfänger-Themen 1
W In einer Function<Double, Double> undefinierte Rechenoperationen abfangen? Java Basics - Anfänger-Themen 3
T set Metode für Double Java Basics - Anfänger-Themen 6
Hijo2006 String to Double Java Basics - Anfänger-Themen 4
K Double Wert runden und in Int umwandeln Java Basics - Anfänger-Themen 7
A Kommafehler beim double einleseen korrigieren Java Basics - Anfänger-Themen 2
K Operatoren The Operator * is undefined for the argument type(s) double, String Java Basics - Anfänger-Themen 4
das_leon String zu double konventieren Java Basics - Anfänger-Themen 1
K Genauer als Double? Java Basics - Anfänger-Themen 4
T Double.parseDouble(args[0]) Java Basics - Anfänger-Themen 13
A Java Ungenauigkeit double Java Basics - Anfänger-Themen 6
B Methoden The method mirror(double[]) in the type Convolution is not applicable for the arguments (double) Java Basics - Anfänger-Themen 8
C Typumwandlung von int<-->double Java Basics - Anfänger-Themen 6
M Double Wert auf 2 Kommastellen runden Java Basics - Anfänger-Themen 2
S Regelabfragen aus Double-Array Java Basics - Anfänger-Themen 2
A Erste Schritte Double Wert aus String zu int Java Basics - Anfänger-Themen 2
P Rückgabe erflogt nicht als Double Java Basics - Anfänger-Themen 2
K Erste Schritte switch - Warum sind long/float/double/... nicht erlaubt? Java Basics - Anfänger-Themen 5
P scanner ein Double einlesen Java Basics - Anfänger-Themen 10
T Java double berechnung fehler Java Basics - Anfänger-Themen 2
S double[x] , double[y] zu Point[] points kopieren? Java Basics - Anfänger-Themen 15
G double in float umwandeln Java Basics - Anfänger-Themen 2
F double[] an andere Methode übergeben Java Basics - Anfänger-Themen 1
B Datentypen Test float und double speichern Zahlen nur ungefähr Java Basics - Anfänger-Themen 4
S Datentypen double - kommastellen abschneiden Java Basics - Anfänger-Themen 6
M int double int double Graph Java Basics - Anfänger-Themen 3
K ArrayList<Double> --> double[] array Java Basics - Anfänger-Themen 5
Z Double in komma und Punkt akzeptieren -> Robusteeingabe Java Basics - Anfänger-Themen 7
S Double und Gleitkommazahlen mit JUnit testen Java Basics - Anfänger-Themen 7
B Datentypen Multiplzieren mit double wird ungenau Java Basics - Anfänger-Themen 4
K Von einem Double wert nur die Zahl vor dem Komma verwenden Java Basics - Anfänger-Themen 9
F Double neu formatieren mit NumberFormat Java Basics - Anfänger-Themen 2
M Double-Ausgabe in JTextField fehlerhaft Java Basics - Anfänger-Themen 2
T Problem mit double-Formatierung Java Basics - Anfänger-Themen 3
M Double Zahl in Grad Zahl Java Basics - Anfänger-Themen 7
M Datentypen Ergebniss- Double to String- wird nicht angezeigt Java Basics - Anfänger-Themen 13
S Double mithilfe eines Scanners so einlesen, dass ich damit rechnen kann Java Basics - Anfänger-Themen 4
M Die Double-Variable rundet? Java Basics - Anfänger-Themen 1
llabusch Methoden Methoden überlagern - entweder int || double Java Basics - Anfänger-Themen 10
S Double, int, Berechnung Java Basics - Anfänger-Themen 3
K Datentypen Wertebereich float/double - Warum nicht hoch -1 Java Basics - Anfänger-Themen 6
A Double[] Array zahlen per Argument übergeben Java Basics - Anfänger-Themen 5
B Erste Schritte Addition von double in switch-Anweisung Java Basics - Anfänger-Themen 2
D Unterschied zwischen double und Double Java Basics - Anfänger-Themen 4
M Double-Zahlen auf Intervalle runden Java Basics - Anfänger-Themen 3
D Schon wieder double -.- Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben