APSI - 0

最近安装了APSI库,尝试了多种方法,现在总结一下!

先提下安装环境需求:

第三方依赖包:

Mac#

vcpkg#

使用vcpkg一键安装
1、先安装vcpkg
(1)第一种方法

  git clone git://github.com/microsoft/vcpkg
  ./vcpkg/bootstrap-vcpkg.sh

在mac上设置全局环境变量:

vim ~/.bash_profile

如果没有bash_profile,则新建一个就行

添加:export PATH=${PATH}:【vcpkg安装目录】
使生效:

source .bash_profile

(2)第二种方法
在 macOS 中,您唯一需要做的是在终端中运行以下命令:

xcode-select --install

然后按照出现的窗口中的提示进行操作。 此时,您就可以使用 ./bootstrap.sh 编译vcpkg了

2、安装APSI

默认APSI_BUILD_TESTS(build tests)和APSI_BUILD_CLI(build cli)是OFF,所以不会生成可执行文件(sender_cli和receiver_cli)
以上工作做好后,一键安装apsi

./vcpkg install apsi

在vcpkg目录中可以找到安装:

cmake+vscode+vcpkg#

1、下载

git clone git://github.com/microsoft/APSI.git

为了使在cmake时自动安装依赖(seal、kuku等),需要设置一下
在vscode的setting.json文件中添加:

{
  "cmake.configureSettings": {
    "CMAKE_TOOLCHAIN_FILE": "[vcpkg root]/scripts/buildsystems/vcpkg.cmake"
  }
}

按照文档说的应该是自动安装那些依赖包,我安装时是自己一个个安装的,即:

vcpkg install seal[no-throw-tran] kuku log4cplus cppzmq flatbuffers jsoncpp gtest tclap

2、编译

为了可以测试test和cli,需要手动安装gtest和tclap
image

vcpkg install gtest tclap

修改CMakeLists.txt文件(改为ON):
image

开始编译:

mkdir build
cd build
cmake ..
make

如果make时遇到/usr/local/lib/cmake/APSI-0.7/APSITargets.cmake": Permission denied,则可以sudo make

结果:

cmake+clion+vcpkg#

1、下载

git clone git://github.com/microsoft/APSI.git

为了使在cmake时自动安装依赖(seal、kuku等),需要设置一下
在clion中设置:File > Settings->Build, Execution, Deployment > CMake添加:

-DCMAKE_TOOLCHAIN_FILE=[vcpkg root]/scripts/buildsystems/vcpkg.cmake

2、编译

为了可以测试test和cli,需要手动安装gtest和tclap
image

vcpkg install gtest tclap

修改CMakeLists.txt文件(改为ON):
image
开始编译:

mkdir build
cd build
cmake ..
make

如果make时遇到/usr/local/lib/cmake/APSI-0.7/APSITargets.cmake": Permission denied,则可以sudo make

测试#

生成数据#

APSI中提供的数据存储形式:(1)存储在SendDB中(2)存储在CSV文件中

tools/scripts/test_data_creator.py中就是生成CLI的测试数据

python3 test_data_creator.py <sender_size> <receiver_size> <intersection_size> [<label_byte_count>] [<item_byte_count>]

三个必要参数:
<sender_size>:表示发送方数据集的大小,生层数据文件db.csv,如果此文件已存在,将被覆盖。
<receiver_size>:表示接收方数据集的大小,生层数据文件query.csv,如果此文件已存在,将被覆盖。
<intersection_size>:表示db.csv和query.csv中共有的item数量,即规定交集大小。
两个可选参数:
<label_byte_count>:表示db.csv中随机生成的label字节大小,如果省略,则db.csv中的数据是unLabeled的。
<item_byte_count>:表示item的大小,如果省略,则是64。
例如:

python3 ../tools/scripts/test_data_creator.py 10000 100 10 

在build中生成:
image

测试#

通用CLI命令选项:
image
发送方CLI命令选项:
image
接收方CLI命令选项:
image
例如:
(1)sender
sender方需要json文件作为参数传递的,库中提供了一些json文件,在 parameters/文件夹下。
image
这些文件用三个数字命名,其中前两个数字分别表示发送方和接收方集合大小的建议上限,第三个(可选)数字表示参数用于label模式,并表示label的字节大小;最后文件名中的可选说明符-com或-cmp结尾,表示参数是否经过优化以最小化通信或计算成本。

./sender_cli -d /Users/pam/Desktop/pam/APSI-main/build/db_10000_0_10_0_64.csv -p /Users/pam/Desktop/pam/APSI-main/parameters/1M-256.json -c -t 1

(2)receiver

./receiver_cli -q /Users/pam/Desktop/pam/APSI-main/build/query_0_100_10_0_64.csv -t 1 -o /Users/pam/Desktop/pam/APSI-main/build/test_0_100_10_0_64.csv

image
得到的10个交集:
image

作者:Hang Shao

出处:https://www.cnblogs.com/pam-sh/p/16009319.html

版权:本作品采用「知识共享」许可协议进行许可。

声明:欢迎交流! 原文链接 ,如有问题,可邮件(mir_soh@163.com)咨询.

posted @   PamShao  阅读(1551)  评论(4编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2020-03-15 数据库 基本概念
点击右上角即可分享
微信分享提示
more_horiz
keyboard_arrow_up dark_mode palette
选择主题
menu