亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? gf2e.h

?? 可以根據NTL庫進RSA加密、解密算法的實現
?? H
字號:


#ifndef NTL_GF2E__H
#define NTL_GF2E__H

#include <NTL/GF2X.h>

NTL_OPEN_NNS



class GF2EInfoT {
private:
   GF2EInfoT();                       // disabled
   GF2EInfoT(const GF2EInfoT&);   // disabled
   void operator=(const GF2EInfoT&);  // disabled
public:
   long ref_count;

   GF2EInfoT(const GF2X& NewP);
   ~GF2EInfoT() { }

   GF2XModulus p;

   long KarCross;
   long ModCross;
   long DivCross;

   ZZ   _card;
   long _card_init;
   long _card_exp;
};

extern GF2EInfoT *GF2EInfo; // info for current modulus, initially null




class GF2EContext {
private:
GF2EInfoT *ptr;

public:
void save();
void restore() const;

GF2EContext() { ptr = 0; }
GF2EContext(const GF2X& p);

GF2EContext(const GF2EContext&); 


GF2EContext& operator=(const GF2EContext&); 


~GF2EContext();


};


class GF2EBak {
private:
long MustRestore;
GF2EInfoT *ptr;

GF2EBak(const GF2EBak&); // disabled
void operator=(const GF2EBak&); // disabled

public:
void save();
void restore();

GF2EBak() { MustRestore = 0; ptr = 0; }

~GF2EBak();


};



struct GF2E_NoAlloc_type { GF2E_NoAlloc_type() { } };
const GF2E_NoAlloc_type GF2E_NoAlloc = GF2E_NoAlloc_type();



class GF2E {

public:

GF2X _GF2E__rep;


// ****** constructors and assignment

GF2E() { _GF2E__rep.xrep.SetMaxLength(GF2E::WordLength()); }

GF2E(GF2E& x, INIT_TRANS_TYPE) : _GF2E__rep(x._GF2E__rep, INIT_TRANS) { }

GF2E(const GF2E& a)  
   { _GF2E__rep.xrep.SetMaxLength(GF2E::WordLength()); _GF2E__rep = a._GF2E__rep; }

GF2E(GF2E_NoAlloc_type) { }  // allocates no space

~GF2E() { } 

GF2E& operator=(const GF2E& a) { _GF2E__rep = a._GF2E__rep; return *this; }

inline GF2E& operator=(long a);
inline GF2E& operator=(GF2 a);

// You can always access the _GF2E__representation directly...if you dare.
GF2X& LoopHole() { return _GF2E__rep; }

static long WordLength() { return GF2EInfo->p.WordLength(); }

static long storage() { return WV_storage(GF2E::WordLength()); }

static const GF2XModulus& modulus() { return GF2EInfo->p; }

static long KarCross() { return GF2EInfo->KarCross; }
static long ModCross() { return GF2EInfo->ModCross; }
static long DivCross() { return GF2EInfo->DivCross; }

static long degree() { return GF2EInfo->p.n; }

static const GF2E& zero();

static const ZZ& cardinality();

static void init(const GF2X& NewP);

};



// read-only access to GF2E representation
inline const GF2X& rep(const GF2E& a) { return a._GF2E__rep; }

inline void clear(GF2E& x)
// x = 0
   { clear(x._GF2E__rep); }

inline void set(GF2E& x)
// x = 1
   { set(x._GF2E__rep); }

inline void swap(GF2E& x, GF2E& y)
// swap x and y

   { swap(x._GF2E__rep, y._GF2E__rep); }

// ****** addition

inline void add(GF2E& x, const GF2E& a, const GF2E& b)
   { add(x._GF2E__rep, a._GF2E__rep, b._GF2E__rep); }

inline void add(GF2E& x, const GF2E& a, GF2 b)
   { add(x._GF2E__rep, a._GF2E__rep, b); }

inline void add(GF2E& x, const GF2E& a, long b)
   { add(x._GF2E__rep, a._GF2E__rep, b); }

inline void add(GF2E& x, GF2 a, const GF2E& b)  { add(x, b, a); }
inline void add(GF2E& x, long a, const GF2E& b)  { add(x, b, a); }

inline void sub(GF2E& x, const GF2E& a, const GF2E& b) { add(x, a, b); }
inline void sub(GF2E& x, const GF2E& a, GF2 b) { add(x, a, b); }
inline void sub(GF2E& x, const GF2E& a, long b) { add(x, a, b); }
inline void sub(GF2E& x, GF2 a, const GF2E& b) { add(x, a, b); }
inline void sub(GF2E& x, long a, const GF2E& b) { add(x, a, b); }

inline void negate(GF2E& x, const GF2E& a) { x = a; }


inline GF2E operator+(const GF2E& a, const GF2E& b) 
   { GF2E x; add(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator+(const GF2E& a, GF2 b) 
   { GF2E x; add(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator+(const GF2E& a, long b) 
   { GF2E x; add(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator+(GF2 a, const GF2E& b) 
   { GF2E x; add(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator+(long a, const GF2E& b) 
   { GF2E x; add(x, a, b); NTL_OPT_RETURN(GF2E, x); }


inline GF2E operator-(const GF2E& a, const GF2E& b) 
   { GF2E x; sub(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator-(const GF2E& a, GF2 b) 
   { GF2E x; sub(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator-(const GF2E& a, long b) 
   { GF2E x; sub(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator-(GF2 a, const GF2E& b) 
   { GF2E x; sub(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator-(long a, const GF2E& b) 
   { GF2E x; sub(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator-(const GF2E& a)
   { GF2E x; negate(x, a); NTL_OPT_RETURN(GF2E, x); } 


inline GF2E& operator+=(GF2E& x, const GF2E& b)
   { add(x, x, b); return x; }

inline GF2E& operator+=(GF2E& x, GF2 b)
   { add(x, x, b); return x; }

inline GF2E& operator+=(GF2E& x, long b)
   { add(x, x, b); return x; }


inline GF2E& operator-=(GF2E& x, const GF2E& b)
   { sub(x, x, b); return x; }

inline GF2E& operator-=(GF2E& x, GF2 b)
   { sub(x, x, b); return x; }

inline GF2E& operator-=(GF2E& x, long b)
   { sub(x, x, b); return x; }


inline GF2E& operator++(GF2E& x) { add(x, x, 1); return x; }

inline void operator++(GF2E& x, int) { add(x, x, 1); }

inline GF2E& operator--(GF2E& x) { sub(x, x, 1); return x; }

inline void operator--(GF2E& x, int) { sub(x, x, 1); }



// ****** multiplication

inline void mul(GF2E& x, const GF2E& a, const GF2E& b)
// x = a*b

   { MulMod(x._GF2E__rep, a._GF2E__rep, b._GF2E__rep, GF2E::modulus()); }


inline void sqr(GF2E& x, const GF2E& a)
// x = a^2

   { SqrMod(x._GF2E__rep, a._GF2E__rep, GF2E::modulus()); }

inline GF2E sqr(const GF2E& a)
   { GF2E x; sqr(x, a); NTL_OPT_RETURN(GF2E, x); }

inline void mul(GF2E& x, const GF2E& a, GF2 b)
   { mul(x._GF2E__rep, a._GF2E__rep, b); }

inline void mul(GF2E& x, const GF2E& a, long b)
   { mul(x._GF2E__rep, a._GF2E__rep, b); }

inline void mul(GF2E& x, GF2 a, const GF2E& b) { mul(x, b, a); }
inline void mul(GF2E& x, long a, const GF2E& b) { mul(x, b, a); }



inline GF2E operator*(const GF2E& a, const GF2E& b) 
   { GF2E x; mul(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator*(const GF2E& a, GF2 b) 
   { GF2E x; mul(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator*(const GF2E& a, long b) 
   { GF2E x; mul(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator*(GF2 a, const GF2E& b) 
   { GF2E x; mul(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator*(long a, const GF2E& b) 
   { GF2E x; mul(x, a, b); NTL_OPT_RETURN(GF2E, x); }


inline GF2E& operator*=(GF2E& x, const GF2E& b)
   { mul(x, x, b); return x; }

inline GF2E& operator*=(GF2E& x, GF2 b)
   { mul(x, x, b); return x; }

inline GF2E& operator*=(GF2E& x, long b)
   { mul(x, x, b); return x; }



// ****** division



void div(GF2E& x, const GF2E& a, const GF2E& b);

void inv(GF2E& x, const GF2E& a);

inline GF2E inv(const GF2E& a)
   { GF2E x; inv(x, a); NTL_OPT_RETURN(GF2E, x); }

inline void div(GF2E& x, const GF2E& a, GF2 b)
   { div(x._GF2E__rep, a._GF2E__rep, b); } 

inline void div(GF2E& x, const GF2E& a, long b)
   { div(x._GF2E__rep, a._GF2E__rep, b); } 

void div(GF2E& x, GF2 a, const GF2E& b);
void div(GF2E& x, long a, const GF2E& b);


inline GF2E operator/(const GF2E& a, const GF2E& b) 
   { GF2E x; div(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator/(const GF2E& a, GF2 b) 
   { GF2E x; div(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator/(const GF2E& a, long b) 
   { GF2E x; div(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator/(GF2 a, const GF2E& b) 
   { GF2E x; div(x, a, b); NTL_OPT_RETURN(GF2E, x); }

inline GF2E operator/(long a, const GF2E& b) 
   { GF2E x; div(x, a, b); NTL_OPT_RETURN(GF2E, x); }


inline GF2E& operator/=(GF2E& x, const GF2E& b)
   { div(x, x, b); return x; }

inline GF2E& operator/=(GF2E& x, GF2 b)
   { div(x, x, b); return x; }

inline GF2E& operator/=(GF2E& x, long b)
   { div(x, x, b); return x; }


// ****** exponentiation

inline void power(GF2E& x, const GF2E& a, const ZZ& e)
   { PowerMod(x._GF2E__rep, a._GF2E__rep, e, GF2E::modulus()); }

inline GF2E power(const GF2E& a, const ZZ& e)
   { GF2E x; power(x, a, e); NTL_OPT_RETURN(GF2E, x); }

inline void power(GF2E& x, const GF2E& a, long e)
   { PowerMod(x._GF2E__rep, a._GF2E__rep, e, GF2E::modulus()); }

inline GF2E power(const GF2E& a, long e)
   { GF2E x; power(x, a, e); NTL_OPT_RETURN(GF2E, x); }


// ****** conversion

inline void conv(GF2E& x, const GF2X& a)
// x = (a mod p)

   { rem(x._GF2E__rep, a, GF2E::modulus()); }

inline void conv(GF2E& x, long a)
   { conv(x._GF2E__rep, a); }

inline void conv(GF2E& x, GF2 a)
   { conv(x._GF2E__rep, a); }

inline void conv(GF2E& x, const ZZ& a)
   { conv(x._GF2E__rep, a); }

inline GF2E to_GF2E(const GF2X& a)
   { GF2E x; conv(x, a); NTL_OPT_RETURN(GF2E, x); }

inline GF2E to_GF2E(long a)
   { GF2E x; conv(x, a); NTL_OPT_RETURN(GF2E, x); }

inline GF2E to_GF2E(GF2 a)
   { GF2E x; conv(x, a); NTL_OPT_RETURN(GF2E, x); }

inline GF2E to_GF2E(const ZZ& a)
   { GF2E x; conv(x, a); NTL_OPT_RETURN(GF2E, x); }


// ****** comparison

inline long IsZero(const GF2E& a)
   { return IsZero(a._GF2E__rep); }

inline long IsOne(const GF2E& a)
   { return IsOne(a._GF2E__rep); }

inline long operator==(const GF2E& a, const GF2E& b)
   { return a._GF2E__rep == b._GF2E__rep; }

inline long operator==(const GF2E& a, GF2 b)
   { return a._GF2E__rep == b; }

inline long operator==(const GF2E& a, long b)
   { return a._GF2E__rep == b; }

inline long operator==(const GF2 a, const GF2E& b)
   { return a == b._GF2E__rep; }

inline long operator==(const long a, const GF2E& b)
   { return a == b._GF2E__rep; }


inline long operator!=(const GF2E& a, const GF2E& b) { return !(a == b); }
inline long operator!=(const GF2E& a, GF2 b) { return !(a == b); }
inline long operator!=(const GF2E& a, long b) { return !(a == b); }
inline long operator!=(GF2 a, const GF2E& b) { return !(a == b); }
inline long operator!=(long a, const GF2E& b) { return !(a == b); }

// ****** trace

inline void trace(GF2& x, const GF2E& a)
   { TraceMod(x, a._GF2E__rep, GF2E::modulus()); }
inline GF2 trace(const GF2E& a)
   { return TraceMod(a._GF2E__rep, GF2E::modulus()); }



// ****** random numbers

inline void random(GF2E& x)
// x = random element in GF2E

   { random(x._GF2E__rep, GF2EInfo->p.n); }

inline GF2E random_GF2E()
   { GF2E x; random(x); NTL_OPT_RETURN(GF2E, x); }


// ****** input/output

inline NTL_SNS ostream& operator<<(NTL_SNS ostream& s, const GF2E& a)
   { return s << a._GF2E__rep; }
   
NTL_SNS istream& operator>>(NTL_SNS istream& s, GF2E& x);


inline GF2E& GF2E::operator=(long a) { conv(*this, a); return *this; }
inline GF2E& GF2E::operator=(GF2 a) { conv(*this, a); return *this; }

NTL_CLOSE_NNS

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品激情偷乱一区二区∴| 成人h动漫精品一区二| 亚洲一区二区成人在线观看| 国产精品家庭影院| 中文字幕一区在线| 亚洲天堂免费在线观看视频| 亚洲丝袜自拍清纯另类| 亚洲欧洲日韩在线| 亚洲精品视频自拍| 一区二区成人在线| 日韩中文字幕亚洲一区二区va在线| 亚洲v中文字幕| 日韩高清一区在线| 久久国产精品99久久久久久老狼 | 亚洲视频香蕉人妖| 亚洲欧洲性图库| 一级日本不卡的影视| 午夜精品久久久久久久99樱桃| 日本免费在线视频不卡一不卡二| 理论电影国产精品| 国产精品99久久久久久有的能看| 国产精品正在播放| 99麻豆久久久国产精品免费优播| 色哟哟一区二区| 7777精品伊人久久久大香线蕉最新版| 日韩精品资源二区在线| 国产欧美精品一区| 亚洲精品免费在线观看| 午夜天堂影视香蕉久久| 国产一区二区看久久| caoporen国产精品视频| 欧美性大战久久久| 日韩精品一区二| 国产精品久久久久久久裸模| 亚洲资源中文字幕| 国产在线麻豆精品观看| bt欧美亚洲午夜电影天堂| 欧美性大战久久久| 精品国产sm最大网站免费看| 国产精品不卡在线| 蜜桃av噜噜一区| 成人精品视频一区| 91精品国产综合久久久久久漫画 | 久久久不卡影院| 亚洲日本在线天堂| 另类小说图片综合网| av中文字幕在线不卡| 91精品国产综合久久久蜜臀图片| 国产欧美视频在线观看| 五月综合激情日本mⅴ| 国产麻豆精品theporn| 欧美午夜精品一区| 国产情人综合久久777777| 香蕉av福利精品导航| 国v精品久久久网| 91精品国产91久久久久久一区二区 | 欧美一级日韩不卡播放免费| 欧美激情在线看| 免费观看在线色综合| 99久免费精品视频在线观看| 欧美v国产在线一区二区三区| 亚洲欧美国产毛片在线| 国产一区二区三区四区五区入口| 欧美专区亚洲专区| 亚洲国产成人一区二区三区| 日韩精品免费专区| 色婷婷综合久久久久中文一区二区| 欧美mv日韩mv亚洲| 亚洲成人福利片| 色一情一伦一子一伦一区| 久久精品夜夜夜夜久久| 日本中文在线一区| 欧美午夜免费电影| 日韩美女视频一区| 国产成人亚洲精品青草天美| 日韩欧美一区二区视频| 亚洲综合免费观看高清在线观看| 成人亚洲一区二区一| 久久亚洲综合色一区二区三区| 午夜视频一区在线观看| 91视频精品在这里| 国产精品久久久久久久久搜平片 | 欧美在线不卡视频| 亚洲日本va午夜在线影院| 国产成人免费av在线| 日韩精品一区二区三区老鸭窝| 亚洲国产精品久久不卡毛片| 色先锋久久av资源部| 国产精品久久久久精k8| 成人性生交大片免费 | 国内精品久久久久影院一蜜桃| 欧美高清性hdvideosex| 亚洲电影欧美电影有声小说| 91色porny在线视频| 亚洲色图色小说| 成人高清视频免费观看| 国产精品免费av| 成人免费av资源| 国产精品欧美极品| 成人在线一区二区三区| 国产精品色在线观看| 成人av网站在线| 日韩一区有码在线| 91麻豆国产精品久久| 一区二区三区中文在线| 欧洲视频一区二区| 亚洲成人免费av| 91精品国产免费| 老色鬼精品视频在线观看播放| 欧美一区二区视频观看视频| 麻豆精品一区二区| 精品乱码亚洲一区二区不卡| 精品写真视频在线观看| 久久久91精品国产一区二区精品 | 色婷婷精品久久二区二区蜜臂av| 亚洲另类色综合网站| 精品视频在线免费观看| 午夜精品福利视频网站| 日韩欧美国产综合一区| 国内精品久久久久影院薰衣草| 国产色综合一区| 波多野结衣视频一区| 亚洲一区av在线| 欧美一区二区三区色| 国产一区二区三区四区在线观看| 国产欧美精品日韩区二区麻豆天美| 91影院在线免费观看| 亚洲国产aⅴ天堂久久| 日韩欧美在线综合网| 国产一区91精品张津瑜| 国产精品国产三级国产aⅴ中文| 在线亚洲+欧美+日本专区| 免费人成在线不卡| 国产亚洲成年网址在线观看| 一本久久a久久精品亚洲| 天天亚洲美女在线视频| 久久精品在线免费观看| 色天天综合色天天久久| 毛片基地黄久久久久久天堂| 国产日韩欧美亚洲| 欧美亚洲综合色| 首页国产丝袜综合| 国产欧美一区二区精品忘忧草| 91美女精品福利| 蜜臀91精品一区二区三区| 国产精品久久久久婷婷| 91精品久久久久久蜜臀| 丁香五精品蜜臀久久久久99网站| 亚洲一区二区黄色| 国产亚洲美州欧州综合国| 欧洲国产伦久久久久久久| 国产专区欧美精品| 悠悠色在线精品| 久久女同互慰一区二区三区| 色一情一伦一子一伦一区| 黄色日韩三级电影| 亚洲国产精品久久不卡毛片 | 国产剧情av麻豆香蕉精品| 亚洲欧美福利一区二区| 欧美成人福利视频| 在线看不卡av| 国产999精品久久久久久绿帽| 午夜视频在线观看一区二区| 国产精品每日更新在线播放网址| 这里只有精品电影| 色婷婷一区二区| 粉嫩在线一区二区三区视频| 日韩av一级片| 亚洲一区在线观看免费 | 日韩av一区二区在线影视| 136国产福利精品导航| 337p粉嫩大胆色噜噜噜噜亚洲| 欧美中文字幕久久| 成人性生交大片免费看中文 | 精品美女一区二区三区| 色婷婷综合激情| 成人性色生活片| 精品综合免费视频观看| 亚洲国产精品麻豆| 成人免费在线播放视频| 国产三级三级三级精品8ⅰ区| 91精品国产综合久久久久久久久久 | 国产精品乱码久久久久久| 日韩午夜在线影院| 欧美日韩亚洲综合在线| 一本色道久久加勒比精品| 国产精品18久久久久久久久久久久| 日本不卡高清视频| 亚洲国产成人tv| 亚洲制服丝袜在线| 一区二区视频在线看| 国产精品人人做人人爽人人添| 26uuu色噜噜精品一区二区| 91麻豆精品国产91久久久更新时间| 色哟哟一区二区| 91社区在线播放| 91色在线porny| 91麻豆自制传媒国产之光| caoporn国产一区二区| 成人福利视频在线|