/******************************************************************************* * Copyright 2012 University of Southern California * * 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. * * This code was developed by the Information Integration Group as part * of the Karma project at the Information Sciences Institute of the * University of Southern California. For more information, publications, * and related projects, please see: http://www.isi.edu/integration ******************************************************************************/ package edu.isi.karma.modeling.alignment; import edu.isi.karma.modeling.ModelingParams; public class LinkFrequency implements Comparable<LinkFrequency> { public LinkFrequency(String linkUri, int type, int count) { this.linkUri = linkUri; this.type = type; this.count = count; } private String linkUri; private int type; private int count; public String getLinkUri() { return linkUri; } public double getWeight() { double weight = 0.0; double w = ModelingParams.PROPERTY_DIRECT_WEIGHT; double epsilon = ModelingParams.PATTERN_LINK_WEIGHT; // double factor = 0.01; int c = this.count < (int)w ? this.count : (int)w - 1; if (type == 1) // match domain, link, and range weight = w - (epsilon / (w - c)); else if (type == 2) // match link and range weight = w - (epsilon / ((w - c) * w)); else if (type == 3) // match domain and link weight = w - (epsilon / ((w - c) * w)); else if (type == 4) // match link weight = w - (epsilon / ((w - c) * w * w)); else if (type == 5) // direct property weight = w; else if (type == 6) // indirect property weight = w + epsilon - (epsilon / (w - c)); else if (type == 7) // property with only domain weight = w + epsilon + (epsilon / ((w - c) * w)); else if (type == 8) // property with only range weight = w + epsilon + (epsilon / ((w - c) * w)); else if (type == 9) // subClass weight = w + epsilon + (epsilon / ((w - c) * w * w)); else if (type == 10) // property without domain and range weight = w + epsilon + (epsilon / ((w - c) * w * w * w)); return weight; } @Override public int compareTo(LinkFrequency o) { if (linkUri == null && o.linkUri != null) return -1; else if (linkUri != null && o.linkUri == null) return 1; else if (linkUri == null && o.linkUri == null) return 0; else { if (type < o.type) return 1; else if (type > o.type) return -1; else { if (count >= o.count) return 1; else return -1; } } } }