Skip to content

Commit

Permalink
resurrect groupby
Browse files Browse the repository at this point in the history
  • Loading branch information
ChihChengLiang committed May 28, 2019
1 parent fc65be3 commit e733f5e
Showing 1 changed file with 19 additions and 8 deletions.
27 changes: 19 additions & 8 deletions py_ecc/bls/api.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@

from operator import (
itemgetter,
)
from secrets import (
randbelow,
)
Expand All @@ -7,6 +9,10 @@
Sequence,
Tuple,
)

from cytoolz.itertoolz import (
groupby,
)
from eth_typing import (
BLSPubkey,
BLSSignature,
Expand Down Expand Up @@ -86,15 +92,20 @@ def aggregate_pubkeys(pubkeys: Sequence[BLSPubkey]) -> BLSPubkey:
return G1_to_pubkey(o)


def _zip(pubkeys: Sequence[BLSPubkey],
message_hashes: Sequence[Hash32])-> Iterator[Tuple[BLSPubkey, Hash32]]:
def _group_key_by_msg(pubkeys: Sequence[BLSPubkey],
message_hashes: Sequence[Hash32])-> Iterator[Tuple[G1Uncompressed, Hash32]]:
if len(pubkeys) != len(message_hashes):
raise ValidationError(
"len(pubkeys) (%s) should be equal to len(message_hashes) (%s)" % (
len(pubkeys), len(message_hashes)
)
)
return zip(pubkeys, message_hashes)
groups_dict = groupby(itemgetter(1), enumerate(message_hashes))
for message_hash, group in groups_dict.items():
agg_key = Z1
for i, _ in group:
agg_key = add(agg_key, pubkey_to_G1(pubkeys[i]))
yield agg_key, message_hash


def verify_multiple(pubkeys: Sequence[BLSPubkey],
Expand All @@ -103,10 +114,10 @@ def verify_multiple(pubkeys: Sequence[BLSPubkey],
domain: int) -> bool:

o = FQ12.one()
for pubkey, message_hash in _zip(pubkeys, message_hashes):
for pubkey, message_hash in _group_key_by_msg(pubkeys, message_hashes):
o *= pairing(
hash_to_G2(message_hash, domain),
pubkey_to_G1(pubkey),
pubkey,
final_exponentiate=False,
)
o *= pairing(signature_to_G2(signature), neg(G1), final_exponentiate=False)
Expand All @@ -131,10 +142,10 @@ def verify_multiple_multiple(
random_ints = (1,) + tuple(2**randbelow(64) for _ in signatures[:-1])
o = FQ12.one()
for r_i, (pubkeys, message_hashes) in zip(random_ints, pubkeys_and_messages):
for pubkey, message_hash in _zip(pubkeys, message_hashes):
for pubkey, message_hash in _group_key_by_msg(pubkeys, message_hashes):
o *= pairing(
multiply(hash_to_G2(message_hash, domain), r_i),
pubkey_to_G1(pubkey),
pubkey,
final_exponentiate=False,
)
agg_sig = Z2
Expand Down

0 comments on commit e733f5e

Please sign in to comment.