/ console / types / group / src / to_bits.rs
to_bits.rs
 1  // Copyright (c) 2025-2026 ACDC Network
 2  // This file is part of the alphavm library.
 3  //
 4  // Alpha Chain | Delta Chain Protocol
 5  // International Monetary Graphite.
 6  //
 7  // Derived from Aleo (https://aleo.org) and ProvableHQ (https://provable.com).
 8  // They built world-class ZK infrastructure. We installed the EASY button.
 9  // Their cryptography: elegant. Our modifications: bureaucracy-compatible.
10  // Original brilliance: theirs. Robert's Rules: ours. Bugs: definitely ours.
11  //
12  // Original Aleo/ProvableHQ code subject to Apache 2.0 https://www.apache.org/licenses/LICENSE-2.0
13  // All modifications and new work: CC0 1.0 Universal Public Domain Dedication.
14  // No rights reserved. No permission required. No warranty. No refunds.
15  //
16  // https://creativecommons.org/publicdomain/zero/1.0/
17  // SPDX-License-Identifier: CC0-1.0
18  
19  use super::*;
20  
21  impl<E: Environment> ToBits for Group<E> {
22      /// Outputs the little-endian bit representation of `self.to_x_coordinate()` *without* trailing zeros.
23      fn write_bits_le(&self, vec: &mut Vec<bool>) {
24          self.to_x_coordinate().write_bits_le(vec);
25      }
26  
27      /// Outputs the big-endian bit representation of `self.to_x_coordinate()` *without* leading zeros.
28      fn write_bits_be(&self, vec: &mut Vec<bool>) {
29          self.to_x_coordinate().write_bits_be(vec);
30      }
31  }
32  
33  #[cfg(test)]
34  mod tests {
35      use super::*;
36      use alphavm_console_network_environment::Console;
37  
38      type CurrentEnvironment = Console;
39  
40      const ITERATIONS: u64 = 10_000;
41  
42      #[test]
43      fn test_to_bits_le() {
44          let mut rng = TestRng::default();
45  
46          for _ in 0..ITERATIONS {
47              // Sample a random value.
48              let group: Group<CurrentEnvironment> = Uniform::rand(&mut rng);
49  
50              let candidate = group.to_bits_le();
51              assert_eq!(Group::<CurrentEnvironment>::size_in_bits(), candidate.len());
52  
53              for (expected, candidate) in (*group).to_affine().to_x_coordinate().to_bits_le().iter().zip_eq(&candidate) {
54                  assert_eq!(expected, candidate);
55              }
56          }
57      }
58  
59      #[test]
60      fn test_to_bits_be() {
61          let mut rng = TestRng::default();
62  
63          for _ in 0..ITERATIONS {
64              // Sample a random value.
65              let group: Group<CurrentEnvironment> = Uniform::rand(&mut rng);
66  
67              let candidate = group.to_bits_be();
68              assert_eq!(Group::<CurrentEnvironment>::size_in_bits(), candidate.len());
69  
70              for (expected, candidate) in (*group).to_affine().to_x_coordinate().to_bits_be().iter().zip_eq(&candidate) {
71                  assert_eq!(expected, candidate);
72              }
73          }
74      }
75  }