Estou apenas tentando implementar o algoritmo de Baum-Welch em escala e encontrei um problema em que minhas variáveis anteriores, após a escala, ultrapassam o valor de 1. Isso é normal? Afinal, as probabilidades não devem exceder 1.
Estou usando o fator de escala que obtive das variáveis avançadas:
Para o algoritmo backward, eu o implementei em java abaixo:
public double[][] backwardAlgo(){
int time = eSequence.size();
double beta[][] = new double[2][time];
// Intialize beta for current time
for(int i = 0; i < 2; i++){
beta[i][time-1] = scaler[time-1];
}
// Use recursive method to calculate beta
double tempBeta = 0;
for(int t = time-2; t >= 0; t--){
for(int i = 0; i < 2; i++){
for(int j = 0; j < 2; j++){
tempBeta = tempBeta + (stateTransitionMatrix[i][j] * emissionMatrix[j][eSequence.get(t+1)] * beta[j][t+1]);
}
beta[i][t] = tempBeta;
beta[i][t] = scaler[t] * beta[i][t];
tempBeta = 0;
}
}
return beta;
}
As escalas são armazenadas na matriz chamada scaler. Existem 2 estados neste hmm. Devo também observar que os fatores de escala que estou obtendo também ultrapassam 1.
fonte