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

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

?? ec2n.cpp

?? #include "pch.h" #include "base64.h" NAMESPACE_BEGIN(CryptoPP) static const int MAX_LINE_LENG
?? 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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费观看高清完整| 91亚洲精品久久久蜜桃| 欧美性欧美巨大黑白大战| 中文字幕制服丝袜一区二区三区| 亚洲精品国产成人久久av盗摄 | 免费成人美女在线观看.| 成人性生交大片免费| 99免费精品在线| 久久久五月婷婷| 久久国内精品视频| 91精品在线麻豆| 一区二区三区四区视频精品免费| 国内精品视频一区二区三区八戒| 3d动漫精品啪啪1区2区免费| 一区二区三区四区高清精品免费观看 | 亚洲成a人v欧美综合天堂下载| 国产成人aaaa| 国产精品嫩草影院av蜜臀| 国产综合成人久久大片91| 精品久久久网站| 美女国产一区二区三区| 91精品国产欧美一区二区成人| 亚洲国产成人精品视频| 91精品一区二区三区在线观看| 国产一区在线看| 欧美一区二区国产| 一区av在线播放| 欧美精品日韩一本| 狠狠v欧美v日韩v亚洲ⅴ| 欧美浪妇xxxx高跟鞋交| 日本sm残虐另类| 精品久久久久久久人人人人传媒 | 国产农村妇女精品| 91丨porny丨国产入口| 国产精品午夜春色av| 成人少妇影院yyyy| 亚洲成人激情av| 日韩精品一区二区三区四区| 国模大尺度一区二区三区| 久久婷婷综合激情| 91国偷自产一区二区开放时间 | 日韩一级完整毛片| 日本欧美一区二区| 日韩视频123| 国产剧情av麻豆香蕉精品| 国产日韩精品一区二区浪潮av | 欧美一区二区三区四区在线观看| 蜜桃视频在线一区| 国产精品色一区二区三区| 99在线精品一区二区三区| 亚洲成人免费在线观看| 精品国产91乱码一区二区三区 | 婷婷开心激情综合| 欧美自拍偷拍午夜视频| 日本怡春院一区二区| 欧美一区二区三区四区在线观看| 国产成人免费视频网站| 一区二区三区精品在线| 精品免费一区二区三区| 国产成人av电影在线播放| 夜夜夜精品看看| 精品精品国产高清a毛片牛牛| 99综合影院在线| 精品国产1区二区| 成人av集中营| 亚洲综合自拍偷拍| 国产欧美日韩综合精品一区二区 | 国产精品99久久久久久久女警 | 国产精品欧美一级免费| 成人黄色在线网站| 狠狠色狠狠色合久久伊人| 夜夜嗨av一区二区三区网页| 国产日产欧产精品推荐色| 欧美一级视频精品观看| 在线观看av一区二区| 国产成人在线视频网址| 理论片日本一区| 中文字幕亚洲综合久久菠萝蜜| 欧美日韩电影在线| 国产 欧美在线| 国产老女人精品毛片久久| 麻豆免费看一区二区三区| 亚洲精品国产无套在线观| 亚洲美女少妇撒尿| 中日韩av电影| 久久久不卡网国产精品二区| 国产夜色精品一区二区av| 欧美精品亚洲一区二区在线播放| 欧美视频日韩视频在线观看| 色婷婷国产精品综合在线观看| 丁香亚洲综合激情啪啪综合| 国产成人免费视| 国产精品综合av一区二区国产馆| 蜜桃视频第一区免费观看| 水蜜桃久久夜色精品一区的特点| 国产精品久久久久影院色老大| 91老师国产黑色丝袜在线| 91行情网站电视在线观看高清版| 欧美羞羞免费网站| 欧美一级精品在线| 久久久久久久网| 日韩精品一区二区三区视频| 精品国产网站在线观看| 国产婷婷色一区二区三区四区| 欧美日韩一区三区四区| 精品国产免费人成在线观看| 日本一区二区视频在线观看| 亚洲综合激情小说| 精品一区二区在线视频| 91一区二区三区在线播放| 精品国产一区a| 成人av免费在线| www.激情成人| 5月丁香婷婷综合| 26uuu欧美| 一二三区精品视频| 国产福利一区二区| 欧美性受极品xxxx喷水| 欧美一级艳片视频免费观看| 精品国产亚洲在线| 亚洲一区二区三区四区不卡| 国产在线乱码一区二区三区| 97精品视频在线观看自产线路二| 欧美丰满嫩嫩电影| 一区在线播放视频| 国产精品一二三区| 日韩一区国产二区欧美三区| 亚洲人成影院在线观看| 国产美女主播视频一区| 91精品国产福利| 亚洲一区二区不卡免费| 奇米777欧美一区二区| 国产91精品一区二区麻豆亚洲| 91一区在线观看| 国产精品国产三级国产a| 免播放器亚洲一区| 91黄色在线观看| 国产天堂亚洲国产碰碰| 欧美国产97人人爽人人喊| 久久爱另类一区二区小说| 欧美卡1卡2卡| 亚洲成人先锋电影| 中文字幕在线观看一区| av亚洲精华国产精华| 国产欧美一区二区在线观看| 国产成人三级在线观看| 日韩一卡二卡三卡| 日韩av二区在线播放| 欧美精品三级在线观看| 亚洲午夜电影在线观看| av在线一区二区| 亚洲免费在线视频一区 二区| 色狠狠色噜噜噜综合网| 1000部国产精品成人观看| 91麻豆国产福利精品| 亚洲欧美另类小说| 欧美日韩一区国产| 久99久精品视频免费观看| 日韩精品一区二区三区在线| 日本欧美一区二区三区乱码| 日本丶国产丶欧美色综合| 亚洲精品五月天| 欧美无人高清视频在线观看| 亚洲18女电影在线观看| 欧美日韩卡一卡二| 国产九色sp调教91| 亚洲免费高清视频在线| 日韩欧美在线网站| 国产精品一区专区| 依依成人精品视频| 日韩欧美国产1| 91视视频在线直接观看在线看网页在线看| 亚洲三级在线观看| 欧美成人综合网站| 久久国产福利国产秒拍| 日韩福利电影在线| 国产综合色精品一区二区三区| 欧美理论片在线| 狠狠色丁香九九婷婷综合五月| 国产午夜精品福利| 欧美日本在线视频| 成人黄色电影在线 | 久久影院午夜片一区| 一本大道久久a久久综合婷婷 | 香蕉久久一区二区不卡无毒影院| 欧美美女喷水视频| 成人午夜大片免费观看| 日本vs亚洲vs韩国一区三区二区| 国产亚洲精品精华液| 欧美一区二区三区电影| 91啪亚洲精品| 国产91精品一区二区| 狠狠色狠狠色综合| 国产乱子伦视频一区二区三区| 亚洲欧美一区二区视频| www成人在线观看| 欧美一区二区三区日韩视频| 亚洲免费观看在线视频| 欧美国产一区二区| 久久蜜桃香蕉精品一区二区三区|