本文整理汇总了C++中HMM::outgoingStates方法的典型用法代码示例。如果您正苦于以下问题:C++ HMM::outgoingStates方法的具体用法?C++ HMM::outgoingStates怎么用?C++ HMM::outgoingStates使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类HMM
的用法示例。
在下文中一共展示了HMM::outgoingStates方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: runtime_error
tuple<vector<double>, Matrix<double>, Matrix<double>> forward_backward(string obs, const HMM& model)
{
if (!model.isFinalized())
throw runtime_error("Model should be finalized!");
// Forward algorithm
Matrix<double> forward(obs.length(), model.numStates(), 0);
vector<double> cs(obs.length(), 0);
// Calculate c1
for (size_t state = 0; state < model.numStates(); state++)
cs[0] += model.startProb(state) * model.emissionProb(state, obs.substr(0,1));
// Base case
for (size_t state = 0; state < model.numStates(); state++)
forward(0, state) = model.startProb(state) * model.emissionProb(state, obs.substr(0,1)) / cs[0];
// Recursion
for (size_t i = 1; i < obs.length(); i++) {
vector<double> delta(model.numStates(), 0);
for (size_t state = 0; state < model.numStates(); state++) {
if (i < model.stateArity(state))
continue;
for (auto prevState : model.incommingStates(state)) {
double val = forward(i - model.stateArity(state), prevState) * model.transitionProb(prevState, state);
for (size_t k = 1; k < model.stateArity(state); k++)
val /= cs[i - k];
delta[state] += val;
}
delta[state] *= model.emissionProb(state, obs.substr(i - model.stateArity(state) + 1, model.stateArity(state)));
cs[i] += delta[state];
}
for (size_t state = 0; state < model.numStates(); state++) {
forward(i, state) = delta[state] / cs[i];
}
}
// Backward algorithm
Matrix<double> backward(obs.length(), model.numStates(), 0);
const size_t N = obs.length() - 1;
for (size_t state = 0; state < model.numStates(); state++)
backward(N, state) = 1;
for (long i = N - 1; i >= 0; i--) {
for (size_t state = 0; state < model.numStates(); state++) {
double prob = 0;
for (auto nextState : model.outgoingStates(state)) {
if (i + model.stateArity(nextState) > N)
continue;
double val = backward(i + model.stateArity(nextState), nextState) * model.transitionProb(state, nextState)
* model.emissionProb(nextState, obs.substr(i + 1, model.stateArity(nextState)));
for (size_t k = 0; k < model.stateArity(nextState); k++)
val /= cs[i + 1 + k];
prob += val;
}
backward(i, state) = prob;
}
}
return make_tuple(cs, forward, backward);
}