/**
* Copyright (c) 2011-2014, OpenIoT
*
* This file is part of OpenIoT.
*
* OpenIoT is free software: you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License as published by the Free
* Software Foundation, version 3 of the License.
*
* OpenIoT 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 Lesser General Public License for more
* details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with OpenIoT. If not, see <http://www.gnu.org/licenses/>.
*
* Contact: OpenIoT mailto: info@openiot.eu
*/
package org.openiot.cupus.topkw;
import java.io.Serializable;
import java.util.LinkedList;
import java.util.ListIterator;
import org.openiot.cupus.artefact.MemorizedPublication;
/**
*
* @author Krešimir Pripužić <kpripuzic at gmail.com>
*/
public class FastSkyline implements Serializable {
private LinkedList<MemorizedPublication> MemorizedPublications;
public FastSkyline() {
this.MemorizedPublications = new LinkedList<MemorizedPublication>();
}
public int getNumDominators(MemorizedPublication p) {
int n = 0;
ListIterator<MemorizedPublication> i = MemorizedPublications.listIterator();
while (i.hasNext()) {
MemorizedPublication j = i.next();
if (j.getRelevance() > p.getRelevance()) {
if (j.getExpiry() > p.getExpiry()) {
n++;
} else {
break;
}
while (i.hasNext()) {
j = i.next();
if (j.getExpiry() > p.getExpiry()) {
n++;
} else {
break;
}
}
break;
}
}
return n;
}
public void add(MemorizedPublication p) {
ListIterator<MemorizedPublication> i = MemorizedPublications.listIterator();
while (i.hasNext()) {
MemorizedPublication j = i.next();
if (j.getExpiry() < p.getExpiry()) {
i.set(p);
i.add(j);
return;
}
}
MemorizedPublications.addLast(p);
}
public void remove(MemorizedPublication p) {
MemorizedPublications.remove(p);
}
public LinkedList<MemorizedPublication> pollDominated(MemorizedPublication p) {
LinkedList<MemorizedPublication> r = new LinkedList<MemorizedPublication>();
ListIterator<MemorizedPublication> i = MemorizedPublications.listIterator();
while (i.hasNext()) {
MemorizedPublication j = i.next();
if (j.getExpiry() < p.getExpiry()) {
if (j.getRelevance() < p.getRelevance()) {
i.remove();
r.add(j);
} else {
break;
}
while (i.hasNext()) {
j = i.next();
if (j.getRelevance() < p.getRelevance()) {
i.remove();
r.add(j);
} else {
break;
}
}
break;
}
}
return r;
}
}