
org.reco4j.similarity.EuclideanSimilarity Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of reco4j-core Show documentation
Show all versions of reco4j-core Show documentation
Reco4j is an open source project aims at developing a recommendation framework based on graph data sources. We choose graph databases for several reasons. They are NoSQL databases, so "schemaless". This means that it is possible to extend the basic data structure with intermediate information, i.e. similarity value between item and so on. Moreover, since every information is expressed with properties, nodes and relations, the recommendation process can be customized to work on every graph.
Reco4j can be used on every graph where "user" and "item" is represented by node and the preferences are modelled as relationship between them.
Current implementation leverage on Neo4j as first graph database integrated in our framework.
The newest version!
/*
* EuclideanSimilarity.java
*
* Copyright (C) 2013 Alessandro Negro
*
* 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 .
*/
package org.reco4j.similarity;
import java.util.List;
import org.reco4j.graph.IEdge;
import org.reco4j.graph.IEdgeType;
import org.reco4j.graph.INode;
/**
*
* @author Alessandro Negro
*/
public class EuclideanSimilarity
extends BasicSimilarity
{
public EuclideanSimilarity(IEuclideanSimilarityConfig config)
{
super(config);
}
@Override
public double getSimilarity(INode x, INode y, IEdgeType edgeType)
{
int commonItems = 0;
double sim = 0.0;
List inEdges = x.getInEdge(edgeType);
for (IEdge edge : inEdges)
{
IEdge otherRating = edge.getSource().getEdge(y, edgeType);
if (otherRating != null)
{
commonItems++;
String propertyName = getConfig().getEdgeRankValueName();
double edgeRating = Double.parseDouble(edge.getProperty(propertyName));
double otherEdgeRating = Double.parseDouble(otherRating.getProperty(propertyName));
sim += Math.pow(edgeRating - otherEdgeRating, 2);
}
}
if (commonItems > 0)
{
sim = Math.sqrt(sim/(double)commonItems);
sim = 1.0 - Math.tanh(sim);
}
return sim;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy