rotate_batch

고정 회전 키들을 통한 회전

Engine.rotate_batch(ciphertext, fixed_rotation_keys)
암호문을 고정 회전 키들 각각의 지정된 delta 만큼 오른쪽으로 회전시켜서 반환합니다. [1, 2, 3, 4] 를 1만큼 회전시키면 [4, 1, 2, 3] 이 됩니다. 하나의 암호문을 여러번 회전해야하는 경우 rotate 함수를 여러번 호출하는 것에 비해 효율적입니다. 일반적으로 레벨을 소모하지 않습니다. 다자간 연산이 아니면서 최대 레벨인 경우에만 레벨을 소모합니다.
  • 인풋:
    • Ciphertext
    • fixed_rotation_keys: list of FixedRotationKey
  • 아웃풋:
    • list of Ciphertext
from desilofhe import Engine

engine = Engine()
secret_key = engine.create_secret_key()
public_key = engine.create_public_key(secret_key)
fixed_rotation_key_1 = engine.create_fixed_rotation_key(secret_key, delta=1)
fixed_rotation_key_2 = engine.create_fixed_rotation_key(secret_key, delta=2)

message = [1, 2, 3]
ciphertext = engine.encrypt(message, public_key)
fixed_rotation_keys = [fixed_rotation_key_1, fixed_rotation_key_2]
rotated_ciphertexts = engine.rotate_batch(ciphertext, fixed_rotation_keys)

회전 키를 통한 회전

Engine.rotate_batch(ciphertext, rotation_key, deltas)
암호문을 지정된 deltas 각각의 값만큼 오른쪽으로 회전시켜서 반환합니다. [1, 2, 3, 4] 를 1만큼 회전시키면 [4, 1, 2, 3] 이 됩니다. 하나의 암호문을 여러번 회전해야하는 경우 rotate 함수를 여러번 호출하는 것에 비해 효율적입니다. 일반적으로 레벨을 소모하지 않습니다. 다자간 연산이 아니면서 최대 레벨인 경우에만 레벨을 소모합니다.
  • 인풋:
    • Ciphertext
    • RotationKey
    • deltas: list of int
  • 아웃풋:
    • list of Ciphertext
from desilofhe import Engine

engine = Engine()
secret_key = engine.create_secret_key()
public_key = engine.create_public_key(secret_key)
rotation_key = engine.create_rotation_key(secret_key)

message = [1, 2, 3]
ciphertext = engine.encrypt(message, public_key)
rotated_ciphertexts = engine.rotate_batch(
    ciphertext, rotation_key, deltas=[1, 2]
)