An implementation of HeContext API with concrete subclasses for HElib scheme. More...

#include <HelibContext.h>

Inheritance diagram for helayers::HelibContext:
helayers::HeContext helayers::HelibBgvContext helayers::HelibCkksContext

Public Member Functions

void init (const HeConfigRequirement &req) override
 Internal use.
 
void initPreset (HelibPreset preset)
 Initalizes with a given preset. More...
 
virtual void init (const HelibConfig &conf)
 Initialize context with given configuration. More...
 
int getTopChainIndex () const override
 Returns the highest available chain index (for schemes where it is applicable).
 
int slotCount () const override
 The number of slots in each CTile (ciphertext) or PTile (plaintext) created over this context.
 
int getSecurityLevel () const override
 Returns the security level supplied by this context.
 
bool hasSecretKey () const override
 Returns whether this context contains a secret key. More...
 
const helib::PubKey & getPublicKey () const
 
const helib::SecKey & getSecretKey () const
 
const helib::Context & getContext () const
 
bool getMirrored () const
 
void setMirrored (bool v)
 
void printSignature (std::ostream &out=std::cout) const override
 Prints a summary of library details and configuration params. More...
 
void debugPrint (const std::string &title="", int verbose=0, std::ostream &out=std::cout) const override
 Prints detailed information for debug purposes. More...
 
void save (std::ostream &out, bool withSecretKey) override
 Saves this context to a stream in binary form. More...
 
void load (std::istream &in) override
 Loads context saved by the save() method. More...
 
void saveSecretKey (std::ostream &out) override
 Save secret key to the given ostream. More...
 
void loadSecretKey (std::istream &in) override
 Load secret key from the given istream. More...
 
std::string getLibraryName () const override
 Returns the name of the underlying library.
 
bool isConfigRequirementFeasible (const HeConfigRequirement &req) const override
 Internal use.
 
- Public Member Functions inherited from helayers::HeContext
 HeContext ()
 Constructs an empty object.
 
 HeContext (const HeContext &src)=delete
 Copy constructor. More...
 
HeContextoperator= (const HeContext &src)=delete
 Copy from another object. More...
 
virtual std::shared_ptr< AbstractCiphertextcreateAbstractCipher ()=0
 Do not use. Should be made private.
 
virtual std::shared_ptr< AbstractPlaintextcreateAbstractPlain ()=0
 Do not use. Should be made private.
 
virtual std::shared_ptr< AbstractEncodergetEncoder ()=0
 Do not use. Should be made private.
 
virtual std::shared_ptr< AbstractFunctionEvaluatorgetFunctionEvaluator ()
 Do not use. Should be made private.
 
virtual std::shared_ptr< AbstractBitwiseEvaluatorgetBitwiseEvaluator ()
 Do not use. Should be made private.
 
const HeTraitsgetTraits ()
 Returns an HeTraits object containing various properties of the underlying scheme.
 
virtual std::shared_ptr< std::vector< uint64_t > > getModulusChain () const
 Returns the modulus chain bit length for each prime in the chain (where applicable).
 
void saveToFile (const std::string &fileName, bool withSecretKey)
 Saves this context to a file in binary form. More...
 
void loadFromFile (const std::string &fileName)
 Loads context saved by the saveToFile() method. More...
 
void saveSecretKeyToFile (const std::string &fileName)
 save secret key to the given file. More...
 
void loadSecretKeyFromFile (const std::string &fileName)
 load secret key from the given file. More...
 
virtual double getDefaultScale () const
 Returns default scale used in encoding (where applicable).
 
virtual void setDefaultScale (double v)
 Sets the default scale to be used in encoding (where applicable). More...
 
virtual std::string getSchemeName () const =0
 Returns the name of the underlying scheme.
 
virtual std::string getSignature () const
 Returns a signature of the context that distinguishes it enough to be able to load previously stored contexts based on their signatures.
 
virtual std::shared_ptr< JsonWrappergetEstimatedLatencies () const
 For internal use.
 
virtual std::shared_ptr< HeContextclone () const
 Returns an uninitialized context of the same type. More...
 

Static Public Member Functions

static std::shared_ptr< HelibContextcreate (HelibPreset preset)
 Creates a new HelibContext for either CKKS or BGV, based on a preset configuration. More...
 
- Static Public Member Functions inherited from helayers::HeContext
static std::shared_ptr< HeContextloadHeContextFromFile (const std::string &fileName)
 Returns a pointer to a context initialized from file. More...
 
static std::shared_ptr< HeContextloadHeContext (std::istream &in)
 Returns a pointer to a context initialized from stream. More...
 
static bool internalRegisterContext (const HeContext *context)
 Registers a context object for the purpose of dynamic loading. More...
 

Protected Attributes

HelibConfig config
 
helib::Context * context = NULL
 
helib::SecKey * secretKey = NULL
 
helib::PubKey * publicKey = NULL
 
long nslots = 0
 
bool mirrored = false
 
- Protected Attributes inherited from helayers::HeContext
HeTraits traits
 

Detailed Description

An implementation of HeContext API with concrete subclasses for HElib scheme.

Member Function Documentation

◆ create()

shared_ptr< HelibContext > helayers::HelibContext::create ( HelibPreset  preset)
static

Creates a new HelibContext for either CKKS or BGV, based on a preset configuration.

See list of presets in HelibConfig.h

Parameters
presetPreset configuration

◆ debugPrint()

void helayers::HelibContext::debugPrint ( const std::string &  title = "",
int  verbose = 0,
std::ostream &  out = std::cout 
) const
overridevirtual

Prints detailed information for debug purposes.

Parameters
[in]titleTitle to print along with the information.
[in]verboseVerbosity level
[in]outOutput stream to print to

Implements helayers::HeContext.

◆ hasSecretKey()

bool helayers::HelibContext::hasSecretKey ( ) const
inlineoverridevirtual

Returns whether this context contains a secret key.

If not, decryption and other operations relying on decryption will not be available (will throw an exception).

Implements helayers::HeContext.

◆ init()

void helayers::HelibContext::init ( const HelibConfig conf)
virtual

Initialize context with given configuration.

Parameters
confConfiguration details

Reimplemented in helayers::HelibCkksContext, and helayers::HelibBgvContext.

◆ initPreset()

void helayers::HelibContext::initPreset ( HelibPreset  preset)

Initalizes with a given preset.

See list of presets in HelibConfig.h

Parameters
presetPreset configuration name

◆ load()

void helayers::HelibContext::load ( std::istream &  in)
overridevirtual

Loads context saved by the save() method.

Parameters
[in]outinput stream to read from

Reimplemented from helayers::HeContext.

◆ loadSecretKey()

void helayers::HelibContext::loadSecretKey ( std::istream &  in)
overridevirtual

Load secret key from the given istream.


Parameters
[in]istreamthe binary stream to load from.
Exceptions
runtime_errorif this HeContext already has a secret key. i.e. hasSecretKey() is ture.

Implements helayers::HeContext.

◆ printSignature()

void helayers::HelibContext::printSignature ( std::ostream &  out = std::cout) const
overridevirtual

Prints a summary of library details and configuration params.

Parameters
[in]outoutput stream to write to

Implements helayers::HeContext.

◆ save()

void helayers::HelibContext::save ( std::ostream &  out,
bool  withSecretKey 
)
overridevirtual

Saves this context to a stream in binary form.

Parameters
[in]outoutput stream to write to
[in]withSecretKeywhether to include the secret key

Reimplemented from helayers::HeContext.

◆ saveSecretKey()

void helayers::HelibContext::saveSecretKey ( std::ostream &  out)
overridevirtual

Save secret key to the given ostream.


Parameters
[out]ostreamthe binary stream to save to.
Exceptions
runtime_errorif this HeContext doesn't have a secret key. i.e. hasSecretKey() is false.

Implements helayers::HeContext.


The documentation for this class was generated from the following files:
  • /opt/IBM/FHE-distro/ML-HElib/src/helayers/hebase/helib/HelibContext.h
  • /opt/IBM/FHE-distro/ML-HElib/src/helayers/hebase/helib/HelibContext.cpp