#include "seal/seal.h"
#include "seal/util/rlwe.h"
#include "bench.h"
using namespace benchmark;
using namespace sealbench;
using namespace seal;
using namespace std;
namespace sealbench
{
void bm_bfv_encrypt_secret(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
Plaintext &pt = bm_env->pt()[0];
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_pt_bfv(pt);
state.ResumeTiming();
bm_env->encryptor()->encrypt_symmetric(pt, ct[2]);
}
}
void bm_bfv_encrypt_public(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
Plaintext &pt = bm_env->pt()[0];
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_pt_bfv(pt);
state.ResumeTiming();
bm_env->encryptor()->encrypt(pt, ct[2]);
}
}
void bm_bfv_decrypt(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
Plaintext &pt = bm_env->pt()[0];
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
state.ResumeTiming();
bm_env->decryptor()->decrypt(ct[0], pt);
}
}
void bm_bfv_encode_batch(State &state, shared_ptr<BMEnv> bm_env)
{
vector<uint64_t> &msg = bm_env->msg_uint64();
Plaintext &pt = bm_env->pt()[0];
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_message_uint64(msg);
state.ResumeTiming();
bm_env->batch_encoder()->encode(msg, pt);
}
}
void bm_bfv_decode_batch(State &state, shared_ptr<BMEnv> bm_env)
{
vector<uint64_t> &msg = bm_env->msg_uint64();
Plaintext &pt = bm_env->pt()[0];
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_pt_bfv(pt);
state.ResumeTiming();
bm_env->batch_encoder()->decode(pt, msg);
}
}
void bm_bfv_add_ct(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
bm_env->randomize_ct_bfv(ct[1]);
state.ResumeTiming();
Ciphertext res;
bm_env->evaluator()->add(ct[0], ct[1], res);
}
}
void bm_bfv_add_pt(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
Plaintext &pt = bm_env->pt()[0];
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
bm_env->randomize_pt_bfv(pt);
state.ResumeTiming();
bm_env->evaluator()->add_plain(ct[0], pt, ct[2]);
}
}
void bm_bfv_negate(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
state.ResumeTiming();
bm_env->evaluator()->negate(ct[0], ct[2]);
}
}
void bm_bfv_sub_ct(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
bm_env->randomize_ct_bfv(ct[1]);
state.ResumeTiming();
bm_env->evaluator()->sub(ct[0], ct[1], ct[2]);
}
}
void bm_bfv_sub_pt(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
Plaintext &pt = bm_env->pt()[0];
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
bm_env->randomize_pt_bfv(pt);
state.ResumeTiming();
bm_env->evaluator()->sub_plain(ct[0], pt, ct[2]);
}
}
void bm_bfv_mul_ct(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
bm_env->randomize_ct_bfv(ct[1]);
state.ResumeTiming();
bm_env->evaluator()->multiply(ct[0], ct[1], ct[2]);
}
}
void bm_bfv_mul_pt(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
Plaintext &pt = bm_env->pt()[0];
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
bm_env->randomize_pt_bfv(pt);
state.ResumeTiming();
bm_env->evaluator()->multiply_plain(ct[0], pt, ct[2]);
}
}
void bm_bfv_square(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
bm_env->randomize_ct_bfv(ct[1]);
state.ResumeTiming();
bm_env->evaluator()->square(ct[0], ct[2]);
}
}
void bm_bfv_modswitch_inplace(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
state.ResumeTiming();
bm_env->evaluator()->mod_switch_to_next_inplace(ct[0]);
}
}
void bm_bfv_relin_inplace(State &state, shared_ptr<BMEnv> bm_env)
{
Ciphertext ct;
for (auto _ : state)
{
state.PauseTiming();
ct.resize(bm_env->context(), size_t(3));
bm_env->randomize_ct_bfv(ct);
state.ResumeTiming();
bm_env->evaluator()->relinearize_inplace(ct, bm_env->rlk());
}
}
void bm_bfv_rotate_rows(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
state.ResumeTiming();
bm_env->evaluator()->rotate_rows(ct[0], 1, bm_env->glk(), ct[2]);
}
}
void bm_bfv_rotate_cols(State &state, shared_ptr<BMEnv> bm_env)
{
vector<Ciphertext> &ct = bm_env->ct();
for (auto _ : state)
{
state.PauseTiming();
bm_env->randomize_ct_bfv(ct[0]);
state.ResumeTiming();
bm_env->evaluator()->rotate_columns(ct[0], bm_env->glk(), ct[2]);
}
}
}