StorageElement.java 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  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,30, 30, 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. //TODO: das beachtet nicht wie viel durch widerstand verloren geht
  57. public float setStatusAndSetEnergy(Mode status, float energyWanted, float energyRequiredForPowerplantBlackstart) {
  58. //TODO: stellen fuer energyNeed nochmal ueberdenken
  59. float energyNeed = resistanceCalculator.calcEnergyNeededForCertainEnergyAfterResistance(energyWanted, getLowDistance(), getHighDistance(), energyRequiredForPowerplantBlackstart);
  60. this.status = status;
  61. switch (status) {
  62. case STANDBY:
  63. this.setEnergyPerElement(0);
  64. chargingRatio = 0;
  65. return 0;
  66. case EMIT:
  67. if (energyNeed >= maxOutRatio) { // more energy wanted than can be giving
  68. if (stateOfCharge >= maxOutRatio) { // more energy wanted than can be given
  69. return emitWantedEnergy(maxOutRatio, energyRequiredForPowerplantBlackstart);
  70. }
  71. } else {// less wanted than what can be max be given
  72. if(stateOfCharge >= energyNeed){
  73. // return emitWantedEnergy(energyNeed, energyRequiredForPowerplantBlackstart);//zurueckrechnungs problem! float nicht genau genug
  74. this.setEnergyPerElement(energyWanted);
  75. chargingRatio = energyNeed;
  76. return energyWanted;
  77. }
  78. }
  79. return notEnoughChargedToEmitWantedEnergy(energyRequiredForPowerplantBlackstart);
  80. case COLLECT://TODO: more testing IGNORES resistanceses!
  81. if (energyWanted >= maxInRatio) { // more engery given than can be collected
  82. if (stateOfCharge + maxInRatio > capacity) { // Storage nearly full only load rest to get full
  83. this.setEnergyPerElement(-(capacity - stateOfCharge));
  84. chargingRatio = -(capacity - stateOfCharge);
  85. return capacity - stateOfCharge;
  86. } else { // load with maximal of what can be collected
  87. this.setEnergyPerElement(-maxInRatio);
  88. chargingRatio = -maxInRatio;
  89. return maxInRatio;
  90. }
  91. } else { // less engery given than can be taken in
  92. if (capacity == stateOfCharge) { // storage full no energy collected
  93. this.status = Mode.STANDBY;
  94. chargingRatio = 0;
  95. return 0;
  96. } else {
  97. if (stateOfCharge + energyWanted > capacity) { // Storage nearly full only load rest to get full
  98. this.setEnergyPerElement(-(capacity - stateOfCharge));
  99. chargingRatio = -(capacity - stateOfCharge);
  100. return capacity - stateOfCharge;
  101. } else { // take all engery that is available
  102. this.setEnergyPerElement(-energyWanted);
  103. chargingRatio = -energyWanted;
  104. return energyWanted;
  105. }
  106. }
  107. }
  108. default:
  109. System.out.println("no status available");
  110. return 0;
  111. }
  112. }
  113. public Mode getStatus() {
  114. return this.status;
  115. }
  116. public void stateOfChargeCalculation(){
  117. System.out.println("stateofcharge" + getId()+ "before:" + stateOfCharge + " with incomming " + status + " after resi " + getEnergyPerElement() +" before resi "+ chargingRatio);
  118. switch (status){
  119. case COLLECT:
  120. case EMIT:
  121. stateOfCharge = stateOfCharge - chargingRatio;
  122. break;
  123. default:
  124. }
  125. //TODO: fix for gui error comment out bottom if (not sure if side effects should work since storage gets disabled every iteration)
  126. if(stateOfCharge <= 0 || stateOfCharge >= capacity){
  127. status = Mode.STANDBY;
  128. chargingRatio = 0;
  129. setEnergyPerElement(0);
  130. }
  131. System.out.println("stateofcharge after:" + stateOfCharge + " now as " + status + " " + getEnergyPerElement() );
  132. }
  133. public void setStateOfCharge(float stateOfCharge){
  134. if(stateOfCharge < capacity){
  135. this.stateOfCharge = stateOfCharge;
  136. }else{
  137. this.stateOfCharge = capacity;
  138. }
  139. }
  140. private float notEnoughChargedToEmitWantedEnergy(float energyRequiredForPowerplantBlackstart){
  141. if(stateOfCharge <= 0){
  142. this.status = Mode.STANDBY;
  143. this.setEnergyPerElement(0);
  144. return 0;
  145. }else{
  146. return emitWantedEnergy(stateOfCharge, energyRequiredForPowerplantBlackstart);
  147. }
  148. }
  149. private float emitWantedEnergy(float maxEnergy, float energyRequiredForPowerplantBlackstart){
  150. float energyAfterResistance = energyAfterResistance(maxEnergy, energyRequiredForPowerplantBlackstart);
  151. this.setEnergyPerElement(energyAfterResistance);
  152. chargingRatio = maxEnergy;
  153. return energyAfterResistance;
  154. }
  155. public float getStateOfCharge() {
  156. return stateOfCharge;
  157. }
  158. public boolean chargeDepleted(){
  159. return stateOfCharge <= 0;
  160. }
  161. public boolean fullyCharged(){
  162. return stateOfCharge >= capacity;
  163. }
  164. @Override
  165. public int compareTo(StorageElement storageElement) {
  166. if(this.stateOfCharge < storageElement.getStateOfCharge()){
  167. return -1;
  168. }else if(this.stateOfCharge > storageElement.getStateOfCharge()){
  169. return 1;
  170. }else{
  171. return Double.compare(storageElement.getLowDistance()+storageElement.getHighDistance(), this.getLowDistance()+this.getHighDistance());
  172. }
  173. }
  174. public enum Mode {
  175. COLLECT, EMIT, STANDBY
  176. }
  177. }