StorageProductionController.java 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. package ui.controller;
  2. import classes.StorageElement;
  3. import java.util.ArrayList;
  4. import java.util.Collections;
  5. public class StorageProductionController {
  6. private ArrayList<StorageElement> storages;
  7. private float energyRequiredForPowerplantBlackstart;
  8. public StorageProductionController(ArrayList<StorageElement> storages, float energyRequiredForPowerplantBlackstart) {
  9. this.storages = storages;
  10. this.energyRequiredForPowerplantBlackstart = energyRequiredForPowerplantBlackstart;
  11. }
  12. public float currentPossibleStorageProduction() {
  13. float possibleEnergy = 0;
  14. for (StorageElement so : storages) {
  15. possibleEnergy += so.getPossibleProduction(energyRequiredForPowerplantBlackstart);
  16. }
  17. return possibleEnergy;
  18. }
  19. // public float currentStorageProduction() {
  20. // float producedEnergy = 0;
  21. // for (StorageElement ele : storages) {
  22. // if (ele.getStatus().equals(StorageElement.Mode.EMIT)) {
  23. // // needed to no emit more than what is available
  24. // if(ele.getStateOfCharge() - ele.getEnergyPerElement() < 0){
  25. // ele.setEnergyPerElement(ele.getStateOfCharge());
  26. // }
  27. // producedEnergy += ele.getEnergyPerElement();
  28. // }
  29. // }
  30. // return producedEnergy;
  31. // }
  32. public void enableStorageDischarging(final float energyNeeded) {
  33. Collections.sort(storages, Collections.reverseOrder());
  34. // System.out.println("energy needed from storage" + energyNeeded);
  35. int storagesLeft = storages.size();
  36. float energyLeftToEnabled = energyNeeded;
  37. for (StorageElement se: storages) {
  38. if(!se.chargeDepleted()){
  39. energyLeftToEnabled = energyLeftToEnabled - se.setStatusAndSetEnergy(
  40. StorageElement.Mode.EMIT, energyLeftToEnabled /*/ storagesLeft*/, energyRequiredForPowerplantBlackstart);
  41. }
  42. storagesLeft = storagesLeft - 1;
  43. if(energyLeftToEnabled <= 0){
  44. System.out.println("enabled energy from storage");
  45. assessFitness(1,1,1,energyNeeded);
  46. return;
  47. }else if(storagesLeft <= 0){
  48. System.out.println("nicht genug enabled");
  49. }
  50. }
  51. }
  52. public void setAllStorageToStandy() {
  53. for (StorageElement se : storages) {
  54. se.setStatusAndSetEnergy(StorageElement.Mode.STANDBY, 0, energyRequiredForPowerplantBlackstart);
  55. }
  56. }
  57. //TODO: selbe probleme wie discharging
  58. void enableStorageCharging(float energyAvailable){
  59. Collections.sort(storages);
  60. System.out.println("energy available to storage" + energyAvailable);
  61. float availableEnergyLeft = energyAvailable;
  62. for (StorageElement se: storages) {
  63. if(!se.fullyCharged()){
  64. availableEnergyLeft = availableEnergyLeft - se.setStatusAndSetEnergy(
  65. StorageElement.Mode.COLLECT, availableEnergyLeft, energyRequiredForPowerplantBlackstart);
  66. }
  67. if(availableEnergyLeft <= 0){
  68. System.out.println("storage charging");
  69. return;
  70. }
  71. }
  72. }
  73. private void assessFitness(float w1, float w2, float w3, float energyNeeded){
  74. float fitness = 0f;
  75. fitness = w1 * distanceFitness() + w2 * supplyFitness(energyNeeded) + w3 * holdMaxPowerFitness();
  76. System.out.println("Fitness score: " + fitness);
  77. }
  78. private float distanceFitness(){//TODO: nicht lieber mit wiederstand?
  79. float distancePenalty = 0;
  80. for (StorageElement ele : storages) {
  81. if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  82. distancePenalty = goodDistance(ele);
  83. }
  84. }
  85. return distancePenalty;
  86. }
  87. private float goodDistance(StorageElement ele){
  88. if(avgDistance() < ele.getHighDistance() + ele.getLowDistance()){
  89. return produceTooMuch(ele);
  90. }else{
  91. return produceTooLittle(ele);
  92. }
  93. }
  94. private float produceTooMuch(StorageElement ele){
  95. if(avgUtilization() <= ele.getUtilization()){
  96. return 0;
  97. }else{
  98. return 1;
  99. }
  100. }
  101. private float produceTooLittle(StorageElement ele){
  102. if(avgUtilization() >= ele.getUtilization()){
  103. return 0;
  104. }else{
  105. return 1;
  106. }
  107. }
  108. private float avgDistance(){
  109. float totalDistance = 0;
  110. for (StorageElement ele : storages) {
  111. if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  112. totalDistance += ele.getHighDistance() + ele.getLowDistance();
  113. }
  114. }
  115. return totalDistance/activeStorages();
  116. }
  117. private float avgUtilization(){
  118. float totalUtilization = 0;
  119. for (StorageElement ele : storages) {
  120. if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  121. totalUtilization += ele.getUtilization();
  122. }
  123. }
  124. return totalUtilization/activeStorages();
  125. }
  126. private float activeStorages(){
  127. float activeStorages = 0;
  128. for (StorageElement ele : storages) {
  129. if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  130. activeStorages++;
  131. }
  132. }
  133. return activeStorages;
  134. }
  135. private float supplyFitness(float energyNeeded){
  136. int activeStoragePower = 0;
  137. for (StorageElement ele : storages) {
  138. if(ele.getStatus().equals(StorageElement.Mode.EMIT)) {
  139. activeStoragePower += ele.getEnergyPerElement();
  140. }
  141. }
  142. if(activeStoragePower < energyNeeded){
  143. return (float) Math.pow(9000, 9000);//TODO:
  144. }else{
  145. return activeStoragePower - energyNeeded;
  146. }
  147. }
  148. private float holdMaxPowerFitness(){
  149. float couldNotHoldPower = 0;
  150. for (StorageElement ele : storages) {
  151. if(ele.getStatus().equals(StorageElement.Mode.EMIT)) {
  152. couldNotHoldPower += maxPowerNextIteration(ele);
  153. }
  154. }
  155. return couldNotHoldPower;
  156. }
  157. private float maxPowerNextIteration(StorageElement ele){
  158. if(ele.getStateOfCharge() - ele.getEnergyPerElement() >= ele.getCurrentMaxOutRatio()){//TODO:
  159. return 0;
  160. }else{
  161. return (float) Math.pow(2, ele.getStateOfCharge() - ele.getEnergyPerElement());
  162. }
  163. }
  164. // private float storageEnergy(StorageElement ele){
  165. // return ele.getStateOfCharge();
  166. // }
  167. //
  168. // private float totalEnergy(){
  169. // float energy = 0;
  170. // for (StorageElement ele : storages) {
  171. // if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  172. // energy = energy + storageEnergy(ele);
  173. // }
  174. // }
  175. // return energy;
  176. // }
  177. }