StorageProductionController.java 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  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 double energyNeeded) {
  33. Collections.sort(storages, Collections.reverseOrder());
  34. // System.out.println("energy needed from storage" + energyNeeded);
  35. int storagesLeft = storages.size();
  36. double 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. double 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, double energyNeeded){
  74. double fitness = 0f;
  75. fitness = w1 * distanceFitness() + w2 * supplyFitness(energyNeeded) + w3 * holdMaxPowerFitness();
  76. System.out.println("Fitness score: " + fitness);
  77. }
  78. private double distanceFitness(){//TODO: nicht lieber mit wiederstand?
  79. double distancePenalty = 0;
  80. for (StorageElement ele : storages) {
  81. if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  82. if(ele.getStatus().equals(StorageElement.Mode.EMIT)) {
  83. distancePenalty += goodDistance(ele);
  84. }
  85. }
  86. }
  87. return distancePenalty;
  88. }
  89. private double goodDistance(StorageElement ele){
  90. if(avgDistance() < ele.getHighDistance() + ele.getLowDistance()){
  91. return produceTooMuch(ele);
  92. }else{
  93. return produceTooLittle(ele);
  94. }
  95. }
  96. private double produceTooMuch(StorageElement ele){
  97. if(avgUtilization() >= ele.getUtilization(energyRequiredForPowerplantBlackstart)){
  98. return 0;
  99. }else{
  100. return 1;
  101. }
  102. }
  103. private double produceTooLittle(StorageElement ele){
  104. if(avgUtilization() <= ele.getUtilization(energyRequiredForPowerplantBlackstart)){
  105. return 0;
  106. }else{
  107. return 1;
  108. }
  109. }
  110. private double avgDistance(){
  111. double totalDistance = 0;
  112. for (StorageElement ele : storages) {
  113. if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  114. totalDistance += ele.getHighDistance() + ele.getLowDistance();
  115. }
  116. }
  117. return totalDistance/activeStorages();
  118. }
  119. private double avgUtilization(){
  120. double totalUtilization = 0;
  121. for (StorageElement ele : storages) {
  122. if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  123. totalUtilization += ele.getUtilization(energyRequiredForPowerplantBlackstart);
  124. }
  125. }
  126. return totalUtilization/activeStorages();
  127. }
  128. private double activeStorages(){
  129. double activeStorages = 0;
  130. for (StorageElement ele : storages) {
  131. if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  132. activeStorages++;
  133. }
  134. }
  135. return activeStorages;
  136. }
  137. private double supplyFitness(double energyNeeded){
  138. double activeStoragePower = 0;
  139. for (StorageElement ele : storages) {
  140. if(ele.getStatus().equals(StorageElement.Mode.EMIT)) {
  141. activeStoragePower += ele.getEnergyPerElement();
  142. }
  143. }
  144. if((int) activeStoragePower + 1 < energyNeeded){
  145. return Math.pow(9000, 9000);//TODO:
  146. }else{
  147. return Math.abs(activeStoragePower - energyNeeded);
  148. }
  149. }
  150. private double holdMaxPowerFitness(){
  151. double couldNotHoldPower = 0;
  152. for (StorageElement ele : storages) {
  153. if(ele.getStatus().equals(StorageElement.Mode.EMIT)) {
  154. couldNotHoldPower += maxPowerNextIteration(ele);
  155. }
  156. }
  157. return couldNotHoldPower;
  158. }
  159. private double maxPowerNextIteration(StorageElement ele){
  160. if(ele.getStateOfCharge() - ele.getEnergyPerElement() >= ele.getCurrentMaxOutRatio()){//TODO:
  161. return 0;
  162. }else{
  163. return ele.getCurrentMaxOutRatio() - (ele.getStateOfCharge() - ele.getEnergyPerElement());
  164. }
  165. }
  166. // private float storageEnergy(StorageElement ele){
  167. // return ele.getStateOfCharge();
  168. // }
  169. //
  170. // private float totalEnergy(){
  171. // float energy = 0;
  172. // for (StorageElement ele : storages) {
  173. // if(ele.getStatus().equals(StorageElement.Mode.EMIT)){
  174. // energy = energy + storageEnergy(ele);
  175. // }
  176. // }
  177. // return energy;
  178. // }
  179. }