StorageElement.java 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. package classes;
  2. import com.google.gson.annotations.Expose;
  3. import ui.model.Model;
  4. public class StorageElement extends HolonElement implements Comparable<StorageElement> {
  5. @Expose
  6. private Mode status;
  7. @Expose
  8. private float stateOfCharge;
  9. @Expose
  10. private float capacity;
  11. @Expose
  12. private float maxInRatio;
  13. @Expose
  14. private float maxOutRatio;
  15. @Expose
  16. private float chargingRatio;
  17. @Expose
  18. private resistanceCalculator resistanceCalculator;
  19. public StorageElement(String eleName, int amount, float energy, Model model, float capacity, float maxInRatio, float maxOutRatio) {
  20. super(eleName, amount, energy, model);
  21. this.stateOfCharge = 0;
  22. this.maxInRatio = maxInRatio;
  23. this.maxOutRatio = maxOutRatio;
  24. this.capacity = capacity * 60;// we save in watts per minute for ease of use
  25. this.status = Mode.STANDBY;
  26. this.chargingRatio = 0;
  27. this.resistanceCalculator = new resistanceCalculator(230, 20000,10, 25, 0.017, 0.017);//TODO
  28. }
  29. public float getEnergyPerElement() {
  30. if (status == Mode.STANDBY) {
  31. return 0;
  32. }
  33. return this.energyPerElement;
  34. }
  35. public float getPossibleProduction(float energyRequiredForPowerplantBlackstart) {
  36. if (stateOfCharge > 0) {
  37. if (stateOfCharge >= maxOutRatio) {
  38. return energyAfterResistance(maxOutRatio, energyRequiredForPowerplantBlackstart);
  39. } else {
  40. return energyAfterResistance(stateOfCharge, energyRequiredForPowerplantBlackstart);
  41. }
  42. } else {
  43. return 0;
  44. }
  45. }
  46. private float energyAfterResistance(float energy, float energyRequiredForPowerplantBlackstart){
  47. return resistanceCalculator.calcEnergyAfterResistance(energy, getLowDistance(), getHighDistance(), energyRequiredForPowerplantBlackstart);
  48. }
  49. /**
  50. *
  51. * @param status Mode of currect operation
  52. * @param energyWanted float how much energy is needed from storage/ can be collected
  53. * by the storage
  54. * @return float how much energy was collected/emited
  55. */
  56. public float setStatusAndSetEnergy(Mode status, float energyWanted, float energyRequiredForPowerplantBlackstart) {
  57. float energyNeed = resistanceCalculator.calcEnergyNeededForCertainEnergyAfterResistance(energyWanted, getLowDistance(), getHighDistance(), energyRequiredForPowerplantBlackstart);
  58. this.status = status;
  59. switch (status) {
  60. case STANDBY:
  61. this.setEnergyPerElement(0);
  62. chargingRatio = 0;
  63. return 0;
  64. case EMIT:
  65. if (energyNeed >= maxOutRatio) { // more energy wanted than can be giving
  66. if (stateOfCharge >= maxOutRatio) { // more energy wanted than can be given
  67. return emitWantedEnergy(maxOutRatio, energyRequiredForPowerplantBlackstart);
  68. }
  69. } else {// less wanted than what can be max be given
  70. if(stateOfCharge >= energyNeed){
  71. // return emitWantedEnergy(energyNeed, energyRequiredForPowerplantBlackstart);//zurueckrechnungs problem! float nicht genau genug
  72. this.setEnergyPerElement(energyWanted);
  73. chargingRatio = energyNeed;
  74. return energyWanted;
  75. }
  76. }
  77. return notEnoughChargedToEmitWantedEnergy(energyRequiredForPowerplantBlackstart);
  78. case COLLECT://TODO: more testing IGNORES resistanceses!
  79. if (energyWanted >= maxInRatio) { // more engery given than can be collected
  80. if (stateOfCharge + maxInRatio > capacity) { // Storage nearly full only load rest to get full
  81. this.setEnergyPerElement(-(capacity - stateOfCharge));
  82. chargingRatio = -(capacity - stateOfCharge);
  83. return capacity - stateOfCharge;
  84. } else { // load with maximal of what can be collected
  85. this.setEnergyPerElement(-maxInRatio);
  86. chargingRatio = -maxInRatio;
  87. return maxInRatio;
  88. }
  89. } else { // less engery given than can be taken in
  90. if (capacity == stateOfCharge) { // storage full no energy collected
  91. this.status = Mode.STANDBY;
  92. chargingRatio = 0;
  93. return 0;
  94. } else {
  95. if (stateOfCharge + energyWanted > capacity) { // Storage nearly full only load rest to get full
  96. this.setEnergyPerElement(-(capacity - stateOfCharge));
  97. chargingRatio = -(capacity - stateOfCharge);
  98. return capacity - stateOfCharge;
  99. } else { // take all engery that is available
  100. this.setEnergyPerElement(-energyWanted);
  101. chargingRatio = -energyWanted;
  102. return energyWanted;
  103. }
  104. }
  105. }
  106. default:
  107. System.out.println("no status available");
  108. return 0;
  109. }
  110. }
  111. public Mode getStatus() {
  112. return this.status;
  113. }
  114. public void stateOfChargeCalculation(){
  115. // System.out.println("stateofcharge" + getId()+ "before:" + stateOfCharge + " with incomming " + status + " after resi " + getEnergyPerElement() +" before resi "+ chargingRatio);
  116. switch (status){
  117. case COLLECT:
  118. case EMIT:
  119. stateOfCharge = stateOfCharge - chargingRatio;
  120. break;
  121. default:
  122. }
  123. //TODO: fix for gui error comment out bottom if (not sure if side effects should work since storage gets disabled every iteration)
  124. if(stateOfCharge <= 0 || stateOfCharge >= capacity){
  125. status = Mode.STANDBY;
  126. chargingRatio = 0;
  127. setEnergyPerElement(0);
  128. }
  129. // System.out.println("stateofcharge after:" + stateOfCharge + " now as " + status + " " + getEnergyPerElement() );
  130. }
  131. public void setStateOfCharge(float percentage){
  132. this.stateOfCharge = capacity * (percentage / 100);
  133. }
  134. private float notEnoughChargedToEmitWantedEnergy(float energyRequiredForPowerplantBlackstart){
  135. if(stateOfCharge <= 0){
  136. this.status = Mode.STANDBY;
  137. this.setEnergyPerElement(0);
  138. return 0;
  139. }else{
  140. return emitWantedEnergy(stateOfCharge, energyRequiredForPowerplantBlackstart);
  141. }
  142. }
  143. private float emitWantedEnergy(float maxEnergy, float energyRequiredForPowerplantBlackstart){
  144. float energyAfterResistance = energyAfterResistance(maxEnergy, energyRequiredForPowerplantBlackstart);
  145. this.setEnergyPerElement(energyAfterResistance);
  146. chargingRatio = maxEnergy;
  147. return energyAfterResistance;
  148. }
  149. public float getStateOfCharge() {
  150. return stateOfCharge;
  151. }
  152. public float getMaxOutRatio() {
  153. return maxOutRatio;
  154. }
  155. public boolean chargeDepleted(){
  156. return stateOfCharge <= 0;
  157. }
  158. public boolean fullyCharged(){
  159. return stateOfCharge >= capacity;
  160. }
  161. @Override
  162. public int compareTo(StorageElement storageElement) {
  163. if(this.stateOfCharge < storageElement.getStateOfCharge()){
  164. return -1;
  165. }else if(this.stateOfCharge > storageElement.getStateOfCharge()){
  166. return 1;
  167. }else{
  168. return Double.compare(storageElement.getLowDistance()+storageElement.getHighDistance(), this.getLowDistance()+this.getHighDistance());
  169. }
  170. }
  171. public enum Mode {
  172. COLLECT, EMIT, STANDBY
  173. }
  174. }