1 | package agents.anac.y2015.group2;
|
---|
2 |
|
---|
3 | import java.util.ArrayList;
|
---|
4 | import java.util.Collections;
|
---|
5 | import java.util.HashMap;
|
---|
6 | import java.util.Iterator;
|
---|
7 | import java.util.LinkedList;
|
---|
8 |
|
---|
9 | class G2IssueSubSet {
|
---|
10 | ArrayList<String> issues;
|
---|
11 | LinkedList<G2SubBid> subBids;
|
---|
12 |
|
---|
13 | G2IssueSubSet (String issue, LinkedList<G2SubBid> subBids) {
|
---|
14 | issues = new ArrayList<String>(1);
|
---|
15 | issues.add(issue);
|
---|
16 |
|
---|
17 | this.subBids = subBids;
|
---|
18 | }
|
---|
19 |
|
---|
20 | G2IssueSubSet(G2IssueSubSet one, G2IssueSubSet two) {
|
---|
21 | issues = new ArrayList<String>(one.issues.size() + two.issues.size());
|
---|
22 | issues.addAll(one.issues);
|
---|
23 | issues.addAll(two.issues);
|
---|
24 |
|
---|
25 | subBids = new LinkedList<G2SubBid>();
|
---|
26 | for(G2SubBid bidOne : one.subBids) {
|
---|
27 | for(G2SubBid bidTwo : two.subBids) {
|
---|
28 | subBids.add(new G2SubBid(bidOne, bidTwo));
|
---|
29 | }
|
---|
30 | }
|
---|
31 | }
|
---|
32 |
|
---|
33 | ArrayList<G2Bid> generateBids() {
|
---|
34 | ArrayList<G2Bid> bids = new ArrayList<G2Bid>();
|
---|
35 | for(G2SubBid subBid: subBids) {
|
---|
36 | HashMap<String, String> map = new HashMap<String, String>();
|
---|
37 | for(int i=issues.size()-1;i>=0; i--) {
|
---|
38 | map.put(issues.get(i), subBid.getValue(i));
|
---|
39 | }
|
---|
40 | bids.add(new G2Bid(map));
|
---|
41 | }
|
---|
42 | return bids;
|
---|
43 | }
|
---|
44 |
|
---|
45 | void trimSubBids() {
|
---|
46 | Collections.sort(subBids);
|
---|
47 | Iterator<G2SubBid> iter = subBids.descendingIterator();
|
---|
48 | G2SubBid previous = null;
|
---|
49 |
|
---|
50 | while(iter.hasNext()) {
|
---|
51 | G2SubBid curr = iter.next();
|
---|
52 | if (!curr.hasHigherOtherUtilities(previous)) {
|
---|
53 | //System.out.println("Bid removed");
|
---|
54 | iter.remove();
|
---|
55 | }
|
---|
56 | previous = curr;
|
---|
57 | }
|
---|
58 | }
|
---|
59 | } |
---|