首页>代码>ssm开发混合音乐推荐系统>/trackstacking/src/main/java/top/wangruns/trackstacking/algorithm/CollaborativeFiltering.java
package top.wangruns.trackstacking.algorithm; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.function.Consumer; public class CollaborativeFiltering { /** * 基于最近邻用户产生协同过滤的推荐结果 * @param userIdList * 用户Id列表 * @param userKNNMatrix * 用户KNN矩阵 * @param user2songRatingMatrix * 用户歌曲“评分”矩阵 * @param songIdList * 歌曲Id列表 * @param n * 推荐的前n首歌曲 * @return * 用户歌曲推荐结果矩阵.userId,[recSongId1,recSongId2...recSongIdn] */ public static Map<Integer, Integer[]> userKNNBasedCF(List<Integer> userIdList, final Map<Integer, Integer[]> userKNNMatrix, final Map<Integer, float[]> user2songRatingMatrix, final List<Integer> songIdList, final int n) { // TODO Auto-generated method stub final Map<Integer,Integer[]> user2songRecMatrix=new HashMap<Integer, Integer[]>(); userIdList.forEach(new Consumer<Integer>() { public void accept(Integer curUserId) { // TODO Auto-generated method stub Integer[] knnIdArray=userKNNMatrix.get(curUserId); /** * 对于每一首当前用户没有听过的歌曲 * 协同得分为: * 其k个最近邻用户对该歌曲的“评分”的聚合 */ float[] curUserRatings=user2songRatingMatrix.get(curUserId); //为用户建立一个最小堆来存放最高的前n首歌曲 MininumHeap mininumHeap=new MininumHeap(n); for(int i=0;i<curUserRatings.length;i++) { //对于没有听过的歌曲 /** * 这里需要注意的是,浮点数不能用==来比较...之前竟然犯了这个低级的错误... * 故这里用 curUserRatings[i]<0.01f 来表示 curUserRatings[i]==0f */ if(curUserRatings[i]<0.01f) { for(int knnIndex=0;knnIndex<knnIdArray.length;knnIndex++) { int knnId=knnIdArray[knnIndex]; float[] knnUserRatings=user2songRatingMatrix.get(knnId); curUserRatings[i]+=knnUserRatings[i]; } //这里的聚合策略取均值 curUserRatings[i]/=knnIdArray.length; int curSongId=songIdList.get(i); //放入堆中 mininumHeap.addElement(new TreeNode(curSongId,curUserRatings[i])); } } /** * 对该用户没有听过的歌曲,协同得分完成,选取n个得分最高的项目作为推荐 */ int trueNumber=n; //如果推荐的歌曲少于计划推荐的n首(处理歌曲很少的情况) if(mininumHeap.getCurHeapSize()<n) { trueNumber=mininumHeap.getCurHeapSize(); } Integer[] curUserRecSongId=new Integer[trueNumber]; for(int i=0;i<trueNumber;i++) { int recSongId=mininumHeap.getArray()[i].id; curUserRecSongId[i]=recSongId; } user2songRecMatrix.put(curUserId, curUserRecSongId); } }); return user2songRecMatrix; } }

露无畏 LV13
1月6日
krispeng LV15
2024年12月18日
zolscy LV24
2024年11月28日
Rainbowsea LV1
2024年11月10日
yangchengshuai LV15
2024年10月24日
yxzzxy LV3
2024年2月18日
zcc123276388 LV1
2023年12月29日
小谢xxxxxxx LV4
2023年5月23日
Boss绝 LV10
2023年4月10日
Numpile LV3
2023年2月16日

lxllxllxlLXL LV1
5月7日
露无畏 LV13
1月6日
zolscy LV24
2024年11月28日
Rainbowsea LV1
2024年11月8日
yangchengshuai LV15
2024年10月24日
13680889751 LV1
2024年6月29日
微信网友_7058156275650560 LV1
2024年6月29日
TY0165 LV20
2024年6月24日
zzgzzg99
2024年5月20日
暂无贡献等级
李俊雄 LV3
2024年5月8日