Collection correlations = ...;

粘自:http://stackoverflow.com/questions/8283439/mahout-recommender


The Apache Mahout Recommender Documentation mentions the following:

// Construct the list of pre-computed correlations
Collection <GenericItemSimilarity.ItemItemSimilarity>  correlations = ...;

I'm not sure how the actual construction is done in the above line. Can someone provide an example?

ItemSimilarity itemSimilarity  =  new GenericItemSimilarity(correlations);
share|improve this question
 
 
add comment

This example refers to the case where you have the similarities already computed, by the Hadoop job for example, and stored on the filesystem or database . As the constructor documentation reads:

A "generic" {@link ItemSimilarity} which takes a static list of precomputed item similarities and bases its responses on that alone. The values may have been precomputed offline by another process, stored in a file, and then read and fed into an instance of this class.

If you have tens of millions of recommendations or less, you can simply compute similarities on the fly and use the other GenericItemSimilarity constructor - GenericItemSimilarity(ItemSimilarity otherSimilarity, DataModel dataModel)

For example:

DataModel dataModel = new FileDataModel(new File("path://to/file.csv"));
ItemSimilarity itemSimilarity = new LogLikelihoodSimilarity(dataModel);
ItemSimilarity itemSimilarity = new GenericItemSimilarity(itemSimilarity, dataModel);
share|improve this answer
 
 
add comment
No problem. We won't show you that ad again. Why didn't you like it?
Oops! I didn't mean to do this.

There's no magic here, it's just suggesting you create a bunch of those ItemItemSimilarity objects, one for each item-item similarity that you know about.

Collection<GenericItemSimilarity.ItemItemSimilarity> correlations = 
  new ArrayList<GenericItemSimilarity.ItemItemSimilarity>();
correlations.add(new GenericItemSimilarity.ItemItemSimilarity(1, 2, 0.5));
...

You can make it this way or any other way you want.

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章