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

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

?? xtr.h

?? Cryptolib4.1.rar
?? H
字號:
#ifndef CRYPTOPP_XTR_H
#define CRYPTOPP_XTR_H

/** \file
	"The XTR public key system" by Arjen K. Lenstra and Eric R. Verheul
*/

#include "modarith.h"

NAMESPACE_BEGIN(CryptoPP)

//! an element of GF(p^2)
class GFP2Element
{
public:
	GFP2Element() {}
	GFP2Element(const Integer &c1, const Integer &c2) : c1(c1), c2(c2) {}
	GFP2Element(const byte *encodedElement, unsigned int size)
		: c1(encodedElement, size/2), c2(encodedElement+size/2, size/2) {}

	void Encode(byte *encodedElement, unsigned int size)
	{
		c1.Encode(encodedElement, size/2);
		c2.Encode(encodedElement+size/2, size/2);
	}

	bool operator==(const GFP2Element &rhs)	{return c1 == rhs.c1 && c2 == rhs.c2;}
	bool operator!=(const GFP2Element &rhs) {return !operator==(rhs);}

	void swap(GFP2Element &a)
	{
		c1.swap(a.c1);
		c2.swap(a.c2);
	}

	static GFP2Element & Zero();

	Integer c1, c2;
};

//! GF(p^2), optimal normal basis
template <class F>
class GFP2_ONB : public AbstractRing<GFP2Element>
{
public:
	typedef F BaseField;

	GFP2_ONB(const Integer &p) : modp(p) {assert(p%3 == 2);}

	const Integer& GetModulus() const {return modp.GetModulus();}

	GFP2Element ConvertIn(const Integer &a) const
	{
		t = modp.Inverse(modp.ConvertIn(a));
		return GFP2Element(t, t);
	}

	GFP2Element ConvertIn(const GFP2Element &a) const
		{return GFP2Element(modp.ConvertIn(a.c1), modp.ConvertIn(a.c2));}

	GFP2Element ConvertOut(const GFP2Element &a) const
		{return GFP2Element(modp.ConvertOut(a.c1), modp.ConvertOut(a.c2));}

	bool Equal(const GFP2Element &a, const GFP2Element &b) const
	{
		return modp.Equal(a.c1, b.c1) && modp.Equal(a.c2, b.c2);
	}

	const Element& Zero() const
	{
		return GFP2Element::Zero();
	}

	const Element& Add(const Element &a, const Element &b) const
	{
		result.c1 = modp.Add(a.c1, b.c1);
		result.c2 = modp.Add(a.c2, b.c2);
		return result;
	}

	const Element& Inverse(const Element &a) const
	{
		result.c1 = modp.Inverse(a.c1);
		result.c2 = modp.Inverse(a.c2);
		return result;
	}

	const Element& Double(const Element &a) const
	{
		result.c1 = modp.Double(a.c1);
		result.c2 = modp.Double(a.c2);
		return result;
	}

	const Element& Subtract(const Element &a, const Element &b) const
	{
		result.c1 = modp.Subtract(a.c1, b.c1);
		result.c2 = modp.Subtract(a.c2, b.c2);
		return result;
	}

	Element& Accumulate(Element &a, const Element &b) const
	{
		modp.Accumulate(a.c1, b.c1);
		modp.Accumulate(a.c2, b.c2);
		return a;
	}

	Element& Reduce(Element &a, const Element &b) const
	{
		modp.Reduce(a.c1, b.c1);
		modp.Reduce(a.c2, b.c2);
		return a;
	}

	bool IsUnit(const Element &a) const
	{
		return a.c1.NotZero() || a.c2.NotZero();
	}

	const Element& One() const
	{
		result.c1 = result.c2 = modp.Inverse(modp.One());
		return result;
	}

	const Element& Multiply(const Element &a, const Element &b) const
	{
		t = modp.Add(a.c1, a.c2);
		t = modp.Multiply(t, modp.Add(b.c1, b.c2));
		result.c1 = modp.Multiply(a.c1, b.c1);
		result.c2 = modp.Multiply(a.c2, b.c2);
		result.c1.swap(result.c2);
		modp.Reduce(t, result.c1);
		modp.Reduce(t, result.c2);
		modp.Reduce(result.c1, t);
		modp.Reduce(result.c2, t);
		return result;
	}

	const Element& MultiplicativeInverse(const Element &a) const
	{
		return result = Exponentiate(a, modp.GetModulus()-2);
	}

	const Element& Square(const Element &a) const
	{
		const Integer &ac1 = (&a == &result) ? (t = a.c1) : a.c1;
		result.c1 = modp.Multiply(modp.Subtract(modp.Subtract(a.c2, a.c1), a.c1), a.c2);
		result.c2 = modp.Multiply(modp.Subtract(modp.Subtract(ac1, a.c2), a.c2), ac1);
		return result;
	}

	Element Exponentiate(const Element &a, const Integer &e) const
	{
		Integer edivp, emodp;
		Integer::Divide(emodp, edivp, e, modp.GetModulus());
		Element b = PthPower(a);
		return AbstractRing<GFP2Element>::CascadeExponentiate(a, emodp, b, edivp);
	}

	const Element & PthPower(const Element &a) const
	{
		result = a;
		result.c1.swap(result.c2);
		return result;
	}

	void RaiseToPthPower(Element &a) const
	{
		a.c1.swap(a.c2);
	}

	// a^2 - 2a^p
	const Element & SpecialOperation1(const Element &a) const
	{
		assert(&a != &result);
		result = Square(a);
		modp.Reduce(result.c1, a.c2);
		modp.Reduce(result.c1, a.c2);
		modp.Reduce(result.c2, a.c1);
		modp.Reduce(result.c2, a.c1);
		return result;
	}

	// x * z - y * z^p
	const Element & SpecialOperation2(const Element &x, const Element &y, const Element &z) const
	{
		assert(&x != &result && &y != &result && &z != &result);
		t = modp.Add(x.c2, y.c2);
		result.c1 = modp.Multiply(z.c1, modp.Subtract(y.c1, t));
		modp.Accumulate(result.c1, modp.Multiply(z.c2, modp.Subtract(t, x.c1)));
		t = modp.Add(x.c1, y.c1);
		result.c2 = modp.Multiply(z.c2, modp.Subtract(y.c2, t));
		modp.Accumulate(result.c2, modp.Multiply(z.c1, modp.Subtract(t, x.c2)));
		return result;
	}

protected:
	BaseField modp;
	mutable GFP2Element result;
	mutable Integer t;
};

void XTR_FindPrimesAndGenerator(RandomNumberGenerator &rng, Integer &p, Integer &q, GFP2Element &g, unsigned int pbits, unsigned int qbits);

GFP2Element XTR_Exponentiate(const GFP2Element &b, const Integer &e, const Integer &p);

NAMESPACE_END

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆精品久久久| 99视频一区二区三区| 久久综合久久鬼色中文字| 极品少妇xxxx偷拍精品少妇| 26uuu精品一区二区三区四区在线| 国产精品一区二区黑丝| 国产亚洲精品福利| av一二三不卡影片| 成人一区二区三区中文字幕| 中文字幕在线观看不卡| 欧洲国内综合视频| 日韩成人精品在线观看| 337p粉嫩大胆噜噜噜噜噜91av| 国产成人在线影院| 亚洲欧洲制服丝袜| 欧美日韩精品一区二区三区四区 | 亚洲一区二区欧美| 欧美男人的天堂一二区| 精品综合久久久久久8888| 国产女人18毛片水真多成人如厕 | 国产精品久久久久aaaa| 色综合亚洲欧洲| 爽好多水快深点欧美视频| 欧美xxxxxxxxx| 成人18精品视频| 亚洲成av人在线观看| 欧美电影免费观看高清完整版| 国产精品456| 一区二区三区91| 日韩一级片在线播放| 成人性视频网站| 午夜精品123| 久久人人97超碰com| 一本色道久久加勒比精品| 日本欧美一区二区三区乱码 | 国产精品毛片a∨一区二区三区| 日本精品一级二级| 另类调教123区| 亚洲日本va午夜在线电影| 国产精品久久久久精k8| 欧美丰满嫩嫩电影| 丁香激情综合五月| 午夜久久久久久| 国产日韩一级二级三级| 欧美日韩三级视频| 国产电影精品久久禁18| 亚洲午夜一区二区| 中文字幕国产精品一区二区| 欧美三片在线视频观看 | 视频精品一区二区| 国产精品嫩草99a| 91精品久久久久久久久99蜜臂| 成人一级片网址| 青青草国产成人av片免费| 国产精品久久久久精k8| 精品日韩在线一区| 91久久奴性调教| 国产高清不卡二三区| 午夜国产精品一区| 亚洲欧美怡红院| www国产亚洲精品久久麻豆| 欧美日韩另类一区| av在线播放成人| 国产在线精品视频| 香蕉av福利精品导航| 国产精品理论片在线观看| 日韩精品一区国产麻豆| 欧美亚洲另类激情小说| 成人一区二区三区在线观看| 麻豆精品一区二区三区| 亚洲一区在线电影| 国产精品久久久久7777按摩| 亚洲精品一线二线三线| 欧美日本精品一区二区三区| 94色蜜桃网一区二区三区| 国产一区二区看久久| 奇米一区二区三区| 亚洲线精品一区二区三区八戒| 中文字幕在线观看一区| 久久九九全国免费| 精品裸体舞一区二区三区| 欧美日韩你懂得| 色婷婷av一区二区三区之一色屋| 国产成人免费在线| 国内精品伊人久久久久av一坑| 亚洲va欧美va人人爽| 艳妇臀荡乳欲伦亚洲一区| 国产精品美女久久久久久2018| 欧美精品一区二区高清在线观看 | 久久国产剧场电影| 日韩有码一区二区三区| 亚洲国产视频a| 玉米视频成人免费看| 亚洲欧洲一区二区三区| 国产精品污www在线观看| 久久中文字幕电影| 精品国产一区二区三区久久影院 | 亚洲欧洲99久久| 欧美国产禁国产网站cc| 久久免费电影网| 久久精品一区四区| 久久亚洲精精品中文字幕早川悠里| 欧美一卡2卡3卡4卡| 4438x成人网最大色成网站| 欧美日韩一区二区三区四区| 在线免费不卡视频| 在线观看视频一区二区欧美日韩| 色噜噜狠狠成人网p站| 91麻豆swag| 在线视频中文字幕一区二区| 91国内精品野花午夜精品| 日本高清不卡一区| 欧美色窝79yyyycom| 欧美性猛交一区二区三区精品| 在线观看国产精品网站| 欧美自拍丝袜亚洲| 欧美日韩夫妻久久| 337p亚洲精品色噜噜噜| 欧美一级在线免费| 精品美女在线观看| 久久精品亚洲乱码伦伦中文 | 亚洲综合一区二区精品导航| 亚洲一二三四在线| 亚欧色一区w666天堂| 日韩av二区在线播放| 免费观看日韩电影| 国产在线不卡一区| 国产成人综合自拍| jizz一区二区| 色天使久久综合网天天| 精品视频一区二区不卡| 欧美一区二区三区日韩| 免费在线观看日韩欧美| 老司机午夜精品| 国产高清一区日本| 99久久99久久精品免费观看 | 99视频在线观看一区三区| 91麻豆自制传媒国产之光| 在线观看亚洲成人| 欧美一区二区三区电影| 久久综合久色欧美综合狠狠| 国产精品麻豆久久久| 一区二区三区免费观看| 日韩精品每日更新| 国产久卡久卡久卡久卡视频精品| 成人性生交大片免费看在线播放 | 欧美在线你懂得| 欧美一区二区三区在线| 久久蜜桃av一区二区天堂| 国产精品久久久久久久久快鸭| 一区二区三区欧美日| 人人超碰91尤物精品国产| 国产精品18久久久久久久网站| www.欧美日韩| 欧美日韩国产高清一区二区三区| 欧美电影免费观看高清完整版在| 国产精品视频一区二区三区不卡| 亚洲黄网站在线观看| 美国毛片一区二区| 成人app软件下载大全免费| 欧美丝袜丝交足nylons图片| 欧美不卡一区二区三区| 亚洲天堂网中文字| 蜜臀久久久久久久| www.久久精品| 91精品久久久久久久91蜜桃| 国产精品少妇自拍| 午夜精品视频在线观看| 国产激情一区二区三区桃花岛亚洲| 色综合一区二区三区| 日韩精品中文字幕一区| 亚洲视频一区在线观看| 美国毛片一区二区三区| 91色九色蝌蚪| 欧美成人bangbros| 亚洲激情欧美激情| 国产精品自拍一区| 欧美性xxxxx极品少妇| 久久久久青草大香线综合精品| 一区二区三区不卡视频| 国产精品一区在线观看乱码| 欧美日韩视频第一区| 中文久久乱码一区二区| 丝袜美腿成人在线| 99在线精品一区二区三区| 日韩精品中文字幕一区| 一区二区三区免费网站| 国产99精品国产| 91麻豆精品91久久久久久清纯| 国产精品青草综合久久久久99| 日韩二区三区在线观看| 97se亚洲国产综合在线| 久久久久久免费网| 视频一区在线视频| 91天堂素人约啪| 久久女同性恋中文字幕| 日本成人超碰在线观看| 欧美韩国一区二区| 精品一区二区三区免费视频| 欧美四级电影在线观看|