From 1cb9f218b266af0adf6f5210e425e42c12092a1e Mon Sep 17 00:00:00 2001 From: Brian Muse Date: Tue, 16 Jul 2024 13:51:47 -0700 Subject: [PATCH] Remove failing FBPCF benchmark test. (#543) Summary: Pull Request resolved: https://github.com/facebookresearch/fbpcf/pull/543 Reviewed By: wenhaizhu Differential Revision: D59823285 fbshipit-source-id: 0e101b998e9e88ee233f70c24ab64c014155c0e7 --- .../COTWithRandomMessageBenchmark.cpp | 198 ------------------ 1 file changed, 198 deletions(-) delete mode 100644 fbpcf/mpc_std_lib/walr_multiplication/util/test/benchmarks/COTWithRandomMessageBenchmark.cpp diff --git a/fbpcf/mpc_std_lib/walr_multiplication/util/test/benchmarks/COTWithRandomMessageBenchmark.cpp b/fbpcf/mpc_std_lib/walr_multiplication/util/test/benchmarks/COTWithRandomMessageBenchmark.cpp deleted file mode 100644 index 3b9fe34f..00000000 --- a/fbpcf/mpc_std_lib/walr_multiplication/util/test/benchmarks/COTWithRandomMessageBenchmark.cpp +++ /dev/null @@ -1,198 +0,0 @@ -/* - * 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 -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "common/init/Init.h" - -#include "fbpcf/engine/communication/test/AgentFactoryCreationHelper.h" -#include "fbpcf/engine/tuple_generator/oblivious_transfer/DummyRandomCorrelatedObliviousTransferFactory.h" -#include "fbpcf/engine/tuple_generator/oblivious_transfer/EmpShRandomCorrelatedObliviousTransferFactory.h" -#include "fbpcf/engine/tuple_generator/oblivious_transfer/ExtenderBasedRandomCorrelatedObliviousTransferFactory.h" -#include "fbpcf/engine/tuple_generator/oblivious_transfer/IknpShRandomCorrelatedObliviousTransferFactory.h" -#include "fbpcf/engine/tuple_generator/oblivious_transfer/NpBaseObliviousTransferFactory.h" -#include "fbpcf/engine/tuple_generator/oblivious_transfer/ferret/RcotExtenderFactory.h" -#include "fbpcf/engine/tuple_generator/oblivious_transfer/ferret/RegularErrorMultiPointCotFactory.h" -#include "fbpcf/engine/tuple_generator/oblivious_transfer/ferret/SinglePointCotFactory.h" -#include "fbpcf/engine/tuple_generator/oblivious_transfer/ferret/TenLocalLinearMatrixMultiplierFactory.h" -#include "fbpcf/engine/util/AesPrgFactory.h" -#include "fbpcf/engine/util/test/benchmarks/BenchmarkHelper.h" -#include "fbpcf/engine/util/test/benchmarks/NetworkedBenchmark.h" - -#include "fbpcf/mpc_std_lib/util/test/util.h" -#include "fbpcf/mpc_std_lib/walr_multiplication/util/COTWithRandomMessageFactory.h" - -namespace fbpcf::mpc_std_lib::walr::util { - -class COTWithRandomMessageBenchmark : public engine::util::NetworkedBenchmark { - public: - void setup() override { - auto [agent0, agent1] = engine::util::getSocketAgents(); - agent0_ = std::move(agent0); - agent1_ = std::move(agent1); - - auto [rcotAgent0, rcotAgent1] = engine::util::getSocketAgents(); - rcotAgent0_ = std::move(rcotAgent0); - rcotAgent1_ = std::move(rcotAgent1); - - std::random_device rd; - std::mt19937_64 e(rd()); - std::uniform_int_distribution dist(0, 0xFFFFFFFFFFFFFFFF); - delta_ = _mm_set_epi64x(dist(e), dist(e)); - engine::util::setLsbTo1(delta_); - - choice_ = engine::util::getRandomBoolVector(size_); - - auto prgFactory0 = std::make_unique(); - auto prgFactory1 = std::make_unique(); - - factory_ = std::make_unique(getRcotFactory()); - } - - protected: - void initSender() override { - sender_ = - factory_->create(delta_, std::move(agent0_), std::move(rcotAgent0_)); - } - - void runSender() override { - sender_->send(size_); - } - - void initReceiver() override { - receiver_ = factory_->create(std::move(agent1_), std::move(rcotAgent1_)); - } - - void runReceiver() override { - receiver_->receive(choice_); - } - - std::pair getTrafficStatistics() override { - return sender_->getTrafficStatistics(); - } - - virtual std::unique_ptr - getRcotFactory() = 0; - - std::unique_ptr factory_; - - private: - const size_t size_ = 1000000; - __m128i delta_; - std::vector choice_; - - std::unique_ptr agent0_; - std::unique_ptr agent1_; - - std::unique_ptr rcotAgent0_; - std::unique_ptr rcotAgent1_; - - std::unique_ptr sender_; - std::unique_ptr receiver_; -}; - -class DummyRCOTBasedCOTwRMBenchmark final - : public COTWithRandomMessageBenchmark { - protected: - std::unique_ptr - getRcotFactory() override { - return std::make_unique< - engine::tuple_generator::oblivious_transfer::insecure:: - DummyRandomCorrelatedObliviousTransferFactory>(); - } -}; - -class EmpFerretBasedCOTwRMBenchmark final - : public COTWithRandomMessageBenchmark { - protected: - std::unique_ptr - getRcotFactory() override { - return std::make_unique< - engine::tuple_generator::oblivious_transfer:: - ExtenderBasedRandomCorrelatedObliviousTransferFactory>( - std::make_unique( - std::make_unique(1024)), - std::make_unique( - std::make_unique< - engine::tuple_generator::oblivious_transfer::ferret:: - TenLocalLinearMatrixMultiplierFactory>(), - std::make_unique( - std::make_unique())), - engine::tuple_generator::oblivious_transfer::ferret::kExtendedSize, - engine::tuple_generator::oblivious_transfer::ferret::kBaseSize, - engine::tuple_generator::oblivious_transfer::ferret::kWeight); - } -}; - -class IknpFerretBasedCOTwRMBenchmark final - : public COTWithRandomMessageBenchmark { - protected: - std::unique_ptr - getRcotFactory() override { - return std::make_unique< - engine::tuple_generator::oblivious_transfer:: - ExtenderBasedRandomCorrelatedObliviousTransferFactory>( - std::make_unique( - std::make_unique()), - std::make_unique( - std::make_unique< - engine::tuple_generator::oblivious_transfer::ferret:: - TenLocalLinearMatrixMultiplierFactory>(), - std::make_unique( - std::make_unique())), - engine::tuple_generator::oblivious_transfer::ferret::kExtendedSize, - engine::tuple_generator::oblivious_transfer::ferret::kBaseSize, - engine::tuple_generator::oblivious_transfer::ferret::kWeight); - } -}; - -BENCHMARK_COUNTERS(DummyRCOTBasedCOTwRM, counters) { - DummyRCOTBasedCOTwRMBenchmark benchmark; - benchmark.runBenchmark(counters); -} - -BENCHMARK_COUNTERS(EmpFerretBasedCOTwRM, counters) { - EmpFerretBasedCOTwRMBenchmark benchmark; - benchmark.runBenchmark(counters); -} - -BENCHMARK_COUNTERS(IknpFerretBasedCOTwRM, counters) { - IknpFerretBasedCOTwRMBenchmark benchmark; - benchmark.runBenchmark(counters); -} - -} // namespace fbpcf::mpc_std_lib::walr::util - -int main(int argc, char* argv[]) { - facebook::initFacebook(&argc, &argv); - folly::runBenchmarks(); - return 0; -}