⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hiddensngram.cc

📁 这是一款很好用的工具包
💻 CC
字号:
/*
 * HiddenSNgram.cc --
 *	N-gram backoff language model with hidden sentence boundaries
 *
 */

#ifndef lint
static char Copyright[] = "Copyright (c) 1995, SRI International.  All Rights Reserved.";
static char RcsId[] = "@(#)$Header: /home/srilm/devel/lm/src/RCS/HiddenSNgram.cc,v 1.2 2006/01/05 20:21:27 stolcke Exp $";
#endif

#include <iostream>
using namespace std;
#include <stdlib.h>

#include "HiddenSNgram.h"

#define DEBUG_PRINT_WORD_PROBS  2       /* from LM.cc */

HiddenSNgram::HiddenSNgram(Vocab &vocab, unsigned order)
    : Ngram(vocab, order)
{
    hiddenSIndex = vocab.addWord(HiddenSent);
}

/*
 * LM interface
 */

LogP
HiddenSNgram::wordProb(VocabIndex word, const VocabIndex *context)
{
    VocabIndex hiddenSContext[2];

    hiddenSContext[0] = hiddenSIndex;
    hiddenSContext[1] = Vocab_None;

    /*
     * Quick hack: take the max if p(w|context) and p(w|<#s>) p(<#s>|context).
     * Replace this with dynamic programming later.
     */

    LogP p1 = Ngram::wordProb(word, context);
    LogP p2 = Ngram::wordProb(hiddenSIndex, context) + 
		  Ngram::wordProb(word, hiddenSContext);

    if (p1 >= p2) {
	return p1;
    } else {
	if (running() && debug(DEBUG_PRINT_WORD_PROBS)) {
	    dout() << "[" << HiddenSent << "]";
	}
	return p2;
    }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -