DrawTests.java 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. package tests;
  2. import java.sql.PreparedStatement;
  3. import java.sql.SQLException;
  4. import java.time.LocalDate;
  5. import java.time.LocalDateTime;
  6. import java.time.format.DateTimeFormatter;
  7. import java.util.ArrayList;
  8. import data.GuiMysql;
  9. import objects.League;
  10. import objects.SoccerMatch;
  11. import objects.TeamResults;
  12. public class DrawTests extends TestClass {
  13. private League leagueInfo;
  14. @Override public void setup(String date, float startingBank, float bettingLevel, Float betMargin, int lookBack, int sportId, Integer countryId,
  15. Integer leagueId) {
  16. super.setup(date, startingBank, bettingLevel, betMargin, lookBack, sportId, countryId, leagueId);
  17. leagueInfo = getLeagueInfoById();
  18. }
  19. @Override public void runTest() {
  20. final ArrayList<SoccerMatch> matches = getMatches();
  21. final float betLevel = bettingLevel / 100f;
  22. final LocalDateTime currentDate = matches.get(0).getGameDate();
  23. LocalDate localDate = currentDate.toLocalDate();
  24. float betAmount = startingBank * betLevel;
  25. int betOnGameCount = 0;
  26. int wins = 0;
  27. float bestBankResult = startingBank;
  28. int bestBetMargin = 0;
  29. int bestLookBack = 0;
  30. for (int lookBack = 4; lookBack < 25; lookBack++) {
  31. for (int betMargin = 1; betMargin < 35; betMargin++) {
  32. final float betMarginDecimal = 1 + (betMargin / (float) 100);
  33. float bank = startingBank;
  34. betOnGameCount = 0;
  35. wins = 0;
  36. for (final SoccerMatch match : matches) {
  37. if (match.getHomeScore() < 0 || match.getAwayScore() < 0) {
  38. continue;
  39. }
  40. final TeamResults homeTeamResults = GuiMysql.getInstance().getTeamResultsTest(match.getHomeTeam().getTeamId(), lookBack, true,
  41. match.getGameDate().format(DateTimeFormatter.ISO_DATE));
  42. final TeamResults awayTeamResults = GuiMysql.getInstance().getTeamResultsTest(match.getAwayTeam().getTeamId(), lookBack, false,
  43. match.getGameDate().format(DateTimeFormatter.ISO_DATE));
  44. final float drawPercent = (homeTeamResults.getDraws() + awayTeamResults.getDraws())
  45. / Float.valueOf(homeTeamResults.getCount() + awayTeamResults.getCount()) * 100;
  46. final float drawOdds = 100 / drawPercent;
  47. if (localDate.isBefore(match.getGameDate().toLocalDate())) {
  48. betAmount = bank * betLevel;
  49. localDate = match.getGameDate().toLocalDate();
  50. }
  51. if (drawOdds * betMarginDecimal <= match.getOddsX()) {
  52. betOnGameCount++;
  53. bank = bank - betAmount;
  54. if (match.getHomeScore() == match.getAwayScore()) {
  55. wins++;
  56. bank = bank + betAmount * match.getOddsX();
  57. }
  58. }
  59. }
  60. if (bestBankResult < bank) {
  61. System.out.println("New best bank " + bank + " with lookback " + lookBack + " and betMargin " + betMargin + " Bet on "
  62. + betOnGameCount + " of " + matches.size() + "(" + betOnGameCount / (float) matches.size() + ") wins " + wins + "("
  63. + wins / Float.valueOf(betOnGameCount) + ")" + " Win / game " + (bank - startingBank) / Float.valueOf(wins) + " kr");
  64. bestBetMargin = betMargin;
  65. bestLookBack = lookBack;
  66. bestBankResult = bank;
  67. } else {
  68. System.out.println("NOT BEST bank " + bank + " with lookback " + lookBack + " and betMargin " + betMargin + " Bet on "
  69. + betOnGameCount + " of " + matches.size() + "(" + betOnGameCount / (float) matches.size() + ") wins " + wins + "("
  70. + wins / Float.valueOf(betOnGameCount) + ")" + " Win / game " + (bank - startingBank) / Float.valueOf(wins) + " kr");
  71. }
  72. }
  73. }
  74. }
  75. public ArrayList<SoccerMatch> getMatches() {
  76. final ArrayList<SoccerMatch> result = new ArrayList<>();
  77. final String sql = "SELECT res.*, " + "hTeam.name as homeTeamName, aTeam.name as awayTeamName " + "FROM SoccerResults as res "
  78. + "Join Team as hTeam ON res.homeTeam = hTeam.id " + "Join Team as aTeam ON res.awayTeam = aTeam.id " + "WHERE " + "res.leagueId = ? "
  79. + "ORDER BY gameDate ASC";
  80. try {
  81. final PreparedStatement stat = getConnection().prepareStatement(sql);
  82. stat.setInt(1, leagueId);
  83. result.addAll(getMatches(stat));
  84. } catch (final SQLException e) {
  85. e.printStackTrace();
  86. }
  87. return result;
  88. }
  89. }