首页>代码>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; } }
最近下载更多
Rainbowsea LV1
11月10日
yangchengshuai LV15
10月24日
yxzzxy LV3
2月18日
zcc123276388 LV1
2023年12月29日
小谢xxxxxxx LV4
2023年5月23日
Boss绝 LV9
2023年4月10日
Numpile LV3
2023年2月16日
568885778 LV12
2023年2月13日
LITIANYU084414 LV11
2023年1月1日
1029162867 LV13
2022年11月12日
最近浏览更多
Rainbowsea LV1
11月8日
yangchengshuai LV15
10月24日
13680889751 LV1
6月29日
微信网友_7058156275650560 LV1
6月29日
TY0165 LV20
6月24日
zzgzzg99
5月20日
暂无贡献等级
李俊雄 LV3
5月8日
kQWERTY
5月4日
暂无贡献等级
a2831244768 LV4
4月13日
玖零定制问题修复 LV34
4月4日