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

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

?? ida.cpp

?? 此文件是實現加解密算法的函數庫
?? CPP
字號:
// ida.cpp - written and placed in the public domain by Wei Dai

#include "pch.h"
#include "ida.h"

#include "algebra.h"
#include "gf2_32.h"
#include "polynomi.h"

#include "polynomi.cpp"

ANONYMOUS_NAMESPACE_BEGIN
static const CryptoPP::GF2_32 field;
NAMESPACE_END

using namespace std;

NAMESPACE_BEGIN(CryptoPP)

void RawIDA::ChannelInitialize(const string &channel, const NameValuePairs &parameters, int propagation)
{
	if (!channel.empty())
		throw NotImplemented("RawIDA: can't reinitialize a channel");

	if (!parameters.GetIntValue("RecoveryThreshold", m_threshold))
		throw InvalidArgument("RawIDA: missing RecoveryThreshold argument");

	if (m_threshold <= 0)
		throw InvalidArgument("RawIDA: RecoveryThreshold must be greater than 0");

	m_lastMapPosition = m_inputChannelMap.end();
	m_channelsReady = 0;
	m_channelsFinished = 0;
	m_w.New(m_threshold);
	m_y.New(m_threshold);
	m_inputQueues.reserve(m_threshold);

	m_outputChannelIds.clear();
	m_outputChannelIdStrings.clear();
	m_outputQueues.clear();

	word32 outputChannelID;
	if (parameters.GetValue("OutputChannelID", outputChannelID))
		AddOutputChannel(outputChannelID);
	else
	{
		int nShares = parameters.GetIntValueWithDefault("NumberOfShares", m_threshold);
		for (unsigned int i=0; i<nShares; i++)
			AddOutputChannel(i);
	}

	if (propagation)
		for (unsigned int i=0; i<m_outputChannelIds.size(); i++)
			AttachedTransformation()->ChannelInitialize(m_outputChannelIdStrings[i], parameters, propagation-1);
}

unsigned int RawIDA::InsertInputChannel(word32 channelId)
{
	if (m_lastMapPosition != m_inputChannelMap.end())
	{
		if (m_lastMapPosition->first == channelId)
			goto skipFind;
		++m_lastMapPosition;
		if (m_lastMapPosition != m_inputChannelMap.end() && m_lastMapPosition->first == channelId)
			goto skipFind;
	}
	m_lastMapPosition = m_inputChannelMap.find(channelId);

skipFind:
	if (m_lastMapPosition == m_inputChannelMap.end())
	{
		if (m_inputChannelIds.size() == m_threshold)
			return m_threshold;

		m_lastMapPosition = m_inputChannelMap.insert(pair<const unsigned long, unsigned int>(channelId, m_inputChannelIds.size())).first;
		m_inputQueues.push_back(MessageQueue());
		m_inputChannelIds.push_back(channelId);

		if (m_inputChannelIds.size() == m_threshold)
			PrepareInterpolation();
	}
	return m_lastMapPosition->second;
}

unsigned int RawIDA::LookupInputChannel(word32 channelId) const
{
	map<word32, unsigned int>::const_iterator it = m_inputChannelMap.find(channelId);
	if (it == m_inputChannelMap.end())
		return m_threshold;
	else
		return it->second;
}

void RawIDA::ChannelData(word32 channelId, const byte *inString, unsigned int length, bool messageEnd)
{
	unsigned int i = InsertInputChannel(channelId);
	if (i < m_threshold)
	{
		unsigned long size = m_inputQueues[i].MaxRetrievable();
		m_inputQueues[i].Put(inString, length);
		if (size < 4 && size + length >= 4)
		{
			m_channelsReady++;
			if (m_channelsReady == m_threshold)
				ProcessInputQueues();
		}

		if (messageEnd)
		{
			m_inputQueues[i].MessageEnd();
			if (m_inputQueues[i].NumberOfMessages() == 1)
			{
				m_channelsFinished++;
				if (m_channelsFinished == m_threshold)
				{
					m_channelsReady = 0;
					for (i=0; i<m_threshold; i++)
						m_channelsReady += m_inputQueues[i].AnyRetrievable();
					ProcessInputQueues();
				}
			}
		}
	}
}

unsigned int RawIDA::InputBuffered(word32 channelId) const
{
	unsigned int i = LookupInputChannel(channelId);
	return i < m_threshold ? m_inputQueues[i].MaxRetrievable() : 0;
}

void RawIDA::ComputeV(unsigned int i)
{
	if (i >= m_v.size())
	{
		m_v.resize(i+1);
		m_outputToInput.resize(i+1);
	}

	m_outputToInput[i] = LookupInputChannel(m_outputChannelIds[i]);
	if (m_outputToInput[i] == m_threshold && i * m_threshold <= 1000*1000)
	{
		m_v[i].resize(m_threshold);
		PrepareBulkPolynomialInterpolationAt(field, m_v[i].begin(), m_outputChannelIds[i], &(m_inputChannelIds[0]), m_w.begin(), m_threshold);
	}
}

void RawIDA::AddOutputChannel(word32 channelId)
{
	m_outputChannelIds.push_back(channelId);
	m_outputChannelIdStrings.push_back(WordToString(channelId));
	m_outputQueues.push_back(ByteQueue());
	if (m_inputChannelIds.size() == m_threshold)
		ComputeV(m_outputChannelIds.size() - 1);
}

void RawIDA::PrepareInterpolation()
{
	assert(m_inputChannelIds.size() == m_threshold);
	PrepareBulkPolynomialInterpolation(field, m_w.begin(), &(m_inputChannelIds[0]), m_threshold);
	for (unsigned int i=0; i<m_outputChannelIds.size(); i++)
		ComputeV(i);
}

void RawIDA::ProcessInputQueues()
{
	bool finished = (m_channelsFinished == m_threshold);
	unsigned int i;

	while (finished ? m_channelsReady > 0 : m_channelsReady == m_threshold)
	{
		m_channelsReady = 0;
		for (i=0; i<m_threshold; i++)
		{
			MessageQueue &queue = m_inputQueues[i];
			queue.GetWord32(m_y[i]);

			if (finished)
				m_channelsReady += queue.AnyRetrievable();
			else
				m_channelsReady += queue.NumberOfMessages() > 0 || queue.MaxRetrievable() >= 4;
		}

		for (i=0; i<m_outputChannelIds.size(); i++)
		{
			if (m_outputToInput[i] != m_threshold)
				m_outputQueues[i].PutWord32(m_y[m_outputToInput[i]]);
			else if (m_v[i].size() == m_threshold)
				m_outputQueues[i].PutWord32(BulkPolynomialInterpolateAt(field, m_y.begin(), m_v[i].begin(), m_threshold));
			else
			{
				m_u.resize(m_threshold);
				PrepareBulkPolynomialInterpolationAt(field, m_u.begin(), m_outputChannelIds[i], &(m_inputChannelIds[0]), m_w.begin(), m_threshold);
				m_outputQueues[i].PutWord32(BulkPolynomialInterpolateAt(field, m_y.begin(), m_u.begin(), m_threshold));
			}
		}
	}

	if (m_outputChannelIds.size() > 0 && m_outputQueues[0].AnyRetrievable())
		FlushOutputQueues();

	if (finished)
	{
		OutputMessageEnds();

		m_channelsReady = 0;
		m_channelsFinished = 0;
		m_v.clear();

		vector<MessageQueue> inputQueues;
		vector<word32> inputChannelIds;

		inputQueues.swap(m_inputQueues);
		inputChannelIds.swap(m_inputChannelIds);
		m_inputChannelMap.clear();
		m_lastMapPosition = m_inputChannelMap.end();

		for (i=0; i<m_threshold; i++)
		{
			inputQueues[i].GetNextMessage();
			inputQueues[i].TransferAllTo(*AttachedTransformation(), WordToString(inputChannelIds[i]));
		}
	}
}

void RawIDA::FlushOutputQueues()
{
	for (unsigned int i=0; i<m_outputChannelIds.size(); i++)
		m_outputQueues[i].TransferAllTo(*AttachedTransformation(), m_outputChannelIdStrings[i]);
}

void RawIDA::OutputMessageEnds()
{
	if (GetAutoSignalPropagation() != 0)
	{
		for (unsigned int i=0; i<m_outputChannelIds.size(); i++)
			AttachedTransformation()->ChannelMessageEnd(m_outputChannelIdStrings[i], GetAutoSignalPropagation()-1);
	}
}

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

void SecretSharing::Initialize(const NameValuePairs &parameters, int propagation)
{
	m_pad = parameters.GetValueWithDefault("AddPadding", true);
	m_ida.Initialize(parameters, propagation);
}

unsigned int SecretSharing::Put2(const byte *begin, unsigned int length, int messageEnd, bool blocking)
{
	if (!blocking)
		throw BlockingInputOnly("SecretSharing");

	SecByteBlock buf(STDMIN(length, 256U));
	unsigned int threshold = m_ida.GetThreshold();
	while (length > 0)
	{
		unsigned int len = STDMIN(length, (unsigned int)buf.size());
		m_ida.ChannelData(0xffffffff, begin, len, false);
		for (unsigned int i=0; i<threshold-1; i++)
		{
			m_rng.GenerateBlock(buf, len);
			m_ida.ChannelData(i, buf, len, false);
		}
		length -= len;
		begin += len;
	}

	if (messageEnd)
	{
		m_ida.SetAutoSignalPropagation(messageEnd-1);
		if (m_pad)
		{
			SecretSharing::Put(1);
			while (m_ida.InputBuffered(0xffffffff) > 0)
				SecretSharing::Put(0);
		}
		m_ida.ChannelData(0xffffffff, NULL, 0, true);
		for (unsigned int i=0; i<m_ida.GetThreshold()-1; i++)
			m_ida.ChannelData(i, NULL, 0, true);
	}

	return 0;
}

void SecretRecovery::Initialize(const NameValuePairs &parameters, int propagation)
{
	m_pad = parameters.GetValueWithDefault("RemovePadding", true);
	RawIDA::Initialize(CombinedNameValuePairs(parameters, MakeParameters("OutputChannelID", (word32)0xffffffff)), propagation);
}

void SecretRecovery::FlushOutputQueues()
{
	if (m_pad)
		m_outputQueues[0].TransferTo(*AttachedTransformation(), m_outputQueues[0].MaxRetrievable()-4);
	else
		m_outputQueues[0].TransferTo(*AttachedTransformation());
}

void SecretRecovery::OutputMessageEnds()
{
	if (m_pad)
	{
		PaddingRemover paddingRemover(new Redirector(*AttachedTransformation()));
		m_outputQueues[0].TransferAllTo(paddingRemover);
	}

	if (GetAutoSignalPropagation() != 0)
		AttachedTransformation()->MessageEnd(GetAutoSignalPropagation()-1);
}

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

void InformationDispersal::Initialize(const NameValuePairs &parameters, int propagation)
{
	m_nextChannel = 0;
	m_pad = parameters.GetValueWithDefault("AddPadding", true);
	m_ida.Initialize(parameters, propagation);
}

unsigned int InformationDispersal::Put2(const byte *begin, unsigned int length, int messageEnd, bool blocking)
{
	if (!blocking)
		throw BlockingInputOnly("InformationDispersal");
	
	while (length--)
	{
		m_ida.ChannelData(m_nextChannel, begin, 1, false);
		begin++;
		m_nextChannel++;
		if (m_nextChannel == m_ida.GetThreshold())
			m_nextChannel = 0;
	}

	if (messageEnd)
	{
		m_ida.SetAutoSignalPropagation(messageEnd-1);
		if (m_pad)
			InformationDispersal::Put(1);
		for (word32 i=0; i<m_ida.GetThreshold(); i++)
			m_ida.ChannelData(i, NULL, 0, true);
	}

	return 0;
}

void InformationRecovery::Initialize(const NameValuePairs &parameters, int propagation)
{
	m_pad = parameters.GetValueWithDefault("RemovePadding", true);
	RawIDA::Initialize(parameters, propagation);
}

void InformationRecovery::FlushOutputQueues()
{
	while (m_outputQueues[0].AnyRetrievable())
	{
		for (unsigned int i=0; i<m_outputChannelIds.size(); i++)
			m_outputQueues[i].TransferTo(m_queue, 1);
	}

	if (m_pad)
		m_queue.TransferTo(*AttachedTransformation(), m_queue.MaxRetrievable()-4*m_threshold);
	else
		m_queue.TransferTo(*AttachedTransformation());
}

void InformationRecovery::OutputMessageEnds()
{
	if (m_pad)
	{
		PaddingRemover paddingRemover(new Redirector(*AttachedTransformation()));
		m_queue.TransferAllTo(paddingRemover);
	}

	if (GetAutoSignalPropagation() != 0)
		AttachedTransformation()->MessageEnd(GetAutoSignalPropagation()-1);
}

unsigned int PaddingRemover::Put2(const byte *begin, unsigned int length, int messageEnd, bool blocking)
{
	if (!blocking)
		throw BlockingInputOnly("PaddingRemover");

	const byte *const end = begin + length;

	if (m_possiblePadding)
	{
		unsigned int len = find_if(begin, end, bind2nd(not_equal_to<byte>(), 0)) - begin;
		m_zeroCount += len;
		begin += len;
		if (begin == end)
			return 0;

		AttachedTransformation()->Put(1);
		while (m_zeroCount--)
			AttachedTransformation()->Put(0);
		AttachedTransformation()->Put(*begin++);
		m_possiblePadding = false;
	}

#if defined(_MSC_VER) && !defined(__MWERKS__)
	// VC60 workaround: built-in reverse_iterator has two template parameters, Dinkumware only has one
	typedef reverse_bidirectional_iterator<const byte *, const byte> rit;
#else
	typedef reverse_iterator<const byte *> rit;
#endif
	const byte *x = find_if(rit(end), rit(begin), bind2nd(not_equal_to<byte>(), 0)).base();
	if (x != begin && *(x-1) == 1)
	{
		AttachedTransformation()->Put(begin, x-begin-1);
		m_possiblePadding = true;
		m_zeroCount = end - x;
	}
	else
		AttachedTransformation()->Put(begin, end-begin);

	if (messageEnd)
	{
		m_possiblePadding = false;
		Output(0, begin, length, messageEnd, blocking);
	}
	return 0;
}

NAMESPACE_END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产69精品久久久久毛片 | 天使萌一区二区三区免费观看| 国产亚洲一区字幕| 欧美电影免费提供在线观看| 欧美一级理论片| 日韩欧美一级精品久久| 欧美一区二区播放| 精品国产乱码久久久久久图片| 欧美成人一区二区| 久久亚洲一区二区三区四区| 国产亚洲精品福利| 亚洲免费大片在线观看| 亚洲一级电影视频| 免费的国产精品| 国产一区欧美二区| www.性欧美| 91久久精品网| 日韩一区二区三区电影在线观看| 欧美精品一区二区三区蜜臀| 国产精品免费视频一区| 亚洲曰韩产成在线| 久久国产精品99精品国产| 国产精品综合久久| 欧美在线免费观看亚洲| 日韩精品一区二区三区swag| 国产精品欧美一区喷水| 亚洲小说欧美激情另类| 黄色日韩三级电影| 色香色香欲天天天影视综合网| 欧美日韩精品一区二区在线播放| 久久亚洲春色中文字幕久久久| 亚洲欧洲中文日韩久久av乱码| 男女男精品视频网| 波多野结衣亚洲| 欧美一区二区大片| 亚洲九九爱视频| 国产在线一区观看| 精品视频1区2区| 日本一区二区三区四区| 日本欧美在线看| 91麻豆国产香蕉久久精品| 日韩欧美www| 亚洲精品成人a在线观看| 国产精品伊人色| 欧美精品久久天天躁| 中文字幕视频一区二区三区久| 久久精品久久99精品久久| 成a人片国产精品| 91精品国产欧美一区二区成人| 亚洲欧洲av色图| 韩国欧美国产1区| 欧美精品第1页| 亚洲精品伦理在线| 国产99久久久国产精品潘金网站| 日韩午夜av电影| 亚洲成av人片一区二区梦乃| 97精品超碰一区二区三区| 久久久亚洲高清| 美女国产一区二区三区| 欧美视频在线播放| 亚洲欧美电影院| 成人高清视频在线| 亚洲国产电影在线观看| 国产在线播放一区| 日韩免费看的电影| 三级不卡在线观看| 欧美日韩五月天| 亚洲综合免费观看高清完整版在线| 成人丝袜18视频在线观看| 26uuu国产电影一区二区| 免费精品99久久国产综合精品| 欧美日韩一区二区不卡| 一区av在线播放| 91精品办公室少妇高潮对白| 最新不卡av在线| 91视频观看视频| 亚洲免费伊人电影| 欧美亚洲愉拍一区二区| 亚洲在线视频网站| 欧美美女激情18p| 日韩成人精品在线观看| 日韩精品一区二区三区在线| 麻豆精品一二三| 久久久久国产精品麻豆ai换脸 | 亚洲丝袜制服诱惑| 99国产一区二区三精品乱码| 亚洲欧美激情小说另类| 欧美性一二三区| 免费观看在线色综合| 日韩欧美国产精品| 国产激情偷乱视频一区二区三区| 亚洲国产精品黑人久久久| 94色蜜桃网一区二区三区| 一区二区免费在线播放| 日韩欧美不卡一区| 国产黑丝在线一区二区三区| 国产精品久久99| 在线看一区二区| 久久电影网电视剧免费观看| 欧美国产综合色视频| 欧美中文字幕亚洲一区二区va在线| 丝袜美腿亚洲一区二区图片| wwww国产精品欧美| 一本久久综合亚洲鲁鲁五月天| 天堂蜜桃91精品| 久久精品男人天堂av| 欧美探花视频资源| 国产一区二区视频在线播放| 成人欧美一区二区三区| 538在线一区二区精品国产| 国产精品18久久久久久久网站| 一区二区三区在线不卡| 精品国产免费一区二区三区四区| 91免费精品国自产拍在线不卡 | 精品国产免费视频| 91视视频在线观看入口直接观看www | 欧美哺乳videos| 97精品国产露脸对白| 麻豆精品视频在线观看视频| 日韩伦理av电影| 欧美精品一区二区三区在线播放 | 国产精品网站在线观看| 欧美男同性恋视频网站| 成人av在线一区二区| 美女看a上一区| 性久久久久久久| 亚洲欧美日韩人成在线播放| 久久婷婷综合激情| 欧美一区二区久久久| 色94色欧美sute亚洲线路一ni | 日本麻豆一区二区三区视频| 亚洲情趣在线观看| 国产精品久久久久久久久久久免费看| 91精品国产麻豆| 欧美日韩免费在线视频| 9色porny自拍视频一区二区| 极品少妇xxxx偷拍精品少妇| 日韩电影免费一区| 午夜精品久久久久久| 亚洲精品国产精华液| 中文字幕一区二区三区av| 欧美经典一区二区| 2021国产精品久久精品| 欧美电影精品一区二区| 91麻豆精品国产91久久久使用方法| 色国产精品一区在线观看| 99精品久久免费看蜜臀剧情介绍 | 一区二区视频在线| 亚洲日本va午夜在线电影| 国产精品丝袜在线| 国产清纯在线一区二区www| 久久久www成人免费毛片麻豆| 日韩精品一区二区在线观看| 日韩一区二区在线看片| 91精品国产综合久久久久| 8x福利精品第一导航| 欧美精品丝袜中出| 日韩视频中午一区| 日韩一级二级三级精品视频| 日韩欧美电影一二三| 久久蜜桃一区二区| 国产偷国产偷精品高清尤物| 国产拍揄自揄精品视频麻豆| 国产精品乱人伦| 亚洲欧美日韩一区二区 | 在线视频中文字幕一区二区| 欧美日韩大陆一区二区| 91麻豆精品国产91久久久使用方法| 日韩欧美中文字幕制服| 国产亚洲一区二区三区四区| 国产精品水嫩水嫩| 亚洲国产另类精品专区| 久久精品国产一区二区| 成人白浆超碰人人人人| 色婷婷久久综合| 91精品国产欧美一区二区成人| 欧美精品一区二区三区蜜桃视频 | 久久机这里只有精品| 国产成人鲁色资源国产91色综| 91丨porny丨最新| 日韩手机在线导航| 日韩理论在线观看| 免费av成人在线| 99精品视频在线播放观看| 在线播放日韩导航| 国产精品另类一区| 午夜精品aaa| 成人激情小说网站| 欧美一级xxx| 亚洲日本在线天堂| 狠狠色狠狠色综合| 在线观看中文字幕不卡| 精品国产伦一区二区三区观看方式| 亚洲欧美视频一区| 久久99久久精品| 在线观看欧美日本| 日本一区二区免费在线| 日本v片在线高清不卡在线观看| av一区二区不卡| 久久久国产精品麻豆|