keySwitching.h
void read(std::istream &str, const Context &context)
Raw IO.
Definition: keySwitching.cpp:235
bool operator==(const KeySwitch &other) const
Definition: keySwitching.cpp:44
void addTheseMatrices(SecKey &sKey, const std::set< long > &automVals, long keyID=0)
Generate specific key-switching matrices, described by the given set.
Definition: keySwitching.cpp:643
void addFewMatrices(SecKey &sKey, long keyID=0)
Generate matrices so every s(X^e) can be reLinearized in at most two steps.
A handle, describing the secret-key element that "matches" a part, of the form s^r(X^t).
Definition: Ctxt.h:78
long KSGiantStepSize(long D)
Function that returns number of baby steps. Used to keep this and matmul routines "in sync".
Definition: keySwitching.cpp:252
void addAllMatrices(SecKey &sKey, long keyID=0)
Maximalistic approach: generate matrices s(X^e)->s(X) for all e in Zm*.
Definition: keySwitching.cpp:262
void add1DMatrices(SecKey &sKey, long keyID=0)
Generate all matrices s(X^{g^i})->s(X) for generators g of Zm* /(p) and i<ord(g). If g has different ...
Definition: keySwitching.cpp:543
void addFrbMatrices(SecKey &sKey, long keyID=0)
Definition: keySwitching.cpp:565
bool operator!=(const KeySwitch &other) const
Definition: keySwitching.cpp:67
KeySwitch(const SKHandle &_fromKey, long fromID=0, long toID=0, long p=0)
Definition: apiAttributes.h:21
void addMinimal1DMatrices(SecKey &sKey, long keyID=0)
These routines just add a single matrix (or two, for bad dimensions)
Definition: keySwitching.cpp:603
void addBSGS1DMatrices(SecKey &sKey, long keyID=0)
Definition: keySwitching.cpp:548
void addMinimalFrbMatrices(SecKey &sKey, long keyID=0)
Definition: keySwitching.cpp:615
std::ostream & operator<<(std::ostream &s, const SKHandle &handle)
Definition: Ctxt.h:190
void addMatrices4Network(SecKey &sKey, const PermNetwork &net, long keyID=0)
Definition: keySwitching.cpp:622
void addSomeFrbMatrices(SecKey &sKey, long bound=HELIB_KEYSWITCH_THRESH, long keyID=0)
Generate all/some Frobenius matrices of the form s(X^{p^i})->s(X)
Definition: keySwitching.cpp:554
void addSome1DMatrices(SecKey &sKey, long bound=HELIB_KEYSWITCH_THRESH, long keyID=0)
Generate some matrices of the form s(X^{g^i})->s(X), but not all. For a generator g whose order is la...
Definition: keySwitching.cpp:528
void readMatrix(std::istream &str, const Context &context)
Read a key-switching matrix from input.
Definition: keySwitching.cpp:193
KeySwitch(long sPow=0, long xPow=0, long fromID=0, long toID=0, long p=0)
Definition: keySwitching.cpp:33
static const KeySwitch & dummy()
returns a dummy static matrix with toKeyId == -1
Definition: keySwitching.cpp:175
void addBSGSFrbMatrices(SecKey &sKey, long keyID=0)
Definition: keySwitching.cpp:570