18 #include <NTL/vector.h>
19 #include <NTL/lzz_pX.h>
25 typedef NTL::Vec<long>
zzX;
27 inline bool IsZero(
const zzX& a) {
return a.length() == 0; }
77 const NTL::zz_pXModulus&
getPhimXMod(
const PAlgebra& palg);
80 void MulMod(
zzX& res,
const zzX& a,
const zzX& b,
const PAlgebra& palg);
95 #endif // ifndef HELIB_ZZX_H
void mul(const EncryptedArray &ea, PlaintextArray &pa, const PlaintextArray &other)
Definition: EncryptedArray.cpp:1061
zzX balanced_zzX(const NTL::zz_pX &f)
Definition: zzX.cpp:122
NTL::Vec< long > zzX
Definition: zzX.h:24
bool IsZero(const zzX &a)
Definition: zzX.h:27
Tensor< T, 2 > operator*(const Tensor< T, 2 > &M1, const Tensor< T2, 2 > &M2)
Definition: Matrix.h:473
void normalize(zzX &f)
Definition: zzX.cpp:65
zzX & operator*=(zzX &a, long b)
Definition: zzX.h:69
IndexSet operator/(const IndexSet &s, const IndexSet &t)
set minus
Definition: IndexSet.cpp:256
zzX & operator/=(zzX &a, long b)
Definition: zzX.h:56
The structure of (Z/mZ)* /(p)
Definition: PAlgebra.h:77
void div(std::vector< NTL::ZZX > &x, const std::vector< NTL::ZZX > &a, long b)
Definition: NumbTh.cpp:1338
void clear(zzX &a)
Definition: zzX.h:28
void MulMod(NTL::ZZX &out, const NTL::ZZX &f, long a, long q, bool abs)
Definition: NumbTh.cpp:831
void reduceModPhimX(zzX &poly, const PAlgebra &palg)
Definition: zzX.cpp:111
Definition: apiAttributes.h:21
void add(const EncryptedArray &ea, PlaintextArray &pa, const PlaintextArray &other)
Definition: EncryptedArray.cpp:1005
void convert(long &x1, const NTL::GF2X &x2)
Definition: NumbTh.h:361
zzX & operator+=(zzX &a, const zzX &b)
Definition: zzX.h:43
zzX operator+(const zzX &a, const zzX &b)
Definition: zzX.h:37
const NTL::zz_pXModulus & getPhimXMod(const PAlgebra &palg)
Definition: zzX.cpp:79