Files
concrete/benchmarks/x_times_y.py
2021-09-28 10:24:28 +02:00

45 lines
1.0 KiB
Python

# Target: x * y
import itertools
import random
import concrete.numpy as hnp
def main():
def function_to_compile(x, y):
return x * y
x = hnp.EncryptedScalar(hnp.UnsignedInteger(3))
y = hnp.EncryptedScalar(hnp.UnsignedInteger(2))
inputset = itertools.product(range(4, 8), range(0, 4))
# Measure: Compilation Time (ms)
engine = hnp.compile_numpy_function(function_to_compile, {"x": x, "y": y}, inputset)
# Measure: End
inputs = []
labels = []
for _ in range(4):
sample_x = random.randint(2 ** 2, 2 ** 3 - 1)
sample_y = random.randint(0, 2 ** 2 - 1)
inputs.append([sample_x, sample_y])
labels.append(function_to_compile(*inputs[-1]))
correct = 0
for input_i, label_i in zip(inputs, labels):
# Measure: Evaluation Time (ms)
result_i = engine.run(*input_i)
# Measure: End
if result_i == label_i:
correct += 1
# Measure: Accuracy (%) = (correct / len(inputs)) * 100
if __name__ == "__main__":
main()