FlexibilityManager.java 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  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. Float[] savings = new Float[predictedPowerUsage.size()];
  26. for(int i=0; i<savings.length; i++)
  27. savings[i] = 0f;
  28. for(Flexibility f : l) {
  29. pu += f.fulfillsConstrains() ? f.getElement().getEnergyPerElement() : 0f;
  30. if(Math.abs(pu) > Math.abs(requiredPower))
  31. break;
  32. for(int i=0; i<Math.min(savings.length, f.getDuration()); i++) {
  33. savings[i] = savings[i] + f.bringtmir();
  34. }
  35. }
  36. if(this.hcu.decreasesPowerUsage(List.of(savings), currentPower, predictedPowerUsage, requiredPower)) {
  37. float s = 0f;
  38. for(int i=0; i<savings.length; i++)
  39. s += savings[i];
  40. s = s/savings.length; //average saving over the next time periods
  41. if(map.containsKey(s) && map.get(s).size() >= l.size())
  42. continue;
  43. map.put(s, l);
  44. }
  45. }
  46. float min = Float.MAX_VALUE;
  47. for(float f : map.keySet()) {
  48. if(Math.abs(requiredPower-f) < Math.abs(requiredPower-min)) {
  49. min = f;
  50. }
  51. }
  52. if(map.containsKey(min)) {
  53. fm.orderFlexFromList(map.get(min));
  54. this.appliedFlexCounter += map.get(min).size();
  55. return min;
  56. }
  57. return 0f;
  58. }
  59. public FlexManager getFlexManager(int timeStep) {
  60. boolean doesFlexManagerExist = savesFlexManager.containsKey(timeStep);
  61. boolean createNew = !doesFlexManagerExist;
  62. FlexManager newFlexManager;
  63. if(createNew) {
  64. newFlexManager = new FlexManager(List.of(this.hcu.getHolon().getHolonObject()), timeStep, savesFlexManager.get(timeStep-1));
  65. if(doesFlexManagerExist) newFlexManager.orderFlexFromList(savesFlexManager.get(timeStep).getAllFlexesOrderedThisTimeStep());
  66. savesFlexManager.put(timeStep, newFlexManager);
  67. }else {
  68. newFlexManager = savesFlexManager.get(timeStep);
  69. }
  70. return newFlexManager;
  71. }
  72. public void orderFlex(Flexibility flex, int timeStep) {
  73. getFlexManager(timeStep).orderFlex(flex);
  74. }
  75. private <T> List<List<T>> getAllPermutations(List<T> set){
  76. List<List<T>> out = new ArrayList<List<T>>();
  77. for(int i=0; i<set.size(); i++) {
  78. for(int j=i; j<set.size(); j++) {
  79. List<T> l = new ArrayList<T>();
  80. l.addAll(set.subList(i, j+1));
  81. out.add(l);
  82. }
  83. }
  84. return out;
  85. }
  86. public int getAppliedFlexCounter() {
  87. return appliedFlexCounter;
  88. }
  89. public int getAmountFlexesForState(int timeStep, FlexState state) {
  90. return getFlexManager(timeStep).getAllFlexWrapperWithState(state).stream().map(fw -> fw.getFlex()).collect(Collectors.toList()).size();
  91. }
  92. }