package geniusweb.exampleparties.anaconda; import java.math.BigDecimal; import java.math.RoundingMode; import java.util.Collections; import java.util.Comparator; import java.util.LinkedList; import java.util.List; import geniusweb.issuevalue.Bid; import geniusweb.issuevalue.Domain; import geniusweb.profile.DefaultPartialOrdering; import geniusweb.profile.Profile; import geniusweb.profile.utilityspace.UtilitySpace; public class SimpleLinearOrdering implements UtilitySpace { private final Domain domain; private final List bids; // worst bid first, best bid last. SimpleLinearOrdering(Profile profile) { this(profile.getDomain(), getSortedBids(profile)); } SimpleLinearOrdering(Domain domain, List bids) { this.domain = domain; this.bids = bids; } @Override public String getName() { throw new UnsupportedOperationException(); } @Override public Domain getDomain() { return domain; } @Override public Bid getReservationBid() { throw new UnsupportedOperationException(); } @Override public BigDecimal getUtility(Bid bid) { if (bids.size() < 2 || !bids.contains(bid)) { return BigDecimal.ZERO; } // using 8 decimals, we have to pick something here return new BigDecimal(bids.indexOf(bid)).divide( new BigDecimal((bids.size() - 1)), 8, RoundingMode.HALF_UP); } public boolean contains(Bid bid) { return bids.contains(bid); } public List getBids() { return Collections.unmodifiableList(bids); } private static List getSortedBids(Profile profile) { if (!(profile instanceof DefaultPartialOrdering)) { throw new UnsupportedOperationException( "Only DefaultPartialOrdering supported"); } DefaultPartialOrdering prof = (DefaultPartialOrdering) profile; List bidslist = prof.getBids(); // NOTE sort defaults to ascending order, this is missing in docs. Collections.sort(bidslist, new Comparator() { @Override public int compare(Bid b1, Bid b2) { return prof.isPreferredOrEqual(b1, b2) ? 1 : -1; } }); return bidslist; } public SimpleLinearOrdering with(Bid bid, List worseBids) { int n = 0; while (n < bids.size() && worseBids.contains(bids.get(n))) n++; LinkedList newbids = new LinkedList(bids); newbids.add(n, bid); return new SimpleLinearOrdering(domain, newbids); } }