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

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

?? ecp.cpp

?? 加密源碼合集
?? CPP
字號:
// ecp.cpp - written and placed in the public domain by Wei Dai

#include "pch.h"
#include "ecp.h"
#include "asn.h"
#include "nbtheory.h"

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

NAMESPACE_BEGIN(CryptoPP)

ANONYMOUS_NAMESPACE_BEGIN
static inline ECP::Point ToMontgomery(const MontgomeryRepresentation &mr, const ECP::Point &P)
{
	return P.identity ? P : ECP::Point(mr.ConvertIn(P.x), mr.ConvertIn(P.y));
}

static inline ECP::Point FromMontgomery(const MontgomeryRepresentation &mr, const ECP::Point &P)
{
	return P.identity ? P : ECP::Point(mr.ConvertOut(P.x), mr.ConvertOut(P.y));
}
NAMESPACE_END

ECP::Point ECP::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 ECP::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 ECP::ValidateParameters(RandomNumberGenerator &rng) const
{
	Integer p = FieldSize();
	return p.IsOdd() && VerifyPrime(rng, p)
		&& !a.IsNegative() && a<p && !b.IsNegative() && b<p
		&& ((4*a*a*a+27*b*b)%p).IsPositive();
}

bool ECP::VerifyPoint(const Point &P) const
{
	const FieldElement &x = P.x, &y = P.y;
	Integer p = FieldSize();
	return P.identity ||
		(!x.IsNegative() && x<p && !x.IsNegative() && x<p
		&& !(((x*x+a)*x+b-y*y)%p));
}

bool ECP::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));
}

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

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

	Point R(Q.x, Q.y);
	field.Reduce(R.x, P.x);
	field.Reduce(R.y, P.y);
	FieldElement t = field.Divide(R.y, R.x);
	R.x = field.Square(t);
	field.Reduce(R.x, P.x);
	field.Reduce(R.x, Q.x);
	R.y = field.Subtract(P.x, R.x);
	R.y = field.Multiply(t, R.y);
	field.Reduce(R.y, P.y);
	return R;
}

ECP::Point ECP::Double(const Point &P) const
{
	if (P.identity || P.y==field.Zero()) return Zero();

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

ECP::Point ECP::Multiply(const Integer &k, const Point &P) const
{
//	return GeneralizedMultiplication(*this, P, k);
	MontgomeryRepresentation mr(field.GetModulus());
	ECP ecpmr(mr, mr.ConvertIn(a), mr.ConvertIn(b));
	return FromMontgomery(mr, ecpmr.IntMultiply(ToMontgomery(mr, P), k));
}

ECP::Point ECP::CascadeMultiply(const Integer &k1, const Point &P, const Integer &k2, const Point &Q) const
{
//	return CascadeMultiplication(*this, P, k1, Q, k2);
	MontgomeryRepresentation mr(field.GetModulus());
	ECP ecpmr(mr, mr.ConvertIn(a), mr.ConvertIn(b));
	return FromMontgomery(mr, ecpmr.CascadeIntMultiply(ToMontgomery(mr, P), k1, ToMontgomery(mr, Q), k2));
}

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

EcPrecomputation<ECP>::EcPrecomputation()
{
}

EcPrecomputation<ECP>::EcPrecomputation(const EcPrecomputation<ECP> &ecp)
	: mr(new MontgomeryRepresentation(*ecp.mr))
	, ec(new ECP(*mr, ecp.ec->GetA(), ecp.ec->GetB()))
	, ep(new ExponentiationPrecomputation<ECP>(*ec, *ecp.ep))
{
}

EcPrecomputation<ECP>::EcPrecomputation(const ECP &ecIn, const ECP::Point &base, unsigned int maxExpBits, unsigned int storage)
	: mr(new MontgomeryRepresentation(ecIn.GetField().GetModulus()))
	, ec(new ECP(*mr, mr->ConvertIn(ecIn.GetA()), mr->ConvertIn(ecIn.GetB())))
	, ep(NULL)
{
	Precompute(base, maxExpBits, storage);
}

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

void EcPrecomputation<ECP>::Precompute(const ECP::Point &base, unsigned int maxExpBits, unsigned int storage)
{
	ep.reset(new ExponentiationPrecomputation<ECP>(*ec, ToMontgomery(*mr, base), maxExpBits, storage));
}

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

	for (unsigned i=0; i<ep->storage; i++)
	{
		ep->g[i].identity = false;
		ep->g[i].x.BERDecode(seq);
		ep->g[i].y.BERDecode(seq);
	}
}

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

	for (unsigned i=0; i<ep->storage; i++)
	{
		ep->g[i].x.DEREncode(seq);
		ep->g[i].y.DEREncode(seq);
	}
}

ECP::Point EcPrecomputation<ECP>::Multiply(const Integer &exponent) const
{
	assert(ep.get());
	return FromMontgomery(*mr, ep->Exponentiate(exponent));
}

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

NAMESPACE_END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
秋霞成人午夜伦在线观看| 日韩精品一卡二卡三卡四卡无卡| 成人h动漫精品一区二| 91色乱码一区二区三区| 色综合久久中文综合久久牛| 欧美军同video69gay| 精品国产区一区| 亚洲欧美在线aaa| 一区二区三区日韩精品视频| 日本成人中文字幕| 亚洲一区二区三区自拍| 国内精品自线一区二区三区视频| 欧美日韩在线三级| 中文字幕一区二区视频| 国产美女视频91| 日韩一级免费观看| 图片区小说区区亚洲影院| 91蝌蚪porny成人天涯| 国产女同性恋一区二区| 精品一区二区三区欧美| 91麻豆精品国产自产在线| 一区二区三区在线播放| 9色porny自拍视频一区二区| 国产亚洲制服色| 欧美成人一区二区三区片免费| 亚洲综合图片区| 91麻豆福利精品推荐| 国产精品久久久久影院色老大| 国产精品69久久久久水密桃| 欧美大度的电影原声| 日韩电影免费在线看| 欧美三级视频在线| 亚洲小说春色综合另类电影| 一本到三区不卡视频| 国产精品久久夜| 成人福利在线看| 国产精品久久久爽爽爽麻豆色哟哟| 国产成人综合亚洲网站| 久久久久久免费| 国产一区二区三区香蕉| 亚洲精品在线三区| 国精产品一区一区三区mba桃花| 欧美成人精品二区三区99精品| 日韩va欧美va亚洲va久久| 7777精品伊人久久久大香线蕉完整版 | 国产成人免费在线观看| 精品国产91亚洲一区二区三区婷婷| 免费看黄色91| 日韩片之四级片| 久久99精品久久久久久国产越南 | 欧美亚洲尤物久久| 亚洲一二三区在线观看| 欧美日韩久久久| 日韩精品91亚洲二区在线观看 | 成人综合在线观看| 国产精品乱人伦| 91蜜桃在线免费视频| 一区二区三区免费在线观看| 欧美中文字幕亚洲一区二区va在线| 亚洲蜜臀av乱码久久精品| 在线欧美日韩国产| 日韩精品视频网| 精品乱码亚洲一区二区不卡| 国产另类ts人妖一区二区| 日本一区二区三区四区在线视频 | 视频一区欧美日韩| 日韩久久久久久| 精品免费视频.| 国产麻豆成人传媒免费观看| 国产精品伦理在线| 在线观看91精品国产入口| 首页亚洲欧美制服丝腿| 精品少妇一区二区三区视频免付费| 国产精品资源在线看| 中文字幕亚洲一区二区av在线 | 99久久综合色| 亚洲成国产人片在线观看| 日韩欧美国产麻豆| 国产超碰在线一区| 亚洲激情成人在线| 日韩一级片网站| 成人黄色电影在线 | 中文天堂在线一区| 91九色最新地址| 喷水一区二区三区| 国产精品全国免费观看高清| 欧美亚洲高清一区二区三区不卡| 蜜桃传媒麻豆第一区在线观看| 国产人成一区二区三区影院| 日本韩国一区二区| 精品一区二区三区香蕉蜜桃| 国产精品福利电影一区二区三区四区| 在线观看国产精品网站| 久久99久久99| 日韩一区有码在线| 日韩一级欧美一级| 91在线免费视频观看| 青青草精品视频| 国产精品久久久久久久久图文区 | 欧美一区二区视频网站| 成人蜜臀av电影| 日本韩国一区二区三区| 极品销魂美女一区二区三区| 亚洲黄色免费网站| 2022国产精品视频| 欧洲精品中文字幕| 国产成人免费在线观看| 日韩黄色片在线观看| 国产精品国产三级国产| 日韩精品最新网址| 色婷婷一区二区三区四区| 国产一区二区三区在线观看免费视频| 一区二区三区欧美在线观看| 2020国产成人综合网| 欧美在线一区二区三区| 高清不卡一区二区| 麻豆精品新av中文字幕| 亚洲欧美电影一区二区| 久久久久97国产精华液好用吗| 欧美怡红院视频| 成人一区二区三区视频在线观看| 青青草国产成人av片免费| 亚洲人123区| 欧美极品美女视频| 欧美成人精品3d动漫h| 欧美日韩一级片在线观看| 99久久99久久久精品齐齐| 久久99九九99精品| 五月天亚洲婷婷| 一区二区三区波多野结衣在线观看| 国产精品系列在线| 久久久99精品免费观看不卡| 欧美一区二区播放| 欧美亚男人的天堂| 一本色道久久综合亚洲91| 国产69精品久久久久毛片 | 亚洲视频在线观看三级| 久久久久国产精品人| 制服视频三区第一页精品| 欧美曰成人黄网| 91一区二区三区在线播放| 粉嫩欧美一区二区三区高清影视| 日韩欧美一级在线播放| 欧美日韩综合在线| 日本精品免费观看高清观看| 99久久综合国产精品| 成人黄色a**站在线观看| 国产高清亚洲一区| 久久99久久精品| 精品制服美女丁香| 麻豆国产一区二区| 蜜芽一区二区三区| 蜜臀av一区二区| 美女久久久精品| 久久se这里有精品| 久久国产生活片100| 久久99热这里只有精品| 久久av资源网| 国模无码大尺度一区二区三区| 精久久久久久久久久久| 精品一区二区三区在线播放 | 亚洲色图清纯唯美| 亚洲欧美日韩系列| 亚洲综合一二区| 性感美女极品91精品| 视频在线观看国产精品| 日韩精品亚洲专区| 久久91精品国产91久久小草| 激情久久久久久久久久久久久久久久| 蜜桃久久精品一区二区| 精品一区二区三区日韩| 国产精品白丝av| 成人午夜私人影院| 91麻豆高清视频| 欧美视频三区在线播放| 777亚洲妇女| 精品福利一区二区三区 | 欧美专区日韩专区| 欧美日韩国产高清一区二区三区 | 亚洲女人****多毛耸耸8| 一区二区三区鲁丝不卡| 亚洲高清视频的网址| 蜜臀av亚洲一区中文字幕| 精品制服美女丁香| 成人黄色国产精品网站大全在线免费观看| av一区二区三区| 欧美影视一区在线| 欧美电影精品一区二区| 国产日韩欧美精品电影三级在线| 国产精品久99| 亚洲综合色噜噜狠狠| 毛片一区二区三区| 国产成人精品三级麻豆| 91老师片黄在线观看| 在线电影国产精品| 国产亚洲综合在线| 依依成人精品视频| 免费国产亚洲视频| 成人精品国产一区二区4080| 在线观看av一区二区|