assert feature >= 0 && feature < featureCount;
int tailStart = feature + 1;
int tailSize = featureCount - feature - 1;
AVector utail = uprefs.subVector(tailStart, tailSize);
MutableSparseVector tails = MutableSparseVector.create(ratings.keySet());
for (VectorEntry e: tails.view(VectorEntry.State.EITHER)) {
AVector ivec = model.getItemVector(e.getKey());
if (ivec == null) {
// FIXME Do this properly
tails.set(e, 0);
} else {
ivec = ivec.subVector(tailStart, tailSize);
tails.set(e, utail.dotProduct(ivec));
}
}
double rmse = Double.MAX_VALUE;
TrainingLoopController controller = rule.getTrainingLoopController();