Projektteil 2
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

EpizentrumRechnung.java 7.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. package de.edotzlaff.detection.detektion.berechnung;
  2. import android.os.Build;
  3. import androidx.annotation.RequiresApi;
  4. import com.google.common.collect.ImmutableSet;
  5. import com.google.common.collect.Sets;
  6. import de.edotzlaff.detection.detektion.Detektionssignal;
  7. import de.edotzlaff.detection.detektion.Epizentrum;
  8. import de.edotzlaff.detection.detektion.berechnung.mathObjekte.Koordinaten;
  9. import de.edotzlaff.detection.detektion.berechnung.mathObjekte.Kreis;
  10. import de.edotzlaff.detection.detektion.berechnung.mathObjekte.Schnittpunkt;
  11. import java.math.BigDecimal;
  12. import java.math.RoundingMode;
  13. import java.time.LocalDateTime;
  14. import java.util.ArrayList;
  15. import java.util.Set;
  16. public class EpizentrumRechnung {
  17. private static final double SCHRITTWEITE = 0.02;
  18. private static final double MAX_ABSTAND = 0.009;
  19. private static final int DOUBLESTELLEN = 8;
  20. @RequiresApi(api = Build.VERSION_CODES.O)
  21. public ArrayList<Endpunkt> initEndpunkte(ArrayList<Detektionssignal> detektionssignal) {
  22. Detektionssignal nahegelegensteMessung = detektionssignal.get(0);
  23. ArrayList<Endpunkt> arrBerechnungsObjekte = new ArrayList<>();
  24. for (int i = 1; i < detektionssignal.size(); i++) {
  25. if (detektionssignal.get(i).getAnkunftsZeit().isBefore(nahegelegensteMessung.getAnkunftsZeit())) {
  26. nahegelegensteMessung = detektionssignal.get(i);
  27. }
  28. }
  29. for (Detektionssignal aufzeichnung : detektionssignal) {
  30. int zeitunterschied = aufzeichnung.getAnkunftsZeit().getHour() * 3600 + aufzeichnung.getAnkunftsZeit().getMinute() * 60 + aufzeichnung.getAnkunftsZeit().getSecond()
  31. - nahegelegensteMessung.getAnkunftsZeit().getHour() * 3600 - nahegelegensteMessung.getAnkunftsZeit().getMinute() * 60 - nahegelegensteMessung.getAnkunftsZeit().getSecond();
  32. double startradius = zeitunterschied * aufzeichnung.getGeschwErdbeben();
  33. Endpunkt tempEndpunkt = new Endpunkt(aufzeichnung.getDeviceId());
  34. Kreis k = new Kreis(aufzeichnung.getKoordinaten().getX(), aufzeichnung.getKoordinaten().getY(), startradius);
  35. tempEndpunkt.setKreis(k);
  36. arrBerechnungsObjekte.add(tempEndpunkt);
  37. }
  38. return arrBerechnungsObjekte;
  39. }
  40. public ArrayList<Schnittpunkt> berechneKreisSchnittpunkte(Kreis kreis1, Kreis kreis2) {
  41. ArrayList<Schnittpunkt> schnittpunkte = new ArrayList<>();
  42. double dx = kreis2.getMittelPunkt().getX() - kreis1.getMittelPunkt().getX();
  43. double dy = kreis2.getMittelPunkt().getY() - kreis1.getMittelPunkt().getY();
  44. double c = Math.sqrt(Math.pow(dx, 2) + Math.pow(dy, 2));
  45. double x = ((Math.pow(kreis1.getRadius(), 2) + Math.pow(c, 2) - Math.pow(kreis2.getRadius(), 2))) / (2 * c);
  46. double y = Math.pow(kreis1.getRadius(), 2) - Math.pow(x, 2);
  47. //Kein Schnittpunkt vorhanden
  48. if (y < 0) {
  49. return schnittpunkte;
  50. }
  51. if (y > 0) {
  52. y = Math.sqrt(y);
  53. }
  54. double ex0 = dx / c;
  55. double ex1 = dy / c;
  56. double ey0 = -ex1;
  57. Schnittpunkt s1 = new Schnittpunkt(kreis1.getMittelPunkt().getX() + x * ex0,
  58. kreis1.getMittelPunkt().getY() + x * ex1);
  59. //Genau ein Schnittpunkt vorhanden
  60. if (y == 0) {
  61. schnittpunkte.add(s1);
  62. return schnittpunkte;
  63. }
  64. Schnittpunkt s2 = new Schnittpunkt(s1.getKoordinaten().getX() - y * ey0, s1.getKoordinaten().getY() - y * ex0);
  65. s1.getKoordinaten().setLocation(s1.getKoordinaten().getX() + y * ey0, s1.getKoordinaten().getY() + y * ex0);
  66. schnittpunkte.add(s1);
  67. schnittpunkte.add(s2);
  68. return schnittpunkte;
  69. }
  70. public boolean genuegendSchnittpunktevorhanden(ArrayList<EndpunktVerbindung> endpunktVerbindungen) {
  71. for (EndpunktVerbindung endpunktVerbindung : endpunktVerbindungen) {
  72. ArrayList<Schnittpunkt> templist;
  73. templist = berechneKreisSchnittpunkte(endpunktVerbindung.getEndpunkt1().getKreis(), endpunktVerbindung.getEndpunkt2().getKreis());
  74. if (templist.isEmpty()) {
  75. return false;
  76. }
  77. endpunktVerbindung.setSchnittpunkte(templist);
  78. }
  79. return true;
  80. }
  81. public Epizentrum ueberpruefeObEpizentrum(ArrayList<EndpunktVerbindung> endpunktVerbindungen) {
  82. int counter;
  83. ArrayList<Schnittpunkt> schnittpunkte = new ArrayList<>();
  84. for (Schnittpunkt s1 : endpunktVerbindungen.get(0).getSchnittpunkte()) {
  85. counter = 0;
  86. for (int i = 1; i < endpunktVerbindungen.size(); i++) {
  87. boolean bereitsSchnittpunktErmittelt = false;
  88. for (Schnittpunkt s2 : endpunktVerbindungen.get(i).getSchnittpunkte()) {
  89. double abstand = Math.sqrt(
  90. Math.pow(s2.getKoordinaten().getX() - s1.getKoordinaten().getX(), 2) +
  91. Math.pow(s2.getKoordinaten().getY() - s1.getKoordinaten().getY(), 2));
  92. if (abstand < MAX_ABSTAND && !bereitsSchnittpunktErmittelt) {
  93. bereitsSchnittpunktErmittelt = true;
  94. counter++;
  95. schnittpunkte.add(s2);
  96. }
  97. if (counter == endpunktVerbindungen.size() - 1) {
  98. schnittpunkte.add(s1);
  99. Epizentrum tempEpizentrum = new Epizentrum();
  100. tempEpizentrum.setKoordinaten(berechneEpizentrumKoordinaten(schnittpunkte));
  101. return tempEpizentrum;
  102. }
  103. }
  104. }
  105. }
  106. return null;
  107. }
  108. public Koordinaten berechneEpizentrumKoordinaten(ArrayList<Schnittpunkt> schnittpunkte) {
  109. double x = 0;
  110. double y = 0;
  111. for (Schnittpunkt s : schnittpunkte) {
  112. x+= s.getKoordinaten().getX();
  113. y+= s.getKoordinaten().getY();
  114. }
  115. return new Koordinaten(new BigDecimal(x/schnittpunkte.size()).setScale(DOUBLESTELLEN, RoundingMode.HALF_UP).doubleValue(),
  116. new BigDecimal(y/schnittpunkte.size()).setScale(DOUBLESTELLEN, RoundingMode.HALF_UP).doubleValue());
  117. }
  118. public ArrayList<EndpunktVerbindung> ermittleEndpunktKonbinationen(ArrayList<Endpunkt> tempBerechungsObjekte) {
  119. ArrayList<EndpunktVerbindung> verbindungen = new ArrayList<>();
  120. Set<Set<Endpunkt>> combinations = Sets.combinations(ImmutableSet.copyOf(tempBerechungsObjekte), 2);
  121. for (Set<Endpunkt> tempEndpunkt : combinations) {
  122. ArrayList<Endpunkt> helpArrayToGetValues = new ArrayList<>(tempEndpunkt);
  123. EndpunktVerbindung endpunktVerbindung = new EndpunktVerbindung(helpArrayToGetValues.get(0), helpArrayToGetValues.get(1));
  124. verbindungen.add(endpunktVerbindung);
  125. }
  126. return verbindungen;
  127. }
  128. @RequiresApi(api = Build.VERSION_CODES.O)
  129. public LocalDateTime berechneEntstehungsZeitpunkt(Detektionssignal detektionssignal, Koordinaten koordEpi) {
  130. double abstand = Math.sqrt(
  131. Math.pow(detektionssignal.getKoordinaten().getX() - koordEpi.getX(), 2) +
  132. Math.pow(detektionssignal.getKoordinaten().getY() - koordEpi.getY(), 2));
  133. int sec = (int) abstand/ detektionssignal.geschwErdbeben;
  134. return detektionssignal.getAnkunftsZeit().minusSeconds(sec);
  135. }
  136. public void erhoheRadius(ArrayList<Endpunkt> tempEndpunktListe) {
  137. for (Endpunkt b : tempEndpunktListe) {
  138. b.erhoeheRadius(SCHRITTWEITE);
  139. }
  140. }
  141. }