HolonControlUnit.java 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. package classes.holonControlUnit;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import classes.Holon;
  5. import classes.holonControlUnit.messages.Message;
  6. import classes.holonControlUnit.messages.StateMsg;
  7. import classes.holonControlUnit.messages.StateRequestMsg;
  8. public class HolonControlUnit {
  9. private Holon holon;
  10. private FlexibilityManager flexMan;
  11. private ForecastComputationUnit forecaster;
  12. private HierarchyControlUnit hierarchyController;
  13. private OptimizationManager optimizer;
  14. private StateEstimator stateEstimator;
  15. private TargetStateAssembler stateAssembler;
  16. private CommunicationModule communicator;
  17. private ArrayList<StateMsg> states;
  18. public HolonControlUnit(Holon h) {
  19. this.holon = h;
  20. this.hierarchyController = new HierarchyControlUnit(this);
  21. this.flexMan = new FlexibilityManager(this);
  22. this.forecaster = new ForecastComputationUnit(this);
  23. this.optimizer = new OptimizationManager(this);
  24. this.stateEstimator = new StateEstimator(this);
  25. this.stateAssembler = new TargetStateAssembler(this);
  26. this.communicator = new CommunicationModule(this);
  27. this.states = new ArrayList<StateMsg>();
  28. }
  29. public ArrayList<Holon> getSubHolon() {
  30. return this.holon.childHolons;
  31. }
  32. public void addSubHolon(Holon subHolon) {
  33. this.hierarchyController.addSubHolon(subHolon.getUniqueID());
  34. }
  35. public void addNewVirtualNeighbor(String virtualNeighbor) {
  36. this.hierarchyController.addVirtualNeighbor(virtualNeighbor);
  37. }
  38. public void addNewVirtualNeighbors(ArrayList<String> virtualNeighbor) {
  39. this.hierarchyController.addVirtualNeighbors(virtualNeighbor);
  40. }
  41. public Holon getHolon() {
  42. return holon;
  43. }
  44. public FlexibilityManager getFlexMan() {
  45. return flexMan;
  46. }
  47. public ForecastComputationUnit getForecaster() {
  48. return forecaster;
  49. }
  50. public HierarchyControlUnit getHierarchyController() {
  51. return hierarchyController;
  52. }
  53. public OptimizationManager getOptimizer() {
  54. return optimizer;
  55. }
  56. public StateEstimator getStateEstimator() {
  57. return stateEstimator;
  58. }
  59. public TargetStateAssembler getStateAssembler() {
  60. return stateAssembler;
  61. }
  62. public CommunicationModule getCommunicator() {
  63. return communicator;
  64. }
  65. public void computeState(int timeStep) {
  66. //compute current state
  67. this.stateEstimator.computeState(timeStep);
  68. //compute target state
  69. this.stateAssembler.assembleTargetState(timeStep);
  70. //evaluate optimization scheme
  71. this.optimizer.evaluateOptimizationScheme(timeStep);
  72. }
  73. public void receiveStateRequest(String sender, StateRequestMsg req) {
  74. int timeStep = req.getTimeStep();
  75. if(!sender.equals(this.hierarchyController.getSuperHolon()) || timeStep < 0)
  76. return;
  77. if(this.states.size() > timeStep) {
  78. String body = this.communicator.getGson().toJson(this.states.get(timeStep));
  79. this.communicator.sendMsg(sender, Message.Type.STATE, body);
  80. } else {
  81. computeState(timeStep);
  82. StateMsg stateMsg = new StateMsg(this.stateEstimator.getPowerUsage(), this.stateEstimator.getNetThroughput(),
  83. this.stateEstimator.getPredictedPowerUsage(), this.stateEstimator.getStateIndicator());
  84. //send current state to sender (super holon)
  85. String body = this.communicator.getGson().toJson(stateMsg);
  86. this.communicator.sendMsg(sender, Message.Type.STATE, body);
  87. this.states.add(stateMsg);
  88. }
  89. }
  90. public boolean matchPowerRange(float power, float des, ArrayList<Float> prePower, float threshold) {
  91. float diff = Math.abs(des - threshold * des);
  92. float tres = Math.max(10-threshold*10, diff); //otherwise the range could be 0
  93. if(power > des + tres || power < des - tres)
  94. return false;
  95. for(int i=0; i<prePower.size(); i++) {
  96. if(prePower.get(i) > des + tres || prePower.get(i) < des - tres)
  97. return false;
  98. }
  99. return true;
  100. }
  101. public boolean decreasesPowerUsage(float requiredPower, float powerUsage, List<Float> predictedPowerUsage) {
  102. if(Math.abs(powerUsage) > Math.abs(requiredPower))
  103. return false;
  104. for(int i=0; i<predictedPowerUsage.size(); i++) {
  105. if(Math.abs(predictedPowerUsage.get(i)) > Math.abs(requiredPower))
  106. return false;
  107. }
  108. return true;
  109. }
  110. }