소스 검색

gen now returns (Scalar, RistrettoPoint) to match the paper

Ian Goldberg 11 달 전
부모
커밋
4a5cb38b30
3개의 변경된 파일9개의 추가작업 그리고 9개의 파일을 삭제
  1. 2 3
      src/arctic.rs
  2. 1 1
      src/bin/shine.rs
  3. 6 5
      src/shine.rs

+ 2 - 3
src/arctic.rs

@@ -72,7 +72,7 @@ fn hash3(pk: &PubKey, coalition: &[u32], msg: &[u8]) -> [u8; 32] {
 pub fn sign1(pk: &PubKey, sk: &SecKey, coalition: &[u32], msg: &[u8]) -> RistrettoPoint {
     assert!(coalition.len() >= 2 * (sk.t as usize) - 1);
     let w = hash3(pk, coalition, msg);
-    shine::commit(&sk.rk.gen(&w))
+    sk.rk.gen(&w).1
 }
 
 pub fn sign2_polys(
@@ -93,8 +93,7 @@ pub fn sign2_polys(
     let kindex = coalition.iter().position(|&k| k == sk.k).unwrap();
 
     let w = hash3(pk, coalition, msg);
-    let my_eval = sk.rk.gen(&w);
-    let my_commit = shine::commit(&my_eval);
+    let (my_eval, my_commit) = sk.rk.gen(&w);
 
     assert!(commitments[kindex] == my_commit);
 

+ 1 - 1
src/bin/shine.rs

@@ -66,7 +66,7 @@ fn main() {
             .iter()
             .map(|rk| {
                 let evalstart = Instant::now();
-                let evaluation = rk.gen(&wvec);
+                let evaluation = rk.gen(&wvec).0;
                 let evaldur = evalstart.elapsed().as_micros() as f64;
                 (evaluation, evaldur)
             })

+ 6 - 5
src/shine.rs

@@ -130,11 +130,12 @@ impl PreprocKey {
         }
     }
 
-    pub fn gen(&self, w: &[u8]) -> Scalar {
-        self.secrets
+    pub fn gen(&self, w: &[u8]) -> (Scalar, RistrettoPoint) {
+        let d = self.secrets
             .iter()
             .map(|&(phi, lagrange)| hash1(&phi, w) * lagrange)
-            .sum()
+            .sum();
+        (d, &d * &dalek_constants::RISTRETTO_BASEPOINT_TABLE)
     }
 
     pub fn delta(&self) -> usize {
@@ -249,7 +250,7 @@ pub fn test_gen() {
     let mut rng = rand::thread_rng();
     let mut w = [0u8; 32];
     rng.fill_bytes(&mut w);
-    let evals: Vec<Scalar> = ppkeys.iter().map(|k| k.gen(&w)).collect();
+    let evals: Vec<Scalar> = ppkeys.iter().map(|k| k.gen(&w).0).collect();
 
     // Try interpolating different subsets and check that the answer is
     // the same
@@ -268,7 +269,7 @@ pub fn test_combinecomm() {
     let mut w = [0u8; 32];
     rng.fill_bytes(&mut w);
     let commitments: Vec<RistrettoPoint> =
-        ppkeys.iter().map(|k| commit(&k.gen(&w))).collect();
+        ppkeys.iter().map(|k| k.gen(&w).1).collect();
 
     let comm1 = combinecomm(3, &vec![1, 2, 3, 4, 5], &commitments[0..=4]);
     let comm2 = combinecomm(3, &vec![3, 4, 5, 6, 7], &commitments[2..=6]);