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

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

?? languagemodel.cpp

?? 解碼器是基于短語的統計機器翻譯系統的核心模塊
?? CPP
字號:
#include "LanguageModel.h"

using namespace std;

extern bool printmore;

LanguageModel::LanguageModel(double prob)
{
	UNKPROB = prob;
}


bool LanguageModel::load(string fileName, Vocab *vocab)//加載LM, srilm,文件為arpa-standard format
{
	string strTmp;
	vcb = vocab;
	if (!vcb) {
		cout << "english vocab is NULL!" << endl;
		return 0;
	}
	input.open(fileName.c_str(), std::ios::in);
	if (!input) 
	{
		cout << "Open Language Model" << fileName << "Error" << endl;
		return 0;
	}
	while (getline(input, strTmp)) 
	{
		int tabPositionStart = strTmp.find_first_of('\t');
		if (tabPositionStart != string::npos) 
		{
			string prob(strTmp, 0, tabPositionStart);
			int tabPositionEnd = strTmp.find_last_of('\t');
			ProbAndBO tmpProbAndBO;
			if (tabPositionEnd != string::npos) 
			{
				string backoffProb(strTmp, tabPositionEnd + 1, strTmp.length() - tabPositionEnd + 1);
				string gram(strTmp, tabPositionStart + 1, tabPositionEnd - tabPositionStart - 1);

				tmpProbAndBO.prob = atof(prob.c_str());
				tmpProbAndBO.backoffWeight = atof(backoffProb.c_str());
				vector<int> gramIDs;
				int numSpace = vcb->getIndices(gram, gramIDs);
				if (numSpace == 1) {
					uniGram.insert(make_pair(gramIDs, tmpProbAndBO));
				}
				else if (numSpace == 2) {
					biGram.insert(make_pair(gramIDs, tmpProbAndBO));
				}
				else if (numSpace == 3) {
					triGram.insert(make_pair(gramIDs, tmpProbAndBO));
				}
			}
			else
			{
				string gram(strTmp, tabPositionStart + 1, strTmp.length() - tabPositionStart + 1);
				tmpProbAndBO.prob = atof(prob.c_str());
				tmpProbAndBO.backoffWeight = 0;
				vector<int> gramIDs;
				int numSpace = vcb->getIndices(gram, gramIDs);
				if (numSpace == 1) {
					uniGram.insert(make_pair(gramIDs, tmpProbAndBO));
				}
				else if (numSpace == 2) {
					biGram.insert(make_pair(gramIDs, tmpProbAndBO));
				}
				else if (numSpace == 3) {
					triGram.insert(make_pair(gramIDs, tmpProbAndBO));
				}	
			}
		}
	}
	input.clear();
	input.close();
	if(printmore) {
	cout << "Loading language model finished!" << endl;
	}

	return 1;
}

double LanguageModel::uniProb(int word)
{
	vector<int> vecTmp;
	vecTmp.push_back(word);
	mapNgram::iterator pos = uniGram.find(vecTmp);
	double p = INFINITE;
	if (pos != uniGram.end()) {
		p = (pos->second).prob * LN;
	}
	if (p - UNKPROB < avs) {
			return UNKPROB;
	}
	return p;

}

double LanguageModel::uniBO(int word)
{
	vector<int> vecTmp;
	vecTmp.push_back(word);
	mapNgram::iterator pos = uniGram.find(vecTmp);
	if (pos != uniGram.end()) {
		return (pos->second).backoffWeight * LN;
	}
	else
	{
		return UNKBO;
	}	
}
//p(wd2|wd1)= if(bigram exists) p_2(wd1,wd2)
//            else              bo_wt_1(wd1)*p_1(wd2)
double LanguageModel::biProb(int word1, int word2)
{
	vector<int> vecTmp;
	vecTmp.push_back(word1);
	vecTmp.push_back(word2);
	mapNgram::iterator pos = biGram.find(vecTmp);
	double p = INFINITE;
	if (pos != biGram.end()) {
		p = (pos->second).prob * LN;	
	}
	else {
		p = uniBO(word1) + uniProb(word2);
	}
	if (p - UNKPROB < avs) {
			return UNKPROB;
	}
	return p;
}

double LanguageModel::biBO(int word1, int word2)
{
	vector<int> vecTmp, vecTmp1, vecTmp2;
	vecTmp.push_back(word1);
	vecTmp.push_back(word2);
	mapNgram::iterator pos = biGram.find(vecTmp);
	if (pos != biGram.end()) 
	{
		return (pos->second).backoffWeight * LN;
	}
}

//p(wd3|wd1,wd2)= if(trigram exists)           p_3(wd1,wd2,wd3)
//                else if(bigram w1,w2 exists) bo_wt_2(w1,w2)*p(wd3|wd2)
//                else                         p(wd3|w2)

double LanguageModel::triProb(int word1, int word2, int word3)
{
	vector<int> vecTmp, vecTmp12;
	vecTmp.push_back(word1);
	vecTmp.push_back(word2);
	vecTmp.push_back(word3);
	vecTmp12.push_back(word1);
	vecTmp12.push_back(word2);

	mapNgram::iterator pos = triGram.find(vecTmp);
	double p = INFINITE;
	if (pos != triGram.end()) {
		p = (pos->second).prob * LN;
		
	}
	else if (biGram.find(vecTmp12) != biGram.end()) 
	{
		p = (biBO(word1, word2) + biProb(word2, word3)) ;
	}
	else
	{
		p = biProb(word2, word3);
	}
	if (p - UNKPROB < avs) {
		return UNKPROB;
	}
	return p;

}

double LanguageModel::wordProb(vector<int> Ephrase)
{
	int len = Ephrase.size();
	if (len == 1) {
		return  uniProb(Ephrase[0]);
	}
	else if (len ==2) {
		return  biProb(Ephrase[0], Ephrase[1]);
	}
	else if (len == 3) {
		return  triProb(Ephrase[0], Ephrase[1],Ephrase[2]);
	}
	else {
		return  triProb(Ephrase[len - 3], Ephrase[len - 2],Ephrase[len - 1]);
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩在线播放三区| 91在线看国产| 男女男精品视频| 亚洲bt欧美bt精品| 午夜一区二区三区在线观看| 一区二区中文视频| 亚洲欧洲综合另类在线| 日韩伦理av电影| 亚洲欧洲制服丝袜| 视频在线观看一区二区三区| 亚洲精选一二三| 亚洲精品老司机| 亚洲va天堂va国产va久| 日本女人一区二区三区| 久久www免费人成看片高清| 久久激情五月婷婷| 国产91丝袜在线播放九色| 高清国产一区二区| 91亚洲精品乱码久久久久久蜜桃| 91在线国产观看| 欧美日韩精品系列| 欧美一级欧美三级在线观看| 亚洲精品在线网站| 2020日本不卡一区二区视频| 国产人久久人人人人爽| 136国产福利精品导航| 亚洲综合免费观看高清完整版| 亚洲风情在线资源站| 久久福利资源站| 97久久超碰国产精品| 欧美精品v日韩精品v韩国精品v| 日韩午夜在线影院| 国产精品视频观看| 午夜精品久久久久久久| 国产伦理精品不卡| 在线精品视频小说1| 日韩一本二本av| 国产精品丝袜久久久久久app| 依依成人综合视频| 国产一区不卡在线| 国产精品国产a级| 色哟哟国产精品免费观看| 欧美色精品天天在线观看视频| 欧美精选一区二区| 国产精品五月天| 日本不卡视频在线| 99re这里只有精品视频首页| 日韩一区二区不卡| 一区二区三区在线观看视频| 精品一区二区成人精品| 色综合久久综合网97色综合| 日韩欧美在线1卡| 亚洲你懂的在线视频| 国产一区久久久| 欧美性感一类影片在线播放| 欧美国产一区二区| 免费成人在线影院| 欧美日韩三级在线| 亚洲人成精品久久久久久| 国产在线精品视频| 日韩一区二区三区电影在线观看| 国产精品青草久久| 国产一区二区调教| 欧美刺激午夜性久久久久久久| 亚洲欧美日韩国产成人精品影院| 国产精品亚洲人在线观看| 欧美一区2区视频在线观看| 伊人开心综合网| 色综合欧美在线视频区| 国产精品毛片a∨一区二区三区| 麻豆成人av在线| 91精品福利在线一区二区三区| 亚洲免费伊人电影| 色婷婷av一区二区三区之一色屋| 日本一区二区成人在线| 国产精品一区二区三区乱码| 精品嫩草影院久久| 国产最新精品精品你懂的| 欧美丰满少妇xxxbbb| 五月天网站亚洲| 7777精品伊人久久久大香线蕉的 | 久久综合五月天婷婷伊人| 日韩不卡在线观看日韩不卡视频| 欧美视频一区在线| 亚洲成人av一区二区三区| 欧美三级一区二区| 视频在线在亚洲| 日韩一区二区三区电影| 美女视频网站黄色亚洲| 欧美精品一区二区久久久 | 欧美www视频| 国产精品一线二线三线| 国产喷白浆一区二区三区| 97精品超碰一区二区三区| 中文字幕中文字幕在线一区| 色综合久久久久| 日韩电影免费在线观看网站| 日韩女同互慰一区二区| 国产成人高清视频| 一区二区三区精品| 日韩一区二区三区三四区视频在线观看 | 伊人婷婷欧美激情| 欧美日韩综合在线免费观看| 麻豆精品视频在线观看视频| 久久久久高清精品| 色婷婷一区二区三区四区| 亚洲va中文字幕| 2020国产精品久久精品美国| 91一区二区在线观看| 日韩中文字幕区一区有砖一区 | 精品电影一区二区三区| 成人网在线免费视频| 久久97超碰色| 亚洲四区在线观看| 日韩精品一区二区三区视频在线观看| 国产成人亚洲精品狼色在线 | 99精品黄色片免费大全| 五月天激情综合| 亚洲国产精品二十页| 欧美日韩中文字幕一区| 韩国视频一区二区| 夜夜揉揉日日人人青青一国产精品 | 久久久久久久久久久电影| 91年精品国产| 国产一区福利在线| 午夜一区二区三区在线观看| 国产精品天美传媒沈樵| 日韩欧美一区二区在线视频| 91免费视频网址| 国产精品99久久久久久久vr| 五月天中文字幕一区二区| 中文字幕成人在线观看| 欧美xxxxxxxxx| 91久久一区二区| 成人av电影免费观看| 麻豆国产欧美日韩综合精品二区| 国产精品毛片久久久久久| 日韩欧美亚洲国产另类| 在线日韩av片| 99国产精品国产精品久久| 国产精品一区二区在线播放| 日韩电影在线看| 五月天激情综合| 亚洲一区二区av电影| 亚洲美女少妇撒尿| 国产精品不卡一区二区三区| 亚洲国产精品激情在线观看| 久久亚区不卡日本| 精品国产一区二区三区四区四| 欧美日韩在线观看一区二区 | 91麻豆高清视频| 成人综合在线视频| 国产精品综合在线视频| 激情欧美日韩一区二区| 美国三级日本三级久久99| 日本欧美一区二区三区乱码| 亚洲一区二区三区四区五区中文| 亚洲视频一二三| 亚洲激情图片qvod| 亚洲综合无码一区二区| 亚洲国产成人精品视频| 亚洲成人动漫一区| 日本免费新一区视频| 狂野欧美性猛交blacked| 韩国欧美一区二区| 国产河南妇女毛片精品久久久| 国产一区二区三区免费观看| 国产馆精品极品| av成人动漫在线观看| 在线精品视频小说1| 欧美精品丝袜久久久中文字幕| 911精品国产一区二区在线| 日韩一区二区三区免费看 | 欧美大度的电影原声| 精品国产伦一区二区三区观看体验| 精品女同一区二区| 中文字幕av一区二区三区免费看| 综合中文字幕亚洲| 亚洲国产wwwccc36天堂| 另类小说视频一区二区| 国产99久久精品| 91国产丝袜在线播放| 欧美一级精品在线| 欧美国产1区2区| 亚洲国产精品精华液网站| 麻豆91在线观看| 91女人视频在线观看| 欧美一区二区精美| 国产精品人妖ts系列视频| 五月天一区二区| 成人国产视频在线观看| 欧美性生活一区| 久久精品水蜜桃av综合天堂| 亚洲狼人国产精品| 激情久久五月天| 欧美羞羞免费网站| 国产欧美日韩视频在线观看| 亚洲国产一区二区a毛片| 国产九色精品成人porny| 欧美性色黄大片手机版|