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

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

?? combinatorialcompleter.cpp

?? 粗慥集成算法集合 ,并有詳細的文檔資料和測試數據處
?? CPP
字號:
//-------------------------------------------------------------------
// Author........: Aleksander 豩rn
// Date..........:
// Description...:
// Revisions.....:
//===================================================================

#include <stdafx.h> // Precompiled headers.
#include <copyright.h>

#include <kernel/algorithms/combinatorialcompleter.h>

#include <kernel/structures/decisiontable.h>

#include <kernel/basic/bits.h>
#include <kernel/basic/message.h>

//-------------------------------------------------------------------
// Methods for class CombinatorialCompleter.
//===================================================================

//-------------------------------------------------------------------
// Constructors/destructor.
//===================================================================

CombinatorialCompleter::CombinatorialCompleter() {
}

CombinatorialCompleter::~CombinatorialCompleter() {
}

//-------------------------------------------------------------------
// Methods inherited from Identifier.
//===================================================================

IMPLEMENTIDMETHODS(CombinatorialCompleter, COMBINATORIALCOMPLETER, Completer)

//-------------------------------------------------------------------
// Methods inherited from Algorithm.
//===================================================================

//-------------------------------------------------------------------
// Method........: Apply
// Author........: Aleksander 豩rn
// Date..........:
// Description...: Returns a new decision table which is a duplicate
//                 of the input table, except for that missing values
//                 have been substituted with all possible value
//                 combinations.
// Comments......:
// Revisions.....:
//===================================================================

Structure *
CombinatorialCompleter::Apply(Structure &structure) const {

	// Is the input structure of right type?
	if (!IsApplicable(structure))
		return NULL;

	// Cast to verified type.
	Handle<DecisionTable> table = dynamic_cast(DecisionTable *, &structure);

	// Operate on an unmasked table.
	bool masked = false;

	int no_objects    = table->GetNoObjects(masked);
	int no_attributes = table->GetNoAttributes(masked);

	// Create a new table. Duplicate the old one to "inherit" masking and dictionary.
	Handle<DecisionTable> complete = dynamic_cast(DecisionTable *, table->Duplicate());

	// Resize the new table to initially contain one object.
	if (!complete->Resize(1, no_attributes, masked)) {
		Message::Error("Failed to resize the new table.");
		return NULL;
	}

	Vector(Vector(int)) values;

	// Calculate value sets (the sets of possible values the attributes can take on).
	if (!CalculateValueSets(values, *table, masked)) {
		Message::Error("Error computing value sets.");
		return NULL;
	}

	int i, j;

	bool first = true;

  // Iterate over all objects.
	for (i = 0; i < no_objects; i++) {

		Bits        is_missing(no_attributes, false);
		Vector(int) no_values;

		no_values.reserve(no_attributes);

		int no_expansions = 1;

		// Compute how many objects the current object expands to.
		for (j = 0; j < no_attributes; j++) {

			// Don't expand missing entries that are masked (or non-missing entries).
			if (!table->IsAttributeEnabled(j) || !table->IsObjectEnabled(i) || !table->IsMissing(i, j, masked)) {
				is_missing[j] = false;
				no_values.push_back(1);
			}
			else {
				is_missing[j] = true;
				no_values.push_back(values[j].size());
			}

			no_expansions *= no_values[j];

		}

		// Append new, empty objects to the complete table.
		for (j = 0; j < no_expansions; j++) {

			// The table had one object originally.
			if (first) {
				first = false;
				continue;
			}

			if (!complete->AppendObject(masked)) {
				Message::Error("Failed to append object to table.");
				return NULL;
			}

		}

		// Get the index of the first new object in the complete table.
		int start = complete->GetNoObjects(masked) - no_expansions;

		// Iterate over all attributes.
		for (j = 0; j < no_attributes; j++) {

			int l, m, k = start;

			// Iterate over all newly appended objects.
			while (k < start + no_expansions) {

				// Iterate over all possible values.
				for (l = 0; l < no_values[j]; l++) {

					int no_repetitions = no_expansions;

					// Compute how often to repeat the current value.
					if (is_missing[j]) {
						for (m = 0; m <= j; m++)
							no_repetitions /= no_values[m];
					}

					// Repeat the current value a certain number of times.
					for (m = 0; m < no_repetitions; m++) {

						int expanded;

						// Determine expansion.
						if (is_missing[j] && !values[j].empty())
							expanded = values[j][l];
						else
							expanded = table->GetEntry(i, j, masked);

						// Set expanded table entry.
						if (!complete->SetEntry(k++, j, expanded, masked)) {
							Message::Error("Failed to set table entry.");
							return NULL;
						}

					}

				}

			}

		}

	}

	return complete.Release();

}

//-------------------------------------------------------------------
// Local methods.
//===================================================================

//-------------------------------------------------------------------
// Method........: CalculateValueSets
// Author........: Aleksander 豩rn
// Date..........:
// Description...: Calculates value sets for all attributes,
//                 ignoring missing entries.
// Comments......:
// Revisions.....:
//===================================================================

bool
CombinatorialCompleter::CalculateValueSets(Vector(Vector(int)) &values, const DecisionTable &table, bool masked) const {

	int no_attributes = table.GetNoAttributes(masked);

	// Erase all entries, if any.
	values.erase(values.begin(), values.end());
	values.reserve(no_attributes);

	int i, j;

	// Calculate value sets.
	for (i = 0; i < no_attributes; i++) {

		// Calculate the distribution.
		Vector(int) entries;
		Vector(int) frequencies;

		if (!table.GetValueSet(entries, frequencies, i, masked))
			return false;

		// Remove missing entries from value set.
		for (j = 0; j < entries.size(); j++) {
			if (entries[j] == Undefined::Integer()) {
				entries.erase(entries.begin() + j);
				break;
			}
		}

		// Store value set for current attribute.
		values.push_back(entries);

	}

	return true;

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区二区久久精品爱涩| 精品写真视频在线观看| 久久精品人人做人人综合| 91精品国产一区二区三区香蕉 | 久久一区二区三区国产精品| 91精品在线观看入口| 在线成人小视频| 337p粉嫩大胆噜噜噜噜噜91av| 日韩欧美一区二区免费| 久久久影院官网| 国产精品国产自产拍高清av| 一区精品在线播放| 亚洲一区二区三区四区五区黄| 亚洲高清视频的网址| 另类小说图片综合网| 国产很黄免费观看久久| 成人激情免费电影网址| 91色在线porny| 在线播放中文字幕一区| 国产午夜精品福利| 一区二区三区成人| 美女诱惑一区二区| 成人av在线网| 88在线观看91蜜桃国自产| 日韩三级视频在线看| 国产精品欧美一级免费| 午夜精品一区在线观看| 国产一区二区福利| 欧美系列在线观看| 久久久久久久性| 亚洲一区二三区| 国产成人av资源| 欧美色视频在线观看| 亚洲精品一区二区三区精华液 | 欧美巨大另类极品videosbest | 中文字幕精品三区| 亚洲成人中文在线| 国产风韵犹存在线视精品| 欧美日精品一区视频| 国产精品亲子伦对白| 日产欧产美韩系列久久99| 成人h版在线观看| 欧美成人在线直播| 一区二区高清免费观看影视大全| 久久97超碰色| 欧美高清一级片在线| 成人免费在线播放视频| 激情综合色播激情啊| 欧美日韩一二三| 中文字幕日本不卡| 国产91富婆露脸刺激对白| 日韩一级在线观看| 视频一区视频二区中文| 91久久国产最好的精华液| 国产精品久久久久久久蜜臀 | 欧美经典一区二区| 美女视频一区二区三区| 欧美美女黄视频| 亚洲精品久久7777| 99久免费精品视频在线观看| 26uuu久久天堂性欧美| 蜜臀国产一区二区三区在线播放| 精品视频一区 二区 三区| 亚洲欧美电影院| kk眼镜猥琐国模调教系列一区二区| 亚洲精品在线网站| 黄色资源网久久资源365| 欧美v国产在线一区二区三区| 日韩精品一二三| 91精品麻豆日日躁夜夜躁| 视频一区二区三区入口| 欧美日韩一区二区在线观看 | 亚洲视频网在线直播| aaa亚洲精品一二三区| 中文字幕精品综合| 成人av在线影院| 亚洲天堂av一区| 老司机精品视频线观看86| 日韩视频免费观看高清完整版在线观看 | 欧日韩精品视频| 日韩经典中文字幕一区| 欧美一区中文字幕| 麻豆精品国产91久久久久久| 日韩精品一区二区三区视频播放 | 欧美理论在线播放| 天堂在线一区二区| 日韩丝袜美女视频| 国产在线播放一区二区三区| 欧美国产日韩在线观看| 色综合欧美在线| 日韩中文字幕91| 久久综合中文字幕| av成人免费在线| 日韩有码一区二区三区| 久久午夜电影网| 91视频免费观看| 偷偷要91色婷婷| 国产婷婷精品av在线| 欧美在线影院一区二区| 蓝色福利精品导航| 综合久久久久综合| 欧美成人r级一区二区三区| 成人性生交大片免费看中文网站 | 制服丝袜亚洲网站| 国产成人免费在线| 亚洲午夜成aⅴ人片| 久久久久亚洲综合| 精品视频在线看| 丁香啪啪综合成人亚洲小说| 一区二区三区四区精品在线视频| 日韩三级视频在线观看| aaa欧美日韩| 极品少妇xxxx精品少妇| 亚洲另类春色校园小说| 精品国产一区二区三区四区四| 97久久精品人人做人人爽50路| 丝瓜av网站精品一区二区| 中文字幕免费不卡| 欧美成人三级在线| 欧美视频中文一区二区三区在线观看 | 麻豆一区二区在线| 亚洲综合偷拍欧美一区色| 久久久91精品国产一区二区精品| 91久久精品一区二区三| 岛国精品在线观看| 韩国精品在线观看| 五月综合激情日本mⅴ| 亚洲日本在线看| 国产精品久久三区| 欧美激情中文不卡| 精品理论电影在线| 4438成人网| 欧美日韩高清一区二区三区| 99re热这里只有精品免费视频| 国产呦精品一区二区三区网站| 天堂av在线一区| 亚洲国产成人av好男人在线观看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 色欧美片视频在线观看在线视频| 国产老妇另类xxxxx| 精品制服美女久久| 琪琪久久久久日韩精品| 日韩国产在线一| 亚洲bt欧美bt精品| 日韩中文字幕一区二区三区| 天天综合色天天综合色h| 天天做天天摸天天爽国产一区 | 日日夜夜免费精品视频| 亚洲成人av一区| 天堂成人免费av电影一区| 五月天亚洲婷婷| 视频一区在线播放| 美女在线视频一区| 韩国女主播一区| 国产xxx精品视频大全| 国产精品一区二区在线观看网站| 国产成人在线影院| 91网站在线播放| 欧美专区日韩专区| 5月丁香婷婷综合| 欧美va亚洲va香蕉在线| 久久一区二区三区国产精品| 中文字幕免费不卡| 一个色在线综合| 日韩电影一区二区三区四区| 久久精品国产99国产精品| 国产黄色91视频| 色天天综合久久久久综合片| 欧美日韩成人一区| 欧美成va人片在线观看| 国产精品婷婷午夜在线观看| 亚洲欧美日韩国产一区二区三区| 亚洲黄色免费网站| 捆绑调教美女网站视频一区| 成人性色生活片免费看爆迷你毛片| 91免费小视频| 日韩欧美中文字幕公布| 亚洲国产精品成人久久综合一区| 亚洲欧美日韩系列| 精品一区二区在线视频| 91在线视频18| 日韩欧美久久久| 成人欧美一区二区三区黑人麻豆| 日日骚欧美日韩| 粉嫩嫩av羞羞动漫久久久| 欧美丝袜丝交足nylons图片| 久久这里只有精品6| 亚洲福利一二三区| 国产成人综合网| 欧美一区二区三区电影| 最新热久久免费视频| 麻豆精品视频在线| 91久久精品一区二区二区| 久久久久99精品一区| 亚洲大片一区二区三区| 波多野结衣91| 久久伊99综合婷婷久久伊| 亚洲sss视频在线视频| 91视频在线看| 国产精品久久久久久一区二区三区 |