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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ec2n.cpp

?? 加密解密算法
?? CPP
字號:
// ec2n.cpp - written and placed in the public domain by Wei Dai

#include "pch.h"
#include "ec2n.h"
#include "asn.h"
#include "nbtheory.h"	// for primeTable

#include "algebra.cpp"
#include "eprecomp.cpp"

NAMESPACE_BEGIN(CryptoPP)

EC2N::Point EC2N::DecodePoint(const byte *encodedPoint) const
{
	if (encodedPoint[0] != 4)	// TODO: handle compressed points
		return Point();
	else
	{
		unsigned int len = field.MaxElementByteLength();
		return Point(FieldElement(encodedPoint+1, len), FieldElement(encodedPoint+1+len, len));
	}
}

void EC2N::EncodePoint(byte *encodedPoint, const Point &P) const
{
	if (P.identity)
		memset(encodedPoint, 0, EncodedPointSize());
	else
	{
		encodedPoint[0] = 4;	// uncompressed
		unsigned int len = field.MaxElementByteLength();
		P.x.Encode(encodedPoint+1, len);
		P.y.Encode(encodedPoint+1+len, len);
	}
}

bool EC2N::ValidateParameters(RandomNumberGenerator &rng) const
{
	return field.GetModulus().IsIrreducible()
		&& a.CoefficientCount() <= field.MaxElementBitLength()
		&& b.CoefficientCount() <= field.MaxElementBitLength() && !!b;
}

bool EC2N::VerifyPoint(const Point &P) const
{
	const FieldElement &x = P.x, &y = P.y;
	return P.identity || 
		(x.CoefficientCount() <= field.MaxElementBitLength()
		&& y.CoefficientCount() <= field.MaxElementBitLength()
		&& !(((x+a)*x*x+b-(x+y)*y)%field.GetModulus()));
}

bool EC2N::Equal(const Point &P, const Point &Q) const
{
	if (P.identity && Q.identity)
		return true;

	if (P.identity && !Q.identity)
		return false;

	if (!P.identity && Q.identity)
		return false;

	return (field.Equal(P.x,Q.x) && field.Equal(P.y,Q.y));
}

EC2N::Point EC2N::Inverse(const Point &P) const
{
	if (P.identity)
		return P;
	else
		return Point(P.x, field.Add(P.x, P.y));
}

EC2N::Point EC2N::Add(const Point &P, const Point &Q) const
{
	if (P.identity) return Q;
	if (Q.identity) return P;
	if (Equal(P, Q)) return Double(P);
	if (field.Equal(P.x, Q.x) && field.Equal(P.y, field.Add(Q.x, Q.y))) return Zero();

	Field::Element t = field.Divide(field.Add(P.y, Q.y), field.Add(P.x, Q.x));
	Point R(field.Square(t), P.y);
	field.Accumulate(R.x, t);
	field.Accumulate(R.x, Q.x);
	field.Accumulate(R.x, a);
	field.Accumulate(R.y, field.Multiply(t, R.x));
	field.Accumulate(R.x, P.x);
	field.Accumulate(R.y, R.x);
	return R;
}

EC2N::Point EC2N::Double(const Point &P) const
{
	if (P.identity) return P;
	if (!field.IsUnit(P.x)) return Zero();

	FieldElement t = field.Divide(P.y, P.x);
	field.Accumulate(t, P.x);
	Point R(field.Square(t), field.Square(P.x));
	field.Accumulate(R.x, t);
	field.Accumulate(R.x, a);
	field.Accumulate(R.y, field.Multiply(t, R.x));
	field.Accumulate(R.y, R.x);
	return R;
}

// ********************************************************

EcPrecomputation<EC2N>::EcPrecomputation()
{
}

EcPrecomputation<EC2N>::EcPrecomputation(const EcPrecomputation<EC2N> &ecp)
	: ec(new EC2N(*ecp.ec))
	, ep(new ExponentiationPrecomputation<EC2N>(*ec, *ecp.ep))
{
}

EcPrecomputation<EC2N>::EcPrecomputation(const EC2N &ecIn, const EC2N::Point &base, unsigned int maxExpBits, unsigned int storage)
	: ec(new EC2N(ecIn)), ep(NULL)
{
	Precompute(base, maxExpBits, storage);
}

EcPrecomputation<EC2N>::~EcPrecomputation()
{
}

void EcPrecomputation<EC2N>::Precompute(const EC2N::Point &base, unsigned int maxExpBits, unsigned int storage)
{
	if (!ep.get() || ep->storage < storage)
		ep.reset(new ExponentiationPrecomputation<EC2N>(*ec, base, maxExpBits, storage));
}

void EcPrecomputation<EC2N>::Load(BufferedTransformation &bt)
{
	ep.reset(new ExponentiationPrecomputation<EC2N>(*ec));
	BERSequenceDecoder seq(bt);
	ep->storage = (unsigned int)(Integer(seq).ConvertToLong());
	ep->exponentBase.BERDecode(seq);
	ep->g.resize(ep->storage);

	unsigned int size = ec->GetField().MaxElementByteLength();
	SecByteBlock buffer(size);
	for (unsigned i=0; i<ep->storage; i++)
	{
		ep->g[i].identity = false;
		seq.Get(buffer, size);
		ep->g[i].x.Decode(buffer, size);
		seq.Get(buffer, size);
		ep->g[i].y.Decode(buffer, size);
	}
}

void EcPrecomputation<EC2N>::Save(BufferedTransformation &bt) const
{
	assert(ep.get());
	DERSequenceEncoder seq(bt);
	Integer(ep->storage).DEREncode(seq);
	ep->exponentBase.DEREncode(seq);

	unsigned int size = ec->GetField().MaxElementByteLength();
	SecByteBlock buffer(size);
	for (unsigned i=0; i<ep->storage; i++)
	{
		ep->g[i].x.Encode(buffer, size);
		seq.Put(buffer, size);
		ep->g[i].y.Encode(buffer, size);
		seq.Put(buffer, size);
	}
}

EC2N::Point EcPrecomputation<EC2N>::Multiply(const Integer &exponent) const
{
	assert(ep.get());
	return ep->Exponentiate(exponent);
}

EC2N::Point EcPrecomputation<EC2N>::CascadeMultiply(const Integer &exponent, const EcPrecomputation<EC2N> &pc2, const Integer &exponent2) const
{
	assert(ep.get());
	return ep->CascadeExponentiate(exponent, *pc2.ep, exponent2);
}

NAMESPACE_END

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www国产成人| 日本亚洲三级在线| www.在线成人| 亚洲欧洲成人自拍| 成人国产精品视频| 亚洲欧洲成人自拍| 色综合 综合色| 亚洲午夜精品网| 91精品国产手机| 国产精品99精品久久免费| 国产精品网站在线播放| 色综合色狠狠综合色| 国产精品高清亚洲| 91啪亚洲精品| 亚洲一区二区三区四区五区黄| 555www色欧美视频| 国产一区 二区 三区一级| 国产精品久久久久久久久动漫| 欧美中文一区二区三区| 日韩国产欧美在线观看| 精品sm捆绑视频| 99久久国产综合精品色伊| 日韩不卡一区二区| 欧美精品一区二区三| 91天堂素人约啪| 亚洲高清免费一级二级三级| 欧美tk—视频vk| 99精品国产视频| 日韩成人免费看| 中文字幕 久热精品 视频在线| 成人黄色综合网站| 亚洲一区成人在线| 51精品国自产在线| 蜜臀99久久精品久久久久久软件| 精品国精品自拍自在线| 国产成人精品在线看| 亚洲色图清纯唯美| 欧美美女bb生活片| 成人性视频免费网站| 亚洲在线观看免费视频| 精品伦理精品一区| 93久久精品日日躁夜夜躁欧美| 久久色.com| 亚洲影院免费观看| 欧美精品一级二级三级| 精品毛片乱码1区2区3区| 精品久久99ma| 美女网站色91| 午夜久久久久久电影| 激情伊人五月天久久综合| 欧美日韩在线亚洲一区蜜芽| 欧美日韩免费一区二区三区 | 五月综合激情婷婷六月色窝| 精品国产区一区| 色噜噜狠狠一区二区三区果冻| 国产成人夜色高潮福利影视| 日本不卡不码高清免费观看| 亚洲精选一二三| 国产精品久久毛片| 久久夜色精品一区| 日韩三级免费观看| 51精品视频一区二区三区| 欧洲精品一区二区| 99久久er热在这里只有精品15| 国产一区二区三区黄视频| 日日夜夜免费精品| 亚洲综合免费观看高清完整版| 日韩美女精品在线| 中文字幕欧美一| 国产精品麻豆欧美日韩ww| 日本一区二区三区四区| 亚洲精品一区二区三区香蕉| 91精品国产福利| 日韩一区二区在线免费观看| 91精品国产黑色紧身裤美女| 欧美制服丝袜第一页| 久久精品人人做人人综合| 精品精品国产高清a毛片牛牛| 制服丝袜成人动漫| 91精品国产综合久久精品性色| 欧美日韩国产色站一区二区三区| 欧美三级中文字幕在线观看| 欧美日韩一区二区三区视频| 欧美无砖砖区免费| 337p亚洲精品色噜噜| 9191久久久久久久久久久| 911国产精品| 成人ar影院免费观看视频| 亚洲一区国产视频| 日韩综合小视频| 一区二区三区在线免费视频| 日韩视频在线你懂得| 国产成人免费视频一区| 亚洲激情网站免费观看| www激情久久| 日韩一卡二卡三卡国产欧美| 91精品蜜臀在线一区尤物| 欧洲激情一区二区| 欧美精品少妇一区二区三区| 免费观看久久久4p| 亚洲欧美另类小说| 日韩免费高清av| 欧美一区国产二区| 精品久久久久av影院 | av电影在线观看一区| 91精品国产色综合久久ai换脸| 亚洲第一成年网| 国产精品区一区二区三| 欧美一区二区三区免费大片 | 色综合天天综合色综合av| 亚洲精品日韩专区silk| 国产三级精品三级| 日韩欧美国产1| 欧美日韩亚洲丝袜制服| 国产精品一区二区免费不卡| 国产美女在线精品| 麻豆精品精品国产自在97香蕉| 美女被吸乳得到大胸91| 蜜臀av性久久久久蜜臀av麻豆| 国精产品一区一区三区mba视频 | 日韩三区在线观看| 久久亚洲精精品中文字幕早川悠里 | 国模大尺度一区二区三区| 555夜色666亚洲国产免| 色菇凉天天综合网| 日本不卡在线视频| 欧美激情在线看| 国产一区免费电影| 日韩欧美精品在线视频| 欧美在线|欧美| 91首页免费视频| 日韩一区二区免费高清| 亚洲欧洲精品一区二区精品久久久 | 91亚洲精品一区二区乱码| 欧美精品色综合| 国产日韩欧美高清| 三级一区在线视频先锋 | 色一情一伦一子一伦一区| 欧美大片免费久久精品三p| 黄色日韩网站视频| 亚洲欧美一区二区三区极速播放| 国产一区二区美女诱惑| 捆绑紧缚一区二区三区视频| 成人妖精视频yjsp地址| 亚洲精品一线二线三线无人区| a在线欧美一区| 日韩理论片网站| 91同城在线观看| 无吗不卡中文字幕| 51精品秘密在线观看| 国产精品毛片高清在线完整版| 国产成人精品免费一区二区| 国产精品全国免费观看高清| 色悠悠亚洲一区二区| 精品中文av资源站在线观看| 在线播放中文一区| 国产一区二区三区在线观看免费视频 | 欧美日韩一区二区三区在线看| 久久久综合精品| 日韩精品视频网| 欧美天堂一区二区三区| 亚洲欧洲性图库| 国产专区综合网| 91精品国产手机| 婷婷久久综合九色综合绿巨人| 欧美tickle裸体挠脚心vk| 97精品久久久午夜一区二区三区| 国产精品福利一区| 91精品国产一区二区| 久久精品国产99国产| 亚洲欧美成aⅴ人在线观看 | 亚洲mv在线观看| 日韩视频免费观看高清完整版 | 亚洲精选视频免费看| 亚洲午夜在线观看视频在线| 色婷婷综合久久久中文一区二区| 一区二区三区国产| 国产精品麻豆视频| 日韩一区二区免费在线观看| 国产精品美女久久久久久久久| 亚洲人成网站影音先锋播放| 国产精品888| 久久人人97超碰com| 国产一二三精品| 久久精品欧美日韩精品| 国产综合一区二区| 精品成人a区在线观看| 精品中文字幕一区二区| 久久精品视频一区二区| 国产美女主播视频一区| 中文字幕一区二区三区不卡 | 亚洲国产sm捆绑调教视频| 99国产精品99久久久久久| 亚洲特黄一级片| 欧美日韩亚洲另类| 老司机精品视频一区二区三区| 欧美精品 日韩| 亚洲第一久久影院| 91精品国产全国免费观看| 综合精品久久久|