/* * Copyright (C) 2016 RankSys http://ranksys.org * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ package org.ranksys.fm.learner; import es.uam.eps.ir.ranksys.fast.index.FastItemIndex; import es.uam.eps.ir.ranksys.fast.index.FastUserIndex; import es.uam.eps.ir.ranksys.fast.preference.FastPreferenceData; import org.ranksys.fm.data.BPRPreferenceFMData; import org.ranksys.javafm.data.FMData; import org.ranksys.javafm.learner.FMLearner; import org.ranksys.javafm.learner.gd.BPR; /** * Learner for PreferenceFMs using Bayesian Probabilistic Ranking. * * @author Saúl Vargas (Saul@VargasSandoval.es) */ public class BPRLearner<U, I> extends PreferenceFMLearner<U, I> { private final double learnRate; private final int numIter; private final double[] regW; private final double[] regM; /** * Constructor. * * @param learnRate learning rate (shrinkage) * @param numIter number of iterations * @param regW regularisation parameter for the feature biase * @param regM regularisation parameter for factorisation * @param users user index * @param items item index */ public BPRLearner(double learnRate, int numIter, double regW, double regM, FastUserIndex<U> users, FastItemIndex<I> items) { super(users, items); this.learnRate = learnRate; this.numIter = numIter; this.regW = vectorise(regW); this.regM = vectorise(regM); } @Override protected FMLearner<FMData> getLearner() { return new BPR(learnRate, numIter, regW, regM); } @Override protected FMData toFMData(FastPreferenceData<U, I> preferences) { return new BPRPreferenceFMData(preferences); } }