forked from spaceandtimelabs/blitzar
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.rs
81 lines (67 loc) · 2.65 KB
/
main.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
extern crate blitzar_sys;
#[cfg(test)]
mod tests {
#[test]
fn compute_commitments_works() {
let config: blitzar_sys::sxt_config = blitzar_sys::sxt_config {
backend: blitzar_sys::SXT_GPU_BACKEND as i32,
num_precomputed_generators: 10 as u64,
};
unsafe {
let ret_init = blitzar_sys::sxt_init(&config);
assert_eq!(ret_init, 0);
};
let n1: u64 = 4;
let num_commitments = 3;
let n1_num_bytes: u8 = 4;
let mut data_bytes: [[u32; 4]; 3] = [
[2000, 7500, 5000, 1500],
[5000, 0, 400000, 10],
[2000 + 5000, 7500 + 0, 5000 + 400000, 1500 + 10],
];
let expected_0: [u8; 32] = [
4,105,58,131,59,69,150,106,
120,137,32,225,175,244,82,115,
216,180,206,150,21,250,240,98,
251,192,146,244,54,169,199,97
];
let expected_1: [u8; 32] = [
2,254,178,195,198,238,44,156,
24,29,88,196,37,63,157,50,
236,159,61,49,153,181,79,126,
55,188,67,1,228,248,72,51
];
let expected_2: [u8; 32] = [
30,237,163,234,252,111,45,133,
235,227,21,117,229,188,88,149,
240,109,205,90,6,130,199,152,
5,221,57,231,168,9,141,122
];
let mut cbinding_commitments: Vec<blitzar_sys::
sxt_ristretto255_compressed> = Vec::with_capacity(num_commitments);
let mut cbinding_descriptors: Vec<blitzar_sys::
sxt_sequence_descriptor> = Vec::with_capacity(num_commitments);
unsafe {
cbinding_commitments.set_len(num_commitments);
cbinding_descriptors.set_len(num_commitments);
for i in 0..num_commitments {
let descriptor = blitzar_sys::sxt_sequence_descriptor {
element_nbytes: n1_num_bytes, // number bytes
n: n1, // number rows
data: data_bytes[i].as_mut_ptr() as *const u8, // data
is_signed: 0, // unsigned
};
cbinding_descriptors[i] = descriptor;
}
blitzar_sys::sxt_curve25519_compute_pedersen_commitments(
cbinding_commitments.as_mut_ptr(),
num_commitments as u32,
cbinding_descriptors.as_mut_ptr(),
0 as u64
);
}
assert_eq!(cbinding_commitments[0].ristretto_bytes, expected_0);
assert_eq!(cbinding_commitments[1].ristretto_bytes, expected_1);
assert_eq!(cbinding_commitments[2].ristretto_bytes, expected_2);
}
}