/**
* Copyright 2012 Anjuke Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.anjuke.romar.mahout.factory;
import java.io.File;
import org.apache.mahout.cf.taste.common.TasteException;
import org.apache.mahout.cf.taste.impl.recommender.GenericItemBasedRecommender;
import org.apache.mahout.cf.taste.impl.similarity.CachingItemSimilarity;
import org.apache.mahout.cf.taste.impl.similarity.GenericItemSimilarity;
import org.apache.mahout.cf.taste.impl.similarity.GenericItemSimilarity.ItemItemSimilarity;
import org.apache.mahout.cf.taste.model.DataModel;
import org.apache.mahout.cf.taste.recommender.Recommender;
import org.apache.mahout.cf.taste.similarity.ItemSimilarity;
import org.apache.mahout.common.ClassUtils;
import com.anjuke.romar.core.RomarConfig;
import com.anjuke.romar.mahout.MahoutService;
import com.anjuke.romar.mahout.RecommenderWrapper;
import com.anjuke.romar.mahout.similarity.ReadableGenericSimilarityProxy;
import com.anjuke.romar.mahout.similarity.ReadableSimilarity;
import com.anjuke.romar.mahout.similarity.RomarFileItemSimilarity;
import com.anjuke.romar.mahout.similarity.file.RomarFileSimilarityIterator;
import com.anjuke.romar.mahout.similarity.file.RomarFileSimilarityIterator.IteratorBuiler;
public class MahoutServiceItemRecommendFactory implements MahoutServiceFactory {
@Override
public MahoutService createService() {
RomarConfig config = RomarConfig.getInstance();
Recommender recommender;
DataModel dataModel = PersistenceDataModelFactory.createDataModel(config);
ItemSimilarity similarity;
if (config.isUseFileSimilarity()) {
File file = new File(config.getSimilarityFile());
if (!file.exists()) {
throw new IllegalArgumentException("similairy file not exists");
}
if (!file.isFile()) {
throw new IllegalArgumentException("similairy file is a directory");
}
IteratorBuiler<ItemItemSimilarity> iteratorBuilder;
if (config.isBinarySimilarityFile()) {
iteratorBuilder = RomarFileSimilarityIterator
.dataFileItemIteratorBuilder();
} else {
iteratorBuilder = RomarFileSimilarityIterator
.lineFileItemIteratorBuilder();
}
similarity = new RomarFileItemSimilarity(file, iteratorBuilder);
} else {
similarity = createSimilarity(config, dataModel);
if (config.isUseSimilariyCache()) {
similarity = new CachingItemSimilarity(similarity,
config.getSimilarityCacheSize());
}
}
recommender = new GenericItemBasedRecommender(dataModel, similarity);
return new RecommenderWrapper(recommender);
}
private ItemSimilarity createSimilarity(RomarConfig config, DataModel dataModel) {
ItemSimilarity similarity = ClassUtils.instantiateAs(
config.getItemSimilarityClass(), ItemSimilarity.class,
new Class<?>[] {DataModel.class}, new Object[] {dataModel});
return similarity;
}
@Override
public ReadableSimilarity createReadableSimilarity(DataModel dataModel) {
RomarConfig config = RomarConfig.getInstance();
ItemSimilarity similarity = createSimilarity(config, dataModel);
try {
return ReadableGenericSimilarityProxy
.proxySimilarity(new GenericItemSimilarity(similarity, dataModel));
} catch (TasteException e) {
throw new RuntimeException(e);
}
}
}