double and add algorithmus für elliptische kurven/ integer binär darstellen

andreas2505

Bekanntes Mitglied
hallo,

ich möchte gerne den double and add algorithmus für elliptische kurven implementieren. (siehe Anhang)
Dazu muss ich aber einen integer Wert binär darstellen und weiß nicht so recht, wie ich das umsetzen soll. Weiterhin muss ich in dann auch noch halbieren und abrunden...
Steht ja alles im Algorithmus (bis zu dem Kästchen)

Kann mir jemand sagen, wie ich das binär darstellen kann und wie ich dann den Schritt berechnen kann, in dem der Wert durch zwei geteilt und abgerundet wird?
 

Anhänge

  • double and add.jpg
    double and add.jpg
    54 KB · Aufrufe: 93

faetzminator

Gesperrter Benutzer
Kann mir jemand sagen, wie ich das binär darstellen kann und wie ich dann den Schritt berechnen kann, in dem der Wert durch zwei geteilt und abgerundet wird?

Java:
String binValue = Integer.toBinaryString(x)
Was meinst du mit abrunden? Wenn du in Java 3 / 2 (als int) teilst, dann kriegst du automatisch 1, da von 1.5 das .x abgeschnitten wird.
 
Zuletzt bearbeitet:

andreas2505

Bekanntes Mitglied
naja das steht doch im algorithmus, im anhang, wie ich das meine.
Aber wenn das ein String ist, kann ich doch damit nicht den restlichen Algorihtmus druchführen, oder?
Wenn ja wie?
 

faetzminator

Gesperrter Benutzer
Ich muss zugeben, dass ich die Aufgabe nur teilweise verstehe.
Na klar, du kannst z.B. [c]charAt(x)[/c] oder [c]toCharArray()[/c] mit [c]- '0'[/c] verwenden. Ansonsten kann man den String natürlich auch einfach mit [c]Integer.parseInt(str)[/c] wieder in einen int parsen. Der Grund, warum hier ein String zurückgegeben wird, wird wohl die begrenzte Datenmenge des int sein.
Probier einfach mal, das zu programmieren und schreib bei Schwierigkeiten wieder rein.
 

andreas2505

Bekanntes Mitglied
Also das hab ich bis jetzt!

An den Stellen wo die Fragezeichen sind, kann ich das aus dem Algorithmus (siehe oben ) nicht umsetzen

Java:
public EPoint mult(BigInteger n, EllipticCurve ec) {
            ECPoint q = this;
            ECPoint r = POINT_INFINITY;
            
            while (n.bitLength() > 0) {
                if (???) {
                    r = r.add(q, ec);
                }
                q = q.add(q);
                n = ???;
                if (n.bitLength() > 0) {
                    ????
                }
            }
            return r;
        }

Wäre super,wenn mir jemand an diesen Stellen helfen kann...
 

andreas2505

Bekanntes Mitglied
kann mir denn gar keiner weiterhelfen???

Die ganze Sache mit elliptischen Kurven brauch eigentlich nicht betrachtet werden. Es geht eigentlich nur um die 3 Stellen mit ????

1. wie frage ich n=1 (mod 2) ab???
2. wie mache ich n=abgerundet(n/2)???
3. wie kann ich wieder zu einem Schritt zurückkehren???

steht alles im Algorithmus oben..., weiß halt nicht wie ichs umsetzen soll
 

faetzminator

Gesperrter Benutzer
1. wie frage ich n=1 (mod 2) ab???
n=1 (mod 2)? Also Modulo macht man mit [c]%[/c]. Also wie [c]3 + 2 // 5[/c] einfach [c]3 % 2 // 1[/c]
2. wie mache ich n=abgerundet(n/2)???
Da du mit int's arbeitest, wird der Nachkommawert - wie bereits von mir erklärt - abgeschnitten. Du musst also nichts aufrufen.
3. wie kann ich wieder zu einem Schritt zurückkehren???
Das macht er auch ohne deine if-Abfrage (Z11). Aber er würde die Schleife solange ausführen, wie [c]n.bitLength() > 0[/c] ist. Also musst du n in der Schleife noch bearbeiten oder ein anderes Abbruchkriterium finden.
 

andreas2505

Bekanntes Mitglied
n=1 (mod 2)? Also Modulo macht man mit % . Also wie 3 + 2 // 5 einfach 3 % 2 // 1

Aber das ist doch eine schreibweise von n in binärer form (siehe Algorithmus). Da kann man das doch nicht so machen oder?

Also musst du n in der Schleife noch bearbeiten oder ein anderes Abbruchkriterium finden.

Wie genau soll ich denn n noch bearbeiten oder was für ein Kriterium soll ich wählen?
 

Ariol

Top Contributor
Aber das ist doch eine schreibweise von n in binärer form (siehe Algorithmus). Da kann man das doch nicht so machen oder?

Wenn die binäre Form als String vorliegt kann man das letzte Zeichen überprüfen:
Code:
n%2==0 --> letztes Zeichen = '0'
n%2==1 --> letztes Zeichen = '1'
n/2 = letztes Zeichen des Strings abschneiden.
 

andreas2505

Bekanntes Mitglied
Java:
public ECPoint mult(Integer n, EllipticCurve ec) {
            ECPoint q = this;
            ECPoint r = POINT_INFINITY;
            
            String binValue = Integer.toBinaryString(n);
            
            while (n > 0) {
                if (n%2==1) {
                    r = r.add(q, ec);
                }
                q = q.add(q, ec);
                n = n/2;
            }
            
            return r;
        }

so hab ichs jetzt. Es kommen zwar keine Fehler raus, aber auch nicht die richtige Werte!

Irgendwas muss also nicht richtig sein
 

andreas2505

Bekanntes Mitglied
Java:
public ECPoint add(ECPoint b, EllipticCurve e) {
        
        if (this.equals(POINT_INFINITY)) {
            return b;
        }
        if (b.equals(POINT_INFINITY)) {
            return this;
        }
        if (this.x.equals(x)) {
            if (this.y.equals(y.negate())) {
                return POINT_INFINITY;
            }
        }
        
        BigInteger lambda;
        
        if (this.equals(b)) {
            System.out.println("+");
            lambda = BigInteger.valueOf(3).multiply(this.x).multiply(this.x).add(e.a).multiply(BigInteger.valueOf(2).multiply(this.y).modInverse(e.field.p)).mod(e.field.p);
        }
        else {
            lambda = b.y.subtract(this.y).multiply(b.x.subtract(this.x)).modInverse(e.field.p).mod(e.field.p);
        }
        
        BigInteger xNeu = lambda.multiply(lambda).subtract(this.x).subtract(b.x).mod(e.field.p);  
        BigInteger yNeu = lambda.multiply(this.x.subtract(xNeu)).subtract(this.y).mod(e.field.p);  
  
        return new ECPoint(xNeu, yNeu);  
            
    }

Die ganze Rechnung basiert auf elliptischen Kurven in einem finiten Feld Fp

die add Methode funktioniert, die wurde getestet.

EDIT:

Naja, obwohl, bei einigen Punktion funktioniert sie doch irgendwie nicht...
 
Zuletzt bearbeitet:
S

systemn

Gast
Java:
    public static boolean is0(int val, int i) {
        while (i-- > 1) {
            val >>= 1;
        }
        return (val & 1) == 0;
    }
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
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
I Output BigDecimal anstatt double / Problem beim Rechnen Java Basics - Anfänger-Themen 16
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