Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * KNNModelBuilder.java
   * 
   * Copyright (C) 2013 Alessandro Negro <alessandro.negro at reco4j.org>
   *
   * This program is free software: you can redistribute it and/or modify
   * it under the terms of the GNU General Public License as published by
   * the Free Software Foundation, either version 3 of the License, or
   * (at your option) any later version.
  *
  * This program is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  * GNU General Public License for more details.
  *
  * You should have received a copy of the GNU General Public License
  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
  */
 package org.reco4j.recommender.knn;
 

Author(s):
Luigi Giuri < luigi.giuri at reco4j.org >
 
 public class KNNModelBuilder
   implements IModelBuilder<KNNModel>
 {
   private static final Logger logger = Logger.getLogger(KNNModelBuilder.class.getName());
   //
   //
   private IEdgeType rankEdgeType;
   private boolean recalculateSimilarity;
   //
   private KNNModel model;
 
   public KNNModelBuilder(UserItemDataset userItemDatasetString itemIdentifierNodePropertyNameIEdgeType rankEdgeTypeISimilarity similarityFunctionIEdgeType similarityEdgeTypeboolean recalculateSimilarity)
   {
     this. = userItemDataset;
     this. = itemIdentifierNodePropertyName;
     this. = rankEdgeType;
     this. = similarityFunction;
     this. = similarityEdgeType;
     this. = recalculateSimilarity;
      = new KNNModel(itemIdentifierNodePropertyName);
   }
   
 
   public void setModelName(String modelName)
   {
     this..setName(modelName);
   }  
   
   @Override
   public KNNModel build()
   {
     return this.;
   }
 
   private void createKNN(ConcurrentHashMap<LongINodeitemList)
   {
     TimeReportUtility timeReport = new TimeReportUtility("createKNN");
 
 
     for (INode item : itemList.values())
     {
       timeReport.start();
       String itemId = item.getProperty();
       if (itemId == null)
         throw new RuntimeException("Items don't have the 'id' property!");
       HashMap<StringRatingknnRow = .getKnnRow(itemId);
       findNearestNeighbour(itemknnRow);
       //printKnnRow(itemId);
       timeReport.stop();
     }
     timeReport.printStatistics();
   }
 
   private void findNearestNeighbour(INode itemIEdgeType rankEdgeTypeHashMap<StringRatingknnRow)
   {
     findNearestNeighbour(itemrankEdgeTypeknnRowfalse);
   }
  private void findNearestNeighbour(INode itemIEdgeType rankEdgeTypeHashMap<StringRatingknnRowboolean rewrite)
  {
    .log(."foundNearestNeighbour: {0}, CommonNodes Size: " + nodesByInEdge.size(), item.getProperty());
    for (INode otherItem : nodesByInEdge.values())
    {
      String otherItemId = otherItem.getProperty();
      if (!rewrite && knnRow.get(otherItemId) != null)
        continue;
      if (itemId == null || itemId.isEmpty() || otherItemId == null || otherItemId.isEmpty())
        throw new RuntimeException("Items don't have the 'id' property!");
      if (itemId.equalsIgnoreCase(otherItemId))
        continue;
      double similarityValue = calculateSimilarity(itemotherItemrankEdgeType);
      if (similarityValue > 0)
      {
        knnRow.put(otherItemIdnew Rating(otherItemsimilarityValue));
        if (!rewrite)
        {
          HashMap<StringRatingotherKnnRow = .getKnnRow(otherItemId);
          otherKnnRow.put(itemIdnew Rating(itemsimilarityValue));
        }
      }
    }
    /*System.out.print(itemId + ":> ");
     for (String key : knnRow.keySet())
     System.out.print(key + "["+ knnRow.get(key).getRate() +"] ");
     System.out.println();*/
  }
  private double calculateSimilarity(INode itemINode otherItemIEdgeType rankEdgeType)
  {
//    IEdgeType similarityEdgeType = EdgeTypeFactory.getEdgeType(IEdgeType.EDGE_TYPE_SIMILARITY, getConfig().getGraphConfig());
    IEdge alreadyCalulatedEdge = null;
//    getConfig().getRecalculateSimilarity();
    {
      alreadyCalulatedEdge = item.getEdge(otherItem);
      if (alreadyCalulatedEdge != null
          && alreadyCalulatedEdge.getPermissiveProperty(.getName()) != null)
      {
        double value = Double.parseDouble(alreadyCalulatedEdge.getProperty(.getClass().getName()));
        return value;
      }
    }
    double similarityValue = .getSimilarity(itemotherItemrankEdgeType);
    //Introdurre una coda di valori da inserire per toglierla dal processo di calcolo
    {
      if (alreadyCalulatedEdge != null)
        alreadyCalulatedEdge.setProperty(.getName(), Double.toString(similarityValue));
      else
        item.addOutEdgeWithProperty(otherItem.getName(), Double.toString(similarityValue));
    }
    return similarityValue;
  }
  public void update(IEdge newEdgeint operation)
  {
    INode dest = newEdge.getDestination();  
    for (INode item : commonNodes.values())
    {
      if (itemId == null)
        throw new RuntimeException("Items don't have the 'id' property!");
      HashMap<StringRatingknnRow = .getKnnRow(itemId);
      findNearestNeighbour(itemknnRowtrue);
    }
  }
  public void setModel(KNNModel model)
  {
    this. = model;
  }
New to GrepCode? Check out our FAQ X