From 4861c1df8185d404d53804a66d14c2106b586199 Mon Sep 17 00:00:00 2001 From: Elliott Lawrence Date: Wed, 16 Mar 2022 13:14:22 -0700 Subject: [PATCH] Benchmark for Product Share Generator (#81) Summary: Pull Request resolved: https://github.com/facebookresearch/fbpcf/pull/81 Same idea as previous diffs. This file will contain benchmarks for everything in the `tuple_generator` folder, and this diff starts with just the product share generator. Reviewed By: RuiyuZhu Differential Revision: D34808834 fbshipit-source-id: 49a01f3348b8779ae5211a681dac0432a4315462 --- .../benchmarks/TupleGeneratorBenchmark.cpp | 96 +++++++++++++++++++ 1 file changed, 96 insertions(+) create mode 100644 fbpcf/engine/tuple_generator/test/benchmarks/TupleGeneratorBenchmark.cpp diff --git a/fbpcf/engine/tuple_generator/test/benchmarks/TupleGeneratorBenchmark.cpp b/fbpcf/engine/tuple_generator/test/benchmarks/TupleGeneratorBenchmark.cpp new file mode 100644 index 00000000..2e1108e7 --- /dev/null +++ b/fbpcf/engine/tuple_generator/test/benchmarks/TupleGeneratorBenchmark.cpp @@ -0,0 +1,96 @@ +/* + * Copyright (c) Meta Platforms, Inc. and affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +#include + +#include "common/init/Init.h" + +#include "fbpcf/engine/tuple_generator/ProductShareGeneratorFactory.h" +#include "fbpcf/engine/tuple_generator/oblivious_transfer/RcotBasedBidirectionObliviousTransferFactory.h" +#include "fbpcf/engine/tuple_generator/oblivious_transfer/RcotHelper.h" +#include "fbpcf/engine/tuple_generator/test/TupleGeneratorTestHelper.h" +#include "fbpcf/engine/util/AesPrgFactory.h" +#include "fbpcf/engine/util/test/benchmarks/BenchmarkHelper.h" +#include "fbpcf/engine/util/test/benchmarks/NetworkedBenchmark.h" + +namespace fbpcf::engine::tuple_generator { + +class ProductShareGeneratorBenchmark : public util::NetworkedBenchmark { + public: + void setup() override { + auto [agentFactory0, agentFactory1] = util::getSocketAgentFactories(); + agentFactory0_ = std::move(agentFactory0); + agentFactory1_ = std::move(agentFactory1); + + senderFactory_ = std::make_unique>( + std::make_unique(), + std::make_unique< + oblivious_transfer::RcotBasedBidirectionObliviousTransferFactory< + bool>>( + 0, *agentFactory0_, oblivious_transfer::createFerretRcotFactory())); + + receiverFactory_ = std::make_unique>( + std::make_unique(), + std::make_unique< + oblivious_transfer::RcotBasedBidirectionObliviousTransferFactory< + bool>>( + 1, *agentFactory1_, oblivious_transfer::createFerretRcotFactory())); + + senderLeft_ = util::getRandomBoolVector(size_); + senderRight_ = util::getRandomBoolVector(size_); + + receiverLeft_ = util::getRandomBoolVector(size_); + receiverRight_ = util::getRandomBoolVector(size_); + } + + void runSender() override { + sender_ = senderFactory_->create(1); + sender_->generateBooleanProductShares(senderLeft_, senderRight_); + } + + void runReceiver() override { + receiver_ = receiverFactory_->create(0); + receiver_->generateBooleanProductShares(receiverLeft_, receiverRight_); + } + + std::pair getTrafficStatistics() override { + return sender_->getTrafficStatistics(); + } + + private: + size_t size_ = 1000000; + + std::unique_ptr + agentFactory0_; + std::unique_ptr + agentFactory1_; + + std::unique_ptr senderFactory_; + std::unique_ptr receiverFactory_; + + std::unique_ptr sender_; + std::unique_ptr receiver_; + + std::vector senderLeft_; + std::vector receiverLeft_; + + std::vector senderRight_; + std::vector receiverRight_; +}; + +BENCHMARK_COUNTERS(ProductShareGenerator, counters) { + ProductShareGeneratorBenchmark benchmark; + benchmark.runBenchmark(counters); +} + +} // namespace fbpcf::engine::tuple_generator + +int main(int argc, char* argv[]) { + facebook::initFacebook(&argc, &argv); + folly::runBenchmarks(); + return 0; +}