script to test agcd
This commit is contained in:
47
scripts/gen_values.py
Normal file
47
scripts/gen_values.py
Normal file
@@ -0,0 +1,47 @@
|
||||
import sys
|
||||
import random
|
||||
import argparse
|
||||
|
||||
def generate_test_values(noise_bits, number, p_bits):
|
||||
|
||||
p = random.randint(2**(p_bits-1), 2**p_bits)
|
||||
while p % 2 == 0:
|
||||
p = random.randint(2**(p_bits-1), 2**p_bits)
|
||||
|
||||
max_noise = (1 << noise_bits) - 1 # 2^noise_bits - 1
|
||||
|
||||
a = [str(p * random.randint(1, 100) + random.randint(0, max_noise)) for _ in range(number)]
|
||||
|
||||
return noise_bits, a, p
|
||||
|
||||
|
||||
def generate_test_file(noise_bits, number, p_bits, filename):
|
||||
noise_bits, a, p = generate_test_values(noise_bits, number, p_bits)
|
||||
|
||||
with open(filename, 'w') as f:
|
||||
f.write(f"{noise_bits}\n")
|
||||
for b in a:
|
||||
f.write(f"{b}\n")
|
||||
f.write(f"// True p: {p}\n")
|
||||
|
||||
return p
|
||||
|
||||
def print_test_values(noise_bits, number, p_bits):
|
||||
|
||||
_, a, p = generate_test_values(noise_bits, number, p_bits)
|
||||
|
||||
print(noise_bits)
|
||||
|
||||
for b in a:
|
||||
print(b)
|
||||
|
||||
print(f"// True p: {p}")
|
||||
|
||||
if __name__ == "__main__":
|
||||
parser = argparse.ArgumentParser(description='Generate test input for AGCD computation')
|
||||
parser.add_argument('--noise-bits', type=int, default=5, help='Number of noise bits (default: 5)')
|
||||
parser.add_argument('--p-bits', type=int, default=16, help='Number of key bits (default: 16)')
|
||||
parser.add_argument('--number', type=int, default=20, help='Number of numbers to generate (default: 20)')
|
||||
|
||||
args = parser.parse_args()
|
||||
print_test_values(args.noise_bits, args.number, args.p_bits)
|
Reference in New Issue
Block a user