Ian Goldberg 7b94f67102 Add "earlyclobber" constraint to oselect_uint32_t преди 2 години
..
CONFIG.h 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
ORExpand.cpp ccaa8afc38 More realistic test sizes in test_ORExpand_parallel преди 2 години
ORExpand.hpp d122d04a6d Implementation of ORExpand (multi-threaded version) преди 2 години
ORExpand.tcc 39a5066ab3 Add a comment for future possible optimization преди 2 години
README 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
RecursiveShuffle.cpp 2562d9ac86 Rather than pre-allocating an array of randomness pools, just give each thread its own thread-local randomness pool преди 2 години
RecursiveShuffle.hpp 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
RecursiveShuffle.tcc 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
SortingNetwork.cpp 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
SortingNetwork.hpp 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
SortingNetwork.tcc 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
TightCompaction_v2.cpp 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
TightCompaction_v2.hpp 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
TightCompaction_v2.tcc 8368bdca59 Fix an out-of-date comment преди 2 години
WaksmanNetwork.cpp ae3646cf41 Sort using precomputable shuffles преди 2 години
WaksmanNetwork.hpp ae3646cf41 Sort using precomputable shuffles преди 2 години
WaksmanNetwork.tcc 5cb57bc4be Generalize sort_mtobliv to be able to sort on different kinds of keys преди 2 години
aes.hpp 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
foav.h 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
oasm_lib.h 7b94f67102 Add "earlyclobber" constraint to oselect_uint32_t преди 2 години
oasm_lib.tcc 0a23f8293c Port code for oblivious compaction, shuffle, sort преди 2 години
utils.cpp 876ba2eeec Remove an unused (and incorrect in any case) function преди 2 години
utils.hpp 876ba2eeec Remove an unused (and incorrect in any case) function преди 2 години

README

This directory contains code ported from "Fast Fully Oblivious
Compaction and Shuffling" and "Waks-On/Waks-Off: Fast Oblivious
Offline/Online Shuffling and Sorting with Waksman Networks" by
Sajin Sasy, Aaron Johnson, and Ian Goldberg:

https://crysp.uwaterloo.ca/software/obliv/

with some additional enhancements, such as a multithreaded
implementation of WaksShuffle + Sort and WaksSort.