最近安裝了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
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
結果:
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
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
在build中生成:
測試
通用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
得到的10個交集: