J'essaie simplement de mettre en œuvre l'algorithme Baum-Welch mis à l'échelle et j'ai rencontré un problème où mes variables en arrière, après la mise à l'échelle, dépassent la valeur 1. Est-ce normal? Après tout, les probabilités ne devraient pas dépasser 1.
J'utilise le facteur d'échelle que j'ai obtenu à partir des variables directes:
Pour l'algorithme rétrograde, je l'ai implémenté en java ci-dessous:
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;
}
Les balances sont stockées dans le tableau appelé scaler. Il y a 2 états dans ce hmm. Je dois également noter que les facteurs d'échelle que j'obtiens sont également supérieurs à 1.
la source