FlexibilityManager.java 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. package classes.holonControlUnit;
  2. import java.util.ArrayList;
  3. import java.util.HashMap;
  4. import java.util.List;
  5. import java.util.stream.Collectors;
  6. import classes.Flexibility;
  7. import ui.controller.FlexManager;
  8. import ui.controller.FlexManager.FlexState;
  9. public class FlexibilityManager {
  10. private HolonControlUnit hcu;
  11. private HashMap<Integer, FlexManager> savesFlexManager;
  12. private int appliedFlexCounter;
  13. public FlexibilityManager(HolonControlUnit hcu) {
  14. this.hcu = hcu;
  15. this.savesFlexManager = new HashMap<>();
  16. this.appliedFlexCounter = 0;
  17. }
  18. public float applyFlexibilities(float currentPower, float requiredPower, ArrayList<Float> predictedPowerUsage, int timeStep) {
  19. FlexManager fm = getFlexManager(timeStep);
  20. List<Flexibility> offeredFlexes = fm.getAllFlexWrapperWithState(FlexState.OFFERED).stream().map(fw -> fw.getFlex()).collect(Collectors.toList());
  21. List<List<Flexibility>> offeredPerm = getAllPermutations(offeredFlexes);
  22. HashMap<Float, List<Flexibility>> map = new HashMap<>();
  23. for(List<Flexibility> l : offeredPerm) {
  24. float pu = 0f;
  25. // ArrayList<Float> pus = new ArrayList<>();
  26. Float[] savings = new Float[predictedPowerUsage.size()];
  27. for(int i=0; i<savings.length; i++)
  28. savings[i] = 0f;
  29. for(Flexibility f : l) {
  30. pu += f.fulfillsConstrains() ? f.getElement().getEnergyPerElement() : 0f;
  31. if(Math.abs(pu) > Math.abs(requiredPower))
  32. break;
  33. for(int i=0; i<Math.min(savings.length, f.getDuration()); i++) {
  34. savings[i] = savings[i] + f.bringtmir();
  35. // savings[i] = savings[i] + (f.fulfillsConstrains() ? f.getElement().getEnergyPerElement() : 0f);
  36. }
  37. // if(!this.hcu.decreasesPowerUsage(List.of(savings), currentPower, predictedPowerUsage, requiredPower))
  38. // break;
  39. }
  40. if(this.hcu.decreasesPowerUsage(List.of(savings), currentPower, predictedPowerUsage, requiredPower)) {
  41. float s = 0f;
  42. for(int i=0; i<savings.length; i++)
  43. s += savings[i];
  44. s = s/savings.length; //average saving over the next time periods
  45. if(map.containsKey(s) && map.get(s).size() >= l.size())
  46. continue;
  47. map.put(s, l);
  48. }
  49. }
  50. float min = Float.MAX_VALUE;
  51. for(float f : map.keySet()) {
  52. if(Math.abs(requiredPower-f) < Math.abs(requiredPower-min)) {
  53. min = f;
  54. }
  55. }
  56. if(map.containsKey(min)) {
  57. fm.orderFlexFromList(map.get(min));
  58. // System.out.println(this.hcu.getHolon().getUniqueID()+" ordered flexes "+map.get(min));
  59. this.appliedFlexCounter += map.get(min).size();
  60. return min;
  61. }
  62. return 0f;
  63. }
  64. public FlexManager getFlexManager(int timeStep) {
  65. boolean doesFlexManagerExist = savesFlexManager.containsKey(timeStep);
  66. boolean createNew = !doesFlexManagerExist;
  67. FlexManager newFlexManager;
  68. if(createNew) {
  69. newFlexManager = new FlexManager(List.of(this.hcu.getHolon().getHolonObject()), timeStep, savesFlexManager.get(timeStep-1));
  70. if(doesFlexManagerExist) newFlexManager.orderFlexFromList(savesFlexManager.get(timeStep).getAllFlexesOrderedThisTimeStep());
  71. savesFlexManager.put(timeStep, newFlexManager);
  72. }else {
  73. newFlexManager = savesFlexManager.get(timeStep);
  74. }
  75. // System.out.println("+++++++++");
  76. // newFlexManager.getAllFlexWrapper().stream().forEach(fw -> System.out.print(fw.getFlex().name+" "+fw.getState()+", "));
  77. // System.out.println("\n+++++++++");
  78. return newFlexManager;
  79. }
  80. public void orderFlex(Flexibility flex, int timeStep) {
  81. // System.out.println(this.hcu.getHolon().getUniqueID()+" ordered flex "+flex);
  82. getFlexManager(timeStep).orderFlex(flex);
  83. }
  84. private <T> List<List<T>> getAllPermutations(List<T> set){
  85. List<List<T>> out = new ArrayList<List<T>>();
  86. for(int i=0; i<set.size(); i++) {
  87. for(int j=i; j<set.size(); j++) {
  88. List<T> l = new ArrayList<T>();
  89. l.addAll(set.subList(i, j+1));
  90. out.add(l);
  91. }
  92. }
  93. return out;
  94. }
  95. public int getAppliedFlexCounter() {
  96. return appliedFlexCounter;
  97. }
  98. }