// 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 #include "openfhe.h" #include "bindings.h" namespace py = pybind11; 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); const std::map> EvalAutomorphismKeyGenWrapper(CryptoContext& self,const PrivateKey privateKey,const std::vector &indexList); const std::map> EvalAutomorphismKeyGenWrapper_PublicKey(CryptoContext& self,const PublicKey publicKey, const PrivateKey privateKey, const std::vector &indexList); #endif // OPENFHE_CRYPTOCONTEXT_BINDINGS_H