Kleiner UPN-Rechner für BigIntegers

Landei

Top Contributor
Rechnen mit BigIntegers ist wirklich eine Qual. Nachdem ich eine Weile überlegt hatte, ein DSL für BigInteger zu schreiben, aber "dank" der recht starren Java-Syntax keine wesentliche Verbesserung gegenüber den vorhandenen Klassen erzielen konnte (jedenfalls keine, die den zusätzlichen Wrapperklassen-Aufwand rechtfertigen würde), habe ich meine Strategie geändert und bin zur Umgekehrt Polnische Notation umgeschwenkt. Ich weiß, die ist etwas gewöhnungsbedürftig. Hier als erstes Ergebnis ein Vergleich von Code für den Lucas-Lehmer-Test.

Konventionell (von Lucas-Lehmer test for Mersenne numbers (Java) - LiteratePrograms ):
Java:
    public static boolean lucasLehmer(int p) {
        BigInteger s = BigInteger.valueOf(4);
        BigInteger m = BigInteger.valueOf(2).pow(p).subtract(BigInteger.ONE);
        for (int i = 0; i < p - 2; i++) {
            s = s.multiply(s).subtract(BigInteger.valueOf(2)).mod(m);
        }
        return s.equals(BigInteger.ZERO);
    }

Und mit UPN:
Java:
    public static boolean lucasLehmerBIRPN(int p) {
        BigInteger s = _(4);
        BigInteger m = _(2, p, POW, DEC); // [2 p ^ --] -> (2^p)-1 
        for (int i = 0; i < p - 2; i++) {
            s = _(s, SQUARE, 2, MINUS, m, MOD); //[s ² 2 - m %] -> (s²-2) % m
        }
        return s.equals(_(0));
    }

Mir geht es erst einmal nur um die Syntax. Wenn ich daran weiterarbeite, kommt das Dingens auf Google Code. Das Beispiel funktioniert zwar schon, die Anzahl der verfügbaren Funktionen ist aber noch ziemlich beschränkt, und ich sehe auch noch einiges Optimierungspotential.

Natürlich kann man auch eine Erweiterung schreiben, die eine "normale" Infix-Eingabe zulässt (eventuell auch als zu parsenden String mit varargs á la printf), und hinter den Kulissen mittels Shuntingyard-Algorithmus in Postfix umwandelt.

Was meint ihr dazu?

[edit] Kleine Verbesserung in meinem Code.
 
Zuletzt bearbeitet:

Landei

Top Contributor
Das Ding mutiert immer weiter unter meinen Händen. Zwar immer noch kein Infix, dafür ein Parser.

Java:
    public static boolean lucasLehmerParsed(int p) {
        BigInteger s = _("4");
        BigInteger m = _("2 $0 ^ --", p);
        for (int i = 0; i < p - 2; i++) {
            s = _("$0 ² 2 - $1 %", s, m);
        }
        return s.equals(_("0"));
    }

Noch ein kleines bisschen, und ich habe Forth (oder Joy, oder Cat, oder Factor) in Java...
 

steinitz

Mitglied
Interessant! Ich suche gerade Java-Beispiele für das Rechnen in endlichen Körpern! Das geht so etwas in die Richtung.
Ein Hinweis wäre toll!

Was charakterisiert übrigens die Carmichael-Zahlen, die den Test Miller-Rabin-Test bestehen?
 

Landei

Top Contributor
Version 0.2 ist fertig. Ich habe noch Funktionen hinzugefügt, etwa die ganzzahlige Wurzel (insgesamt sind es immerhin 55 Funktionen). Weiterhin unterstütze ich boolesche Logik (also logische Operatoren, Vergleichsoperatoren, if, isPrime, isSquare u.s.w), Ranges (erzeuge die Zahlen 5..20, Schrittweite 3) und Metafunktionen (eine gegebene Funktion auf alle Zahlen auf dem Stack anwenden). Ich habe alle Operatorn mit JUnit abgedeckt, dabei habe ich tatsächlich drei, vier Bugs gefunden. Das Modul ist erweiterbar, man kann eigene Funktionen oder Metafunktionen verwenden (nach Registrierung auch in der geparsten Version). Die Dokumentation habe ich erweitert, auch wenn sie noch nicht perfekt ist.

Download: http://birpn.googlecode.com/files/BIRPN-0.2.jar

Interessant ist, dass man sich relativ einfach eigene Funktionen oder Metafunktionen schreiben und ganz normal verwenden kann (für die Verwendung mit dem String-Aufruf müssen sie vorher registriert werden). Dafür fehlt zwar noch die Dokumentation, aber wer sich die Sourcen der vorhandenen Operatoren anschaut, kann sehen, wie es funktionert.

Ich plane als nächstes, Dokumentation und JUnit-Abdeckung auf Vordermann zu bringen, sowie die Projektstruktur zu verbessern. Neue Features sind erst mal nicht geplant. Eine interessante Erweiterung wäre eine zweite Utility-Klasse, die statt RPN die "normale" Infix-Notation erlaubt, aber das wäre schon ein wenig Arbeit...
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
A Kleiner Downloader Allgemeine Java-Themen 3
vandread Problem bei kleiner Thread-Übung Allgemeine Java-Themen 2
H Kleiner HTML Parser (Facharbeit) Allgemeine Java-Themen 11
S Kleiner Texteditor mit MD5-Check Allgemeine Java-Themen 4
-MacNuke- [NumberFormat] Prozente kleiner 1% Allgemeine Java-Themen 11
chik Doppelt verkettete Liste bzw. Zirkulärliste (kleiner Fehler, den ich nicht finde) Allgemeine Java-Themen 4
G JRE: Minimale Systemanforderungen kleiner als 64 MB? Allgemeine Java-Themen 6
U URI Rechner Allgemeine Java-Themen 4
U URI Rechner Allgemeine Java-Themen 2
U URI Rechner (Java Script) Allgemeine Java-Themen 7
H Java Rechner Programmierung der Mathematik Allgemeine Java-Themen 33
Alex_99 Rechner: Wert zwischenspeichern und bei Bedarf mit Ihm weiterrechnen? Allgemeine Java-Themen 6
M Rechner dez in Hex umwandeln Allgemeine Java-Themen 5
A Rechner in Android Studio Allgemeine Java-Themen 2
H Projekt Quadraturverfahren Rechner Allgemeine Java-Themen 2
N Eclipse Dynamisches-Web-Project auf anderen Rechner transportieren Allgemeine Java-Themen 5
KilledByCheese Dezimal nach Hexadezimal rechner wirft seltsame exception Allgemeine Java-Themen 4
P Mehrere Java Versionen auf dem Rechner Allgemeine Java-Themen 3
S BMI Rechner mit eclipse Visual Editor (Seperates Fenster) Allgemeine Java-Themen 7
Thallius Serialisiertes File kann auf anderem Rechner nicht geladen werden Allgemeine Java-Themen 12
D IP-Adresse der Rechner im Netzwerk auflisten Allgemeine Java-Themen 2
M Fitness-Rechner: NullPointerException Allgemeine Java-Themen 7
K Programm startet nur auf eigenem Rechner??? Allgemeine Java-Themen 6
M Linux Rechner per ssh runterfahren mit Java Allgemeine Java-Themen 8
M AWT JAVA Rechner Allgemeine Java-Themen 20
E eindeutige Id's für Rechner Allgemeine Java-Themen 7
S Dem Rechner klarmachen das Java 1.5 installiert ist Allgemeine Java-Themen 13
F Zugriff auf lokalen Rechner wer weiss Rat ? Allgemeine Java-Themen 16
M ireport (Jasper Report) geht nur auf meinen Rechner Allgemeine Java-Themen 3
S Rechner formatiert - nichts geht mehr. Allgemeine Java-Themen 2
S jar-datei auf anderem Rechner nicht ausführbar. Allgemeine Java-Themen 40
W Datei und druckerfreigaben von lokalem Rechner auslesen. Allgemeine Java-Themen 2
N entfernten rechner runterfahren => putty-ersatz Allgemeine Java-Themen 8
B Mehrere Versionen auf einem Rechner Allgemeine Java-Themen 2
A Java-Applikation auf einem anderen Rechner starten Allgemeine Java-Themen 17
L kleine frage zum rechner Allgemeine Java-Themen 7
X Java Wirrwarr auf dem Rechner Allgemeine Java-Themen 5
B Rechner stürzt ab wenn Java-Anwendungen geöffnet werden! Allgemeine Java-Themen 2
thE_29 Linux-Rechner herunterfahren Allgemeine Java-Themen 3
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
_user_q Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 61
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben