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
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、编译
vcpkg install gtest tclap
开始编译:
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、编译
vcpkg install gtest tclap
修改CMakeLists.txt文件(改为ON):
开始编译:
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
测试#
通用CLI命令选项:
发送方CLI命令选项:
接收方CLI命令选项:
例如:
(1)sender
sender方需要json文件作为参数传递的,库中提供了一些json文件,在 parameters/文件夹下。
这些文件用三个数字命名,其中前两个数字分别表示发送方和接收方集合大小的建议上限,第三个(可选)数字表示参数用于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
作者:Hang Shao
出处:https://www.cnblogs.com/pam-sh/p/16009319.html
版权:本作品采用「知识共享」许可协议进行许可。
声明:欢迎交流! 原文链接 ,如有问题,可邮件(mir_soh@163.com)咨询.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
2020-03-15 数据库 基本概念