// BSD 2-Clause License // Copyright (c) 2023, OpenFHE // All rights reserved. // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are met: // 1. Redistributions of source code must retain the above copyright notice, this // list of conditions and the following disclaimer. // 2. Redistributions in binary form must reproduce the above copyright notice, // this list of conditions and the following disclaimer in the documentation // and/or other materials provided with the distribution. // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE // DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE // FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL // DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, // OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. #ifndef OPENFHE_CRYPTOCONTEXT_BINDINGS_H #define OPENFHE_CRYPTOCONTEXT_BINDINGS_H #include #include #include #include #include "openfhe.h" using namespace lbcrypto; using ParmType = typename DCRTPoly::Params; Ciphertext EvalFastRotationPrecomputeWrapper(CryptoContext& self, ConstCiphertext ciphertext); Ciphertext EvalFastRotationWrapper(CryptoContext& self, ConstCiphertext ciphertext, const usint index, const usint m, ConstCiphertext digits); Ciphertext EvalFastRotationExtWrapper(CryptoContext& self,ConstCiphertext ciphertext, const usint index, ConstCiphertext digits, bool addFirst); Plaintext DecryptWrapper(CryptoContext& self, ConstCiphertext ciphertext,const PrivateKey privateKey); Plaintext DecryptWrapper(CryptoContext& self, const PrivateKey privateKey,ConstCiphertext ciphertext); Plaintext MultipartyDecryptFusionWrapper(CryptoContext& self,const std::vector>& partialCiphertextVec); const std::map> EvalAutomorphismKeyGenWrapper(CryptoContext& self,const PrivateKey privateKey,const std::vector &indexList); const std::shared_ptr>> GetEvalSumKeyMapWrapper(CryptoContext& self, const std::string &id); const PlaintextModulus GetPlaintextModulusWrapper(CryptoContext& self); const double GetModulusWrapper(CryptoContext& self); void RemoveElementWrapper(Ciphertext& self, usint index); const double GetScalingFactorRealWrapper(CryptoContext& self, uint32_t l); const uint64_t GetModulusCKKSWrapper(CryptoContext& self); const ScalingTechnique GetScalingTechniqueWrapper(CryptoContext& self); const usint GetDigitSizeWrapper(CryptoContext& self); #endif // OPENFHE_CRYPTOCONTEXT_BINDINGS_H