HyCodeYourTale
classpublicPriority 3

Splitter

com.hypixel.hytale.builtin.hytalegenerator.framework.math.Splitter

4

Methods

4

Public Methods

0

Fields

1

Constructors

Constructors

public
Splitter()

Methods

Public Methods (4)

publicstatic
Splitter.Range[] split(Splitter.Range range, int pieces)
@Nonnull
publicstatic
Splitter.Area[] split(Splitter.Area area, int pieces)
@Nonnull
publicstatic
Splitter.Area[] splitX(Splitter.Area area, int pieces)
@Nonnull
public
String toString()
@Nonnull@Override

Source Code

package com.hypixel.hytale.builtin.hytalegenerator.framework.math;

import javax.annotation.Nonnull;

public class Splitter {
   public Splitter() {
   }

   @Nonnull
   public static Splitter.Range[] split(@Nonnull Splitter.Range range, int pieces) {
      if (pieces < 0) {
         throw new IllegalArgumentException("negative number of pieces");
      } else {
         int size = range.max - range.min;
         int pieceSize = size / pieces;
         if (size % pieces > 0) {
            pieceSize++;
         }

         Splitter.Range[] output = new Splitter.Range[pieces];

         for (int i = 0; i < output.length; i++) {
            int min = Math.min(i * pieceSize + range.min, range.max);
            int max = Math.min(min + pieceSize, range.max);
            output[i] = new Splitter.Range(min, max);
         }

         return output;
      }
   }

   @Nonnull
   public static Splitter.Area[] split(@Nonnull Splitter.Area area, int pieces) {
      if (pieces < 1) {
         throw new IllegalArgumentException("negative number of pieces");
      } else if (pieces == 1) {
         return new Splitter.Area[]{area};
      } else {
         int sizeX = area.maxX - area.minX;
         int sizeZ = area.maxZ - area.minZ;
         if (pieces > sizeX) {
            pieces = sizeX;
         }

         Splitter.Area[] output = new Splitter.Area[pieces];
         if (pieces % 3 == 0) {
            Splitter.Range[] rangesX = split(new Splitter.Range(area.minX, area.maxX), 3);
            Splitter.Range[] rangesZ = split(new Splitter.Range(area.minZ, area.maxZ), pieces / 3);
            int o = 0;

            for (Splitter.Range x : rangesX) {
               for (Splitter.Range range : rangesZ) {
                  output[o++] = new Splitter.Area(x.min, range.min, x.max, range.max);
               }
            }
         } else if (pieces % 2 == 0) {
            Splitter.Range[] rangesX = split(new Splitter.Range(area.minX, area.maxX), 2);
            Splitter.Range[] rangesZ = split(new Splitter.Range(area.minZ, area.maxZ), pieces / 2);
            int o = 0;

            for (Splitter.Range x : rangesX) {
               for (Splitter.Range range : rangesZ) {
                  output[o++] = new Splitter.Area(x.min, range.min, x.max, range.max);
               }
            }
         } else {
            Splitter.Range[] ranges = split(new Splitter.Range(area.minX, area.maxX), pieces);

            for (int i = 0; i < ranges.length; i++) {
               output[i] = new Splitter.Area(ranges[i].min, area.minZ, ranges[i].max, area.maxZ);
            }
         }

         return output;
      }
   }

   @Nonnull
   public static Splitter.Area[] splitX(@Nonnull Splitter.Area area, int pieces) {
      if (pieces < 1) {
         throw new IllegalArgumentException("negative number of pieces");
      } else if (pieces == 1) {
         return new Splitter.Area[]{area};
      } else {
         int sizeX = area.maxX - area.minX;
         int sizeZ = area.maxZ - area.minZ;
         if (pieces > sizeX) {
            pieces = sizeX;
         }

         Splitter.Area[] output = new Splitter.Area[pieces];
         Splitter.Range[] ranges = split(new Splitter.Range(area.minX, area.maxX), pieces);

         for (int i = 0; i < ranges.length; i++) {
            output[i] = new Splitter.Area(ranges[i].min, area.minZ, ranges[i].max, area.maxZ);
         }

         return output;
      }
   }

   public static class Area {
      public final int minX;
      public final int minZ;
      public final int maxX;
      public final int maxZ;

      public Area(int minX, int minZ, int maxX, int maxZ) {
         if (maxX >= minX && maxZ >= minZ) {
            this.minX = minX;
            this.minZ = minZ;
            this.maxX = maxX;
            this.maxZ = maxZ;
         } else {
            throw new IllegalArgumentException("max smaller than min");
         }
      }

      @Nonnull
      @Override
      public String toString() {
         return "Area{minX=" + this.minX + ", minZ=" + this.minZ + ", maxX=" + this.maxX + ", maxZ=" + this.maxZ + "}";
      }
   }

   public static class Range {
      public final int min;
      public final int max;

      public Range(int min, int max) {
         if (max < min) {
            throw new IllegalArgumentException("max smaller than min");
         } else {
            this.min = min;
            this.max = max;
         }
      }
   }
}