All Downloads are FREE. Search and download functionalities are using the official Maven repository.

POGOProtos.Data.Telemetry.DistributionOuterClass Maven / Gradle / Ivy

// Generated by the protocol buffer compiler.  DO NOT EDIT!
// source: POGOProtos/Data/Telemetry/Distribution.proto

package POGOProtos.Data.Telemetry;

public final class DistributionOuterClass {
  private DistributionOuterClass() {}
  public static void registerAllExtensions(
      com.google.protobuf.ExtensionRegistryLite registry) {
  }

  public static void registerAllExtensions(
      com.google.protobuf.ExtensionRegistry registry) {
    registerAllExtensions(
        (com.google.protobuf.ExtensionRegistryLite) registry);
  }
  public interface DistributionOrBuilder extends
      // @@protoc_insertion_point(interface_extends:POGOProtos.Data.Telemetry.Distribution)
      com.google.protobuf.MessageOrBuilder {

    /**
     * int64 count = 1;
     */
    long getCount();

    /**
     * float mean = 2;
     */
    float getMean();

    /**
     * double sum_of_squared_deviation = 3;
     */
    double getSumOfSquaredDeviation();

    /**
     * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
     */
    boolean hasRange();
    /**
     * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
     */
    POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range getRange();
    /**
     * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
     */
    POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.RangeOrBuilder getRangeOrBuilder();

    /**
     * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
     */
    boolean hasBucketOptions();
    /**
     * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
     */
    POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions getBucketOptions();
    /**
     * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
     */
    POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptionsOrBuilder getBucketOptionsOrBuilder();

    /**
     * repeated int64 bucket_counts = 6;
     */
    java.util.List getBucketCountsList();
    /**
     * repeated int64 bucket_counts = 6;
     */
    int getBucketCountsCount();
    /**
     * repeated int64 bucket_counts = 6;
     */
    long getBucketCounts(int index);
  }
  /**
   * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution}
   */
  public  static final class Distribution extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:POGOProtos.Data.Telemetry.Distribution)
      DistributionOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use Distribution.newBuilder() to construct.
    private Distribution(com.google.protobuf.GeneratedMessageV3.Builder builder) {
      super(builder);
    }
    private Distribution() {
      count_ = 0L;
      mean_ = 0F;
      sumOfSquaredDeviation_ = 0D;
      bucketCounts_ = java.util.Collections.emptyList();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    private Distribution(
        com.google.protobuf.CodedInputStream input,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      this();
      if (extensionRegistry == null) {
        throw new java.lang.NullPointerException();
      }
      int mutable_bitField0_ = 0;
      com.google.protobuf.UnknownFieldSet.Builder unknownFields =
          com.google.protobuf.UnknownFieldSet.newBuilder();
      try {
        boolean done = false;
        while (!done) {
          int tag = input.readTag();
          switch (tag) {
            case 0:
              done = true;
              break;
            case 8: {

              count_ = input.readInt64();
              break;
            }
            case 21: {

              mean_ = input.readFloat();
              break;
            }
            case 25: {

              sumOfSquaredDeviation_ = input.readDouble();
              break;
            }
            case 34: {
              POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.Builder subBuilder = null;
              if (range_ != null) {
                subBuilder = range_.toBuilder();
              }
              range_ = input.readMessage(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.parser(), extensionRegistry);
              if (subBuilder != null) {
                subBuilder.mergeFrom(range_);
                range_ = subBuilder.buildPartial();
              }

              break;
            }
            case 42: {
              POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.Builder subBuilder = null;
              if (bucketOptions_ != null) {
                subBuilder = bucketOptions_.toBuilder();
              }
              bucketOptions_ = input.readMessage(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.parser(), extensionRegistry);
              if (subBuilder != null) {
                subBuilder.mergeFrom(bucketOptions_);
                bucketOptions_ = subBuilder.buildPartial();
              }

              break;
            }
            case 48: {
              if (!((mutable_bitField0_ & 0x00000020) == 0x00000020)) {
                bucketCounts_ = new java.util.ArrayList();
                mutable_bitField0_ |= 0x00000020;
              }
              bucketCounts_.add(input.readInt64());
              break;
            }
            case 50: {
              int length = input.readRawVarint32();
              int limit = input.pushLimit(length);
              if (!((mutable_bitField0_ & 0x00000020) == 0x00000020) && input.getBytesUntilLimit() > 0) {
                bucketCounts_ = new java.util.ArrayList();
                mutable_bitField0_ |= 0x00000020;
              }
              while (input.getBytesUntilLimit() > 0) {
                bucketCounts_.add(input.readInt64());
              }
              input.popLimit(limit);
              break;
            }
            default: {
              if (!parseUnknownFieldProto3(
                  input, unknownFields, extensionRegistry, tag)) {
                done = true;
              }
              break;
            }
          }
        }
      } catch (com.google.protobuf.InvalidProtocolBufferException e) {
        throw e.setUnfinishedMessage(this);
      } catch (java.io.IOException e) {
        throw new com.google.protobuf.InvalidProtocolBufferException(
            e).setUnfinishedMessage(this);
      } finally {
        if (((mutable_bitField0_ & 0x00000020) == 0x00000020)) {
          bucketCounts_ = java.util.Collections.unmodifiableList(bucketCounts_);
        }
        this.unknownFields = unknownFields.build();
        makeExtensionsImmutable();
      }
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Builder.class);
    }

    public interface BucketOptionsOrBuilder extends
        // @@protoc_insertion_point(interface_extends:POGOProtos.Data.Telemetry.Distribution.BucketOptions)
        com.google.protobuf.MessageOrBuilder {

      /**
       * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
       */
      boolean hasLinearBuckets();
      /**
       * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
       */
      POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets getLinearBuckets();
      /**
       * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
       */
      POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBucketsOrBuilder getLinearBucketsOrBuilder();

      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
       */
      boolean hasExponentialBuckets();
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
       */
      POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets getExponentialBuckets();
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
       */
      POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBucketsOrBuilder getExponentialBucketsOrBuilder();

      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
       */
      boolean hasExplicitBuckets();
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
       */
      POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets getExplicitBuckets();
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
       */
      POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBucketsOrBuilder getExplicitBucketsOrBuilder();

      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.BucketTypeCase getBucketTypeCase();
    }
    /**
     * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.BucketOptions}
     */
    public  static final class BucketOptions extends
        com.google.protobuf.GeneratedMessageV3 implements
        // @@protoc_insertion_point(message_implements:POGOProtos.Data.Telemetry.Distribution.BucketOptions)
        BucketOptionsOrBuilder {
    private static final long serialVersionUID = 0L;
      // Use BucketOptions.newBuilder() to construct.
      private BucketOptions(com.google.protobuf.GeneratedMessageV3.Builder builder) {
        super(builder);
      }
      private BucketOptions() {
      }

      @java.lang.Override
      public final com.google.protobuf.UnknownFieldSet
      getUnknownFields() {
        return this.unknownFields;
      }
      private BucketOptions(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        this();
        if (extensionRegistry == null) {
          throw new java.lang.NullPointerException();
        }
        int mutable_bitField0_ = 0;
        com.google.protobuf.UnknownFieldSet.Builder unknownFields =
            com.google.protobuf.UnknownFieldSet.newBuilder();
        try {
          boolean done = false;
          while (!done) {
            int tag = input.readTag();
            switch (tag) {
              case 0:
                done = true;
                break;
              case 10: {
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.Builder subBuilder = null;
                if (bucketTypeCase_ == 1) {
                  subBuilder = ((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_).toBuilder();
                }
                bucketType_ =
                    input.readMessage(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.parser(), extensionRegistry);
                if (subBuilder != null) {
                  subBuilder.mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_);
                  bucketType_ = subBuilder.buildPartial();
                }
                bucketTypeCase_ = 1;
                break;
              }
              case 18: {
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.Builder subBuilder = null;
                if (bucketTypeCase_ == 2) {
                  subBuilder = ((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_).toBuilder();
                }
                bucketType_ =
                    input.readMessage(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.parser(), extensionRegistry);
                if (subBuilder != null) {
                  subBuilder.mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_);
                  bucketType_ = subBuilder.buildPartial();
                }
                bucketTypeCase_ = 2;
                break;
              }
              case 26: {
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.Builder subBuilder = null;
                if (bucketTypeCase_ == 3) {
                  subBuilder = ((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_).toBuilder();
                }
                bucketType_ =
                    input.readMessage(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.parser(), extensionRegistry);
                if (subBuilder != null) {
                  subBuilder.mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_);
                  bucketType_ = subBuilder.buildPartial();
                }
                bucketTypeCase_ = 3;
                break;
              }
              default: {
                if (!parseUnknownFieldProto3(
                    input, unknownFields, extensionRegistry, tag)) {
                  done = true;
                }
                break;
              }
            }
          }
        } catch (com.google.protobuf.InvalidProtocolBufferException e) {
          throw e.setUnfinishedMessage(this);
        } catch (java.io.IOException e) {
          throw new com.google.protobuf.InvalidProtocolBufferException(
              e).setUnfinishedMessage(this);
        } finally {
          this.unknownFields = unknownFields.build();
          makeExtensionsImmutable();
        }
      }
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.Builder.class);
      }

      public interface ExplicitBucketsOrBuilder extends
          // @@protoc_insertion_point(interface_extends:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExplicitBuckets)
          com.google.protobuf.MessageOrBuilder {

        /**
         * repeated int64 bounds = 1;
         */
        java.util.List getBoundsList();
        /**
         * repeated int64 bounds = 1;
         */
        int getBoundsCount();
        /**
         * repeated int64 bounds = 1;
         */
        long getBounds(int index);
      }
      /**
       * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExplicitBuckets}
       */
      public  static final class ExplicitBuckets extends
          com.google.protobuf.GeneratedMessageV3 implements
          // @@protoc_insertion_point(message_implements:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExplicitBuckets)
          ExplicitBucketsOrBuilder {
      private static final long serialVersionUID = 0L;
        // Use ExplicitBuckets.newBuilder() to construct.
        private ExplicitBuckets(com.google.protobuf.GeneratedMessageV3.Builder builder) {
          super(builder);
        }
        private ExplicitBuckets() {
          bounds_ = java.util.Collections.emptyList();
        }

        @java.lang.Override
        public final com.google.protobuf.UnknownFieldSet
        getUnknownFields() {
          return this.unknownFields;
        }
        private ExplicitBuckets(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          this();
          if (extensionRegistry == null) {
            throw new java.lang.NullPointerException();
          }
          int mutable_bitField0_ = 0;
          com.google.protobuf.UnknownFieldSet.Builder unknownFields =
              com.google.protobuf.UnknownFieldSet.newBuilder();
          try {
            boolean done = false;
            while (!done) {
              int tag = input.readTag();
              switch (tag) {
                case 0:
                  done = true;
                  break;
                case 8: {
                  if (!((mutable_bitField0_ & 0x00000001) == 0x00000001)) {
                    bounds_ = new java.util.ArrayList();
                    mutable_bitField0_ |= 0x00000001;
                  }
                  bounds_.add(input.readInt64());
                  break;
                }
                case 10: {
                  int length = input.readRawVarint32();
                  int limit = input.pushLimit(length);
                  if (!((mutable_bitField0_ & 0x00000001) == 0x00000001) && input.getBytesUntilLimit() > 0) {
                    bounds_ = new java.util.ArrayList();
                    mutable_bitField0_ |= 0x00000001;
                  }
                  while (input.getBytesUntilLimit() > 0) {
                    bounds_.add(input.readInt64());
                  }
                  input.popLimit(limit);
                  break;
                }
                default: {
                  if (!parseUnknownFieldProto3(
                      input, unknownFields, extensionRegistry, tag)) {
                    done = true;
                  }
                  break;
                }
              }
            }
          } catch (com.google.protobuf.InvalidProtocolBufferException e) {
            throw e.setUnfinishedMessage(this);
          } catch (java.io.IOException e) {
            throw new com.google.protobuf.InvalidProtocolBufferException(
                e).setUnfinishedMessage(this);
          } finally {
            if (((mutable_bitField0_ & 0x00000001) == 0x00000001)) {
              bounds_ = java.util.Collections.unmodifiableList(bounds_);
            }
            this.unknownFields = unknownFields.build();
            makeExtensionsImmutable();
          }
        }
        public static final com.google.protobuf.Descriptors.Descriptor
            getDescriptor() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_descriptor;
        }

        @java.lang.Override
        protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
            internalGetFieldAccessorTable() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_fieldAccessorTable
              .ensureFieldAccessorsInitialized(
                  POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets.Builder.class);
        }

        public static final int BOUNDS_FIELD_NUMBER = 1;
        private java.util.List bounds_;
        /**
         * repeated int64 bounds = 1;
         */
        public java.util.List
            getBoundsList() {
          return bounds_;
        }
        /**
         * repeated int64 bounds = 1;
         */
        public int getBoundsCount() {
          return bounds_.size();
        }
        /**
         * repeated int64 bounds = 1;
         */
        public long getBounds(int index) {
          return bounds_.get(index);
        }
        private int boundsMemoizedSerializedSize = -1;

        private byte memoizedIsInitialized = -1;
        @java.lang.Override
        public final boolean isInitialized() {
          byte isInitialized = memoizedIsInitialized;
          if (isInitialized == 1) return true;
          if (isInitialized == 0) return false;

          memoizedIsInitialized = 1;
          return true;
        }

        @java.lang.Override
        public void writeTo(com.google.protobuf.CodedOutputStream output)
                            throws java.io.IOException {
          getSerializedSize();
          if (getBoundsList().size() > 0) {
            output.writeUInt32NoTag(10);
            output.writeUInt32NoTag(boundsMemoizedSerializedSize);
          }
          for (int i = 0; i < bounds_.size(); i++) {
            output.writeInt64NoTag(bounds_.get(i));
          }
          unknownFields.writeTo(output);
        }

        @java.lang.Override
        public int getSerializedSize() {
          int size = memoizedSize;
          if (size != -1) return size;

          size = 0;
          {
            int dataSize = 0;
            for (int i = 0; i < bounds_.size(); i++) {
              dataSize += com.google.protobuf.CodedOutputStream
                .computeInt64SizeNoTag(bounds_.get(i));
            }
            size += dataSize;
            if (!getBoundsList().isEmpty()) {
              size += 1;
              size += com.google.protobuf.CodedOutputStream
                  .computeInt32SizeNoTag(dataSize);
            }
            boundsMemoizedSerializedSize = dataSize;
          }
          size += unknownFields.getSerializedSize();
          memoizedSize = size;
          return size;
        }

        @java.lang.Override
        public boolean equals(final java.lang.Object obj) {
          if (obj == this) {
           return true;
          }
          if (!(obj instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets)) {
            return super.equals(obj);
          }
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets other = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets) obj;

          boolean result = true;
          result = result && getBoundsList()
              .equals(other.getBoundsList());
          result = result && unknownFields.equals(other.unknownFields);
          return result;
        }

        @java.lang.Override
        public int hashCode() {
          if (memoizedHashCode != 0) {
            return memoizedHashCode;
          }
          int hash = 41;
          hash = (19 * hash) + getDescriptor().hashCode();
          if (getBoundsCount() > 0) {
            hash = (37 * hash) + BOUNDS_FIELD_NUMBER;
            hash = (53 * hash) + getBoundsList().hashCode();
          }
          hash = (29 * hash) + unknownFields.hashCode();
          memoizedHashCode = hash;
          return hash;
        }

        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(
            java.nio.ByteBuffer data)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(
            java.nio.ByteBuffer data,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(
            com.google.protobuf.ByteString data)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(
            com.google.protobuf.ByteString data,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(byte[] data)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(
            byte[] data,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(java.io.InputStream input)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(
            java.io.InputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseDelimitedFrom(java.io.InputStream input)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseDelimitedWithIOException(PARSER, input);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseDelimitedFrom(
            java.io.InputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseDelimitedWithIOException(PARSER, input, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(
            com.google.protobuf.CodedInputStream input)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parseFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input, extensionRegistry);
        }

        @java.lang.Override
        public Builder newBuilderForType() { return newBuilder(); }
        public static Builder newBuilder() {
          return DEFAULT_INSTANCE.toBuilder();
        }
        public static Builder newBuilder(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets prototype) {
          return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
        }
        @java.lang.Override
        public Builder toBuilder() {
          return this == DEFAULT_INSTANCE
              ? new Builder() : new Builder().mergeFrom(this);
        }

        @java.lang.Override
        protected Builder newBuilderForType(
            com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
          Builder builder = new Builder(parent);
          return builder;
        }
        /**
         * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExplicitBuckets}
         */
        public static final class Builder extends
            com.google.protobuf.GeneratedMessageV3.Builder implements
            // @@protoc_insertion_point(builder_implements:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExplicitBuckets)
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBucketsOrBuilder {
          public static final com.google.protobuf.Descriptors.Descriptor
              getDescriptor() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_descriptor;
          }

          @java.lang.Override
          protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
              internalGetFieldAccessorTable() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_fieldAccessorTable
                .ensureFieldAccessorsInitialized(
                    POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets.Builder.class);
          }

          // Construct using POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets.newBuilder()
          private Builder() {
            maybeForceBuilderInitialization();
          }

          private Builder(
              com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
            super(parent);
            maybeForceBuilderInitialization();
          }
          private void maybeForceBuilderInitialization() {
            if (com.google.protobuf.GeneratedMessageV3
                    .alwaysUseFieldBuilders) {
            }
          }
          @java.lang.Override
          public Builder clear() {
            super.clear();
            bounds_ = java.util.Collections.emptyList();
            bitField0_ = (bitField0_ & ~0x00000001);
            return this;
          }

          @java.lang.Override
          public com.google.protobuf.Descriptors.Descriptor
              getDescriptorForType() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_descriptor;
          }

          @java.lang.Override
          public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets getDefaultInstanceForType() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets.getDefaultInstance();
          }

          @java.lang.Override
          public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets build() {
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets result = buildPartial();
            if (!result.isInitialized()) {
              throw newUninitializedMessageException(result);
            }
            return result;
          }

          @java.lang.Override
          public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets buildPartial() {
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets result = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets(this);
            int from_bitField0_ = bitField0_;
            if (((bitField0_ & 0x00000001) == 0x00000001)) {
              bounds_ = java.util.Collections.unmodifiableList(bounds_);
              bitField0_ = (bitField0_ & ~0x00000001);
            }
            result.bounds_ = bounds_;
            onBuilt();
            return result;
          }

          @java.lang.Override
          public Builder clone() {
            return (Builder) super.clone();
          }
          @java.lang.Override
          public Builder setField(
              com.google.protobuf.Descriptors.FieldDescriptor field,
              java.lang.Object value) {
            return (Builder) super.setField(field, value);
          }
          @java.lang.Override
          public Builder clearField(
              com.google.protobuf.Descriptors.FieldDescriptor field) {
            return (Builder) super.clearField(field);
          }
          @java.lang.Override
          public Builder clearOneof(
              com.google.protobuf.Descriptors.OneofDescriptor oneof) {
            return (Builder) super.clearOneof(oneof);
          }
          @java.lang.Override
          public Builder setRepeatedField(
              com.google.protobuf.Descriptors.FieldDescriptor field,
              int index, java.lang.Object value) {
            return (Builder) super.setRepeatedField(field, index, value);
          }
          @java.lang.Override
          public Builder addRepeatedField(
              com.google.protobuf.Descriptors.FieldDescriptor field,
              java.lang.Object value) {
            return (Builder) super.addRepeatedField(field, value);
          }
          @java.lang.Override
          public Builder mergeFrom(com.google.protobuf.Message other) {
            if (other instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets) {
              return mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets)other);
            } else {
              super.mergeFrom(other);
              return this;
            }
          }

          public Builder mergeFrom(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets other) {
            if (other == POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets.getDefaultInstance()) return this;
            if (!other.bounds_.isEmpty()) {
              if (bounds_.isEmpty()) {
                bounds_ = other.bounds_;
                bitField0_ = (bitField0_ & ~0x00000001);
              } else {
                ensureBoundsIsMutable();
                bounds_.addAll(other.bounds_);
              }
              onChanged();
            }
            this.mergeUnknownFields(other.unknownFields);
            onChanged();
            return this;
          }

          @java.lang.Override
          public final boolean isInitialized() {
            return true;
          }

          @java.lang.Override
          public Builder mergeFrom(
              com.google.protobuf.CodedInputStream input,
              com.google.protobuf.ExtensionRegistryLite extensionRegistry)
              throws java.io.IOException {
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets parsedMessage = null;
            try {
              parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
            } catch (com.google.protobuf.InvalidProtocolBufferException e) {
              parsedMessage = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets) e.getUnfinishedMessage();
              throw e.unwrapIOException();
            } finally {
              if (parsedMessage != null) {
                mergeFrom(parsedMessage);
              }
            }
            return this;
          }
          private int bitField0_;

          private java.util.List bounds_ = java.util.Collections.emptyList();
          private void ensureBoundsIsMutable() {
            if (!((bitField0_ & 0x00000001) == 0x00000001)) {
              bounds_ = new java.util.ArrayList(bounds_);
              bitField0_ |= 0x00000001;
             }
          }
          /**
           * repeated int64 bounds = 1;
           */
          public java.util.List
              getBoundsList() {
            return java.util.Collections.unmodifiableList(bounds_);
          }
          /**
           * repeated int64 bounds = 1;
           */
          public int getBoundsCount() {
            return bounds_.size();
          }
          /**
           * repeated int64 bounds = 1;
           */
          public long getBounds(int index) {
            return bounds_.get(index);
          }
          /**
           * repeated int64 bounds = 1;
           */
          public Builder setBounds(
              int index, long value) {
            ensureBoundsIsMutable();
            bounds_.set(index, value);
            onChanged();
            return this;
          }
          /**
           * repeated int64 bounds = 1;
           */
          public Builder addBounds(long value) {
            ensureBoundsIsMutable();
            bounds_.add(value);
            onChanged();
            return this;
          }
          /**
           * repeated int64 bounds = 1;
           */
          public Builder addAllBounds(
              java.lang.Iterable values) {
            ensureBoundsIsMutable();
            com.google.protobuf.AbstractMessageLite.Builder.addAll(
                values, bounds_);
            onChanged();
            return this;
          }
          /**
           * repeated int64 bounds = 1;
           */
          public Builder clearBounds() {
            bounds_ = java.util.Collections.emptyList();
            bitField0_ = (bitField0_ & ~0x00000001);
            onChanged();
            return this;
          }
          @java.lang.Override
          public final Builder setUnknownFields(
              final com.google.protobuf.UnknownFieldSet unknownFields) {
            return super.setUnknownFieldsProto3(unknownFields);
          }

          @java.lang.Override
          public final Builder mergeUnknownFields(
              final com.google.protobuf.UnknownFieldSet unknownFields) {
            return super.mergeUnknownFields(unknownFields);
          }


          // @@protoc_insertion_point(builder_scope:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExplicitBuckets)
        }

        // @@protoc_insertion_point(class_scope:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExplicitBuckets)
        private static final POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets DEFAULT_INSTANCE;
        static {
          DEFAULT_INSTANCE = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets();
        }

        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets getDefaultInstance() {
          return DEFAULT_INSTANCE;
        }

        private static final com.google.protobuf.Parser
            PARSER = new com.google.protobuf.AbstractParser() {
          @java.lang.Override
          public ExplicitBuckets parsePartialFrom(
              com.google.protobuf.CodedInputStream input,
              com.google.protobuf.ExtensionRegistryLite extensionRegistry)
              throws com.google.protobuf.InvalidProtocolBufferException {
            return new ExplicitBuckets(input, extensionRegistry);
          }
        };

        public static com.google.protobuf.Parser parser() {
          return PARSER;
        }

        @java.lang.Override
        public com.google.protobuf.Parser getParserForType() {
          return PARSER;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExplicitBuckets getDefaultInstanceForType() {
          return DEFAULT_INSTANCE;
        }

      }

      public interface ExponentialBucketsOrBuilder extends
          // @@protoc_insertion_point(interface_extends:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExponentialBuckets)
          com.google.protobuf.MessageOrBuilder {

        /**
         * int64 num_finite_buckets = 1;
         */
        long getNumFiniteBuckets();

        /**
         * float growth_factor = 2;
         */
        float getGrowthFactor();

        /**
         * float scale = 3;
         */
        float getScale();
      }
      /**
       * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExponentialBuckets}
       */
      public  static final class ExponentialBuckets extends
          com.google.protobuf.GeneratedMessageV3 implements
          // @@protoc_insertion_point(message_implements:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExponentialBuckets)
          ExponentialBucketsOrBuilder {
      private static final long serialVersionUID = 0L;
        // Use ExponentialBuckets.newBuilder() to construct.
        private ExponentialBuckets(com.google.protobuf.GeneratedMessageV3.Builder builder) {
          super(builder);
        }
        private ExponentialBuckets() {
          numFiniteBuckets_ = 0L;
          growthFactor_ = 0F;
          scale_ = 0F;
        }

        @java.lang.Override
        public final com.google.protobuf.UnknownFieldSet
        getUnknownFields() {
          return this.unknownFields;
        }
        private ExponentialBuckets(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          this();
          if (extensionRegistry == null) {
            throw new java.lang.NullPointerException();
          }
          int mutable_bitField0_ = 0;
          com.google.protobuf.UnknownFieldSet.Builder unknownFields =
              com.google.protobuf.UnknownFieldSet.newBuilder();
          try {
            boolean done = false;
            while (!done) {
              int tag = input.readTag();
              switch (tag) {
                case 0:
                  done = true;
                  break;
                case 8: {

                  numFiniteBuckets_ = input.readInt64();
                  break;
                }
                case 21: {

                  growthFactor_ = input.readFloat();
                  break;
                }
                case 29: {

                  scale_ = input.readFloat();
                  break;
                }
                default: {
                  if (!parseUnknownFieldProto3(
                      input, unknownFields, extensionRegistry, tag)) {
                    done = true;
                  }
                  break;
                }
              }
            }
          } catch (com.google.protobuf.InvalidProtocolBufferException e) {
            throw e.setUnfinishedMessage(this);
          } catch (java.io.IOException e) {
            throw new com.google.protobuf.InvalidProtocolBufferException(
                e).setUnfinishedMessage(this);
          } finally {
            this.unknownFields = unknownFields.build();
            makeExtensionsImmutable();
          }
        }
        public static final com.google.protobuf.Descriptors.Descriptor
            getDescriptor() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_descriptor;
        }

        @java.lang.Override
        protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
            internalGetFieldAccessorTable() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_fieldAccessorTable
              .ensureFieldAccessorsInitialized(
                  POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets.Builder.class);
        }

        public static final int NUM_FINITE_BUCKETS_FIELD_NUMBER = 1;
        private long numFiniteBuckets_;
        /**
         * int64 num_finite_buckets = 1;
         */
        public long getNumFiniteBuckets() {
          return numFiniteBuckets_;
        }

        public static final int GROWTH_FACTOR_FIELD_NUMBER = 2;
        private float growthFactor_;
        /**
         * float growth_factor = 2;
         */
        public float getGrowthFactor() {
          return growthFactor_;
        }

        public static final int SCALE_FIELD_NUMBER = 3;
        private float scale_;
        /**
         * float scale = 3;
         */
        public float getScale() {
          return scale_;
        }

        private byte memoizedIsInitialized = -1;
        @java.lang.Override
        public final boolean isInitialized() {
          byte isInitialized = memoizedIsInitialized;
          if (isInitialized == 1) return true;
          if (isInitialized == 0) return false;

          memoizedIsInitialized = 1;
          return true;
        }

        @java.lang.Override
        public void writeTo(com.google.protobuf.CodedOutputStream output)
                            throws java.io.IOException {
          if (numFiniteBuckets_ != 0L) {
            output.writeInt64(1, numFiniteBuckets_);
          }
          if (growthFactor_ != 0F) {
            output.writeFloat(2, growthFactor_);
          }
          if (scale_ != 0F) {
            output.writeFloat(3, scale_);
          }
          unknownFields.writeTo(output);
        }

        @java.lang.Override
        public int getSerializedSize() {
          int size = memoizedSize;
          if (size != -1) return size;

          size = 0;
          if (numFiniteBuckets_ != 0L) {
            size += com.google.protobuf.CodedOutputStream
              .computeInt64Size(1, numFiniteBuckets_);
          }
          if (growthFactor_ != 0F) {
            size += com.google.protobuf.CodedOutputStream
              .computeFloatSize(2, growthFactor_);
          }
          if (scale_ != 0F) {
            size += com.google.protobuf.CodedOutputStream
              .computeFloatSize(3, scale_);
          }
          size += unknownFields.getSerializedSize();
          memoizedSize = size;
          return size;
        }

        @java.lang.Override
        public boolean equals(final java.lang.Object obj) {
          if (obj == this) {
           return true;
          }
          if (!(obj instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets)) {
            return super.equals(obj);
          }
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets other = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets) obj;

          boolean result = true;
          result = result && (getNumFiniteBuckets()
              == other.getNumFiniteBuckets());
          result = result && (
              java.lang.Float.floatToIntBits(getGrowthFactor())
              == java.lang.Float.floatToIntBits(
                  other.getGrowthFactor()));
          result = result && (
              java.lang.Float.floatToIntBits(getScale())
              == java.lang.Float.floatToIntBits(
                  other.getScale()));
          result = result && unknownFields.equals(other.unknownFields);
          return result;
        }

        @java.lang.Override
        public int hashCode() {
          if (memoizedHashCode != 0) {
            return memoizedHashCode;
          }
          int hash = 41;
          hash = (19 * hash) + getDescriptor().hashCode();
          hash = (37 * hash) + NUM_FINITE_BUCKETS_FIELD_NUMBER;
          hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
              getNumFiniteBuckets());
          hash = (37 * hash) + GROWTH_FACTOR_FIELD_NUMBER;
          hash = (53 * hash) + java.lang.Float.floatToIntBits(
              getGrowthFactor());
          hash = (37 * hash) + SCALE_FIELD_NUMBER;
          hash = (53 * hash) + java.lang.Float.floatToIntBits(
              getScale());
          hash = (29 * hash) + unknownFields.hashCode();
          memoizedHashCode = hash;
          return hash;
        }

        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(
            java.nio.ByteBuffer data)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(
            java.nio.ByteBuffer data,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(
            com.google.protobuf.ByteString data)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(
            com.google.protobuf.ByteString data,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(byte[] data)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(
            byte[] data,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(java.io.InputStream input)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(
            java.io.InputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseDelimitedFrom(java.io.InputStream input)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseDelimitedWithIOException(PARSER, input);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseDelimitedFrom(
            java.io.InputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseDelimitedWithIOException(PARSER, input, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(
            com.google.protobuf.CodedInputStream input)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parseFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input, extensionRegistry);
        }

        @java.lang.Override
        public Builder newBuilderForType() { return newBuilder(); }
        public static Builder newBuilder() {
          return DEFAULT_INSTANCE.toBuilder();
        }
        public static Builder newBuilder(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets prototype) {
          return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
        }
        @java.lang.Override
        public Builder toBuilder() {
          return this == DEFAULT_INSTANCE
              ? new Builder() : new Builder().mergeFrom(this);
        }

        @java.lang.Override
        protected Builder newBuilderForType(
            com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
          Builder builder = new Builder(parent);
          return builder;
        }
        /**
         * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExponentialBuckets}
         */
        public static final class Builder extends
            com.google.protobuf.GeneratedMessageV3.Builder implements
            // @@protoc_insertion_point(builder_implements:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExponentialBuckets)
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBucketsOrBuilder {
          public static final com.google.protobuf.Descriptors.Descriptor
              getDescriptor() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_descriptor;
          }

          @java.lang.Override
          protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
              internalGetFieldAccessorTable() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_fieldAccessorTable
                .ensureFieldAccessorsInitialized(
                    POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets.Builder.class);
          }

          // Construct using POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets.newBuilder()
          private Builder() {
            maybeForceBuilderInitialization();
          }

          private Builder(
              com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
            super(parent);
            maybeForceBuilderInitialization();
          }
          private void maybeForceBuilderInitialization() {
            if (com.google.protobuf.GeneratedMessageV3
                    .alwaysUseFieldBuilders) {
            }
          }
          @java.lang.Override
          public Builder clear() {
            super.clear();
            numFiniteBuckets_ = 0L;

            growthFactor_ = 0F;

            scale_ = 0F;

            return this;
          }

          @java.lang.Override
          public com.google.protobuf.Descriptors.Descriptor
              getDescriptorForType() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_descriptor;
          }

          @java.lang.Override
          public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets getDefaultInstanceForType() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets.getDefaultInstance();
          }

          @java.lang.Override
          public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets build() {
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets result = buildPartial();
            if (!result.isInitialized()) {
              throw newUninitializedMessageException(result);
            }
            return result;
          }

          @java.lang.Override
          public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets buildPartial() {
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets result = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets(this);
            result.numFiniteBuckets_ = numFiniteBuckets_;
            result.growthFactor_ = growthFactor_;
            result.scale_ = scale_;
            onBuilt();
            return result;
          }

          @java.lang.Override
          public Builder clone() {
            return (Builder) super.clone();
          }
          @java.lang.Override
          public Builder setField(
              com.google.protobuf.Descriptors.FieldDescriptor field,
              java.lang.Object value) {
            return (Builder) super.setField(field, value);
          }
          @java.lang.Override
          public Builder clearField(
              com.google.protobuf.Descriptors.FieldDescriptor field) {
            return (Builder) super.clearField(field);
          }
          @java.lang.Override
          public Builder clearOneof(
              com.google.protobuf.Descriptors.OneofDescriptor oneof) {
            return (Builder) super.clearOneof(oneof);
          }
          @java.lang.Override
          public Builder setRepeatedField(
              com.google.protobuf.Descriptors.FieldDescriptor field,
              int index, java.lang.Object value) {
            return (Builder) super.setRepeatedField(field, index, value);
          }
          @java.lang.Override
          public Builder addRepeatedField(
              com.google.protobuf.Descriptors.FieldDescriptor field,
              java.lang.Object value) {
            return (Builder) super.addRepeatedField(field, value);
          }
          @java.lang.Override
          public Builder mergeFrom(com.google.protobuf.Message other) {
            if (other instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets) {
              return mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets)other);
            } else {
              super.mergeFrom(other);
              return this;
            }
          }

          public Builder mergeFrom(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets other) {
            if (other == POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets.getDefaultInstance()) return this;
            if (other.getNumFiniteBuckets() != 0L) {
              setNumFiniteBuckets(other.getNumFiniteBuckets());
            }
            if (other.getGrowthFactor() != 0F) {
              setGrowthFactor(other.getGrowthFactor());
            }
            if (other.getScale() != 0F) {
              setScale(other.getScale());
            }
            this.mergeUnknownFields(other.unknownFields);
            onChanged();
            return this;
          }

          @java.lang.Override
          public final boolean isInitialized() {
            return true;
          }

          @java.lang.Override
          public Builder mergeFrom(
              com.google.protobuf.CodedInputStream input,
              com.google.protobuf.ExtensionRegistryLite extensionRegistry)
              throws java.io.IOException {
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets parsedMessage = null;
            try {
              parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
            } catch (com.google.protobuf.InvalidProtocolBufferException e) {
              parsedMessage = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets) e.getUnfinishedMessage();
              throw e.unwrapIOException();
            } finally {
              if (parsedMessage != null) {
                mergeFrom(parsedMessage);
              }
            }
            return this;
          }

          private long numFiniteBuckets_ ;
          /**
           * int64 num_finite_buckets = 1;
           */
          public long getNumFiniteBuckets() {
            return numFiniteBuckets_;
          }
          /**
           * int64 num_finite_buckets = 1;
           */
          public Builder setNumFiniteBuckets(long value) {
            
            numFiniteBuckets_ = value;
            onChanged();
            return this;
          }
          /**
           * int64 num_finite_buckets = 1;
           */
          public Builder clearNumFiniteBuckets() {
            
            numFiniteBuckets_ = 0L;
            onChanged();
            return this;
          }

          private float growthFactor_ ;
          /**
           * float growth_factor = 2;
           */
          public float getGrowthFactor() {
            return growthFactor_;
          }
          /**
           * float growth_factor = 2;
           */
          public Builder setGrowthFactor(float value) {
            
            growthFactor_ = value;
            onChanged();
            return this;
          }
          /**
           * float growth_factor = 2;
           */
          public Builder clearGrowthFactor() {
            
            growthFactor_ = 0F;
            onChanged();
            return this;
          }

          private float scale_ ;
          /**
           * float scale = 3;
           */
          public float getScale() {
            return scale_;
          }
          /**
           * float scale = 3;
           */
          public Builder setScale(float value) {
            
            scale_ = value;
            onChanged();
            return this;
          }
          /**
           * float scale = 3;
           */
          public Builder clearScale() {
            
            scale_ = 0F;
            onChanged();
            return this;
          }
          @java.lang.Override
          public final Builder setUnknownFields(
              final com.google.protobuf.UnknownFieldSet unknownFields) {
            return super.setUnknownFieldsProto3(unknownFields);
          }

          @java.lang.Override
          public final Builder mergeUnknownFields(
              final com.google.protobuf.UnknownFieldSet unknownFields) {
            return super.mergeUnknownFields(unknownFields);
          }


          // @@protoc_insertion_point(builder_scope:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExponentialBuckets)
        }

        // @@protoc_insertion_point(class_scope:POGOProtos.Data.Telemetry.Distribution.BucketOptions.ExponentialBuckets)
        private static final POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets DEFAULT_INSTANCE;
        static {
          DEFAULT_INSTANCE = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets();
        }

        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets getDefaultInstance() {
          return DEFAULT_INSTANCE;
        }

        private static final com.google.protobuf.Parser
            PARSER = new com.google.protobuf.AbstractParser() {
          @java.lang.Override
          public ExponentialBuckets parsePartialFrom(
              com.google.protobuf.CodedInputStream input,
              com.google.protobuf.ExtensionRegistryLite extensionRegistry)
              throws com.google.protobuf.InvalidProtocolBufferException {
            return new ExponentialBuckets(input, extensionRegistry);
          }
        };

        public static com.google.protobuf.Parser parser() {
          return PARSER;
        }

        @java.lang.Override
        public com.google.protobuf.Parser getParserForType() {
          return PARSER;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.ExponentialBuckets getDefaultInstanceForType() {
          return DEFAULT_INSTANCE;
        }

      }

      public interface LinearBucketsOrBuilder extends
          // @@protoc_insertion_point(interface_extends:POGOProtos.Data.Telemetry.Distribution.BucketOptions.LinearBuckets)
          com.google.protobuf.MessageOrBuilder {

        /**
         * int64 num_finite_buckets = 1;
         */
        long getNumFiniteBuckets();

        /**
         * int64 width = 2;
         */
        long getWidth();

        /**
         * int64 offset = 3;
         */
        long getOffset();
      }
      /**
       * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.BucketOptions.LinearBuckets}
       */
      public  static final class LinearBuckets extends
          com.google.protobuf.GeneratedMessageV3 implements
          // @@protoc_insertion_point(message_implements:POGOProtos.Data.Telemetry.Distribution.BucketOptions.LinearBuckets)
          LinearBucketsOrBuilder {
      private static final long serialVersionUID = 0L;
        // Use LinearBuckets.newBuilder() to construct.
        private LinearBuckets(com.google.protobuf.GeneratedMessageV3.Builder builder) {
          super(builder);
        }
        private LinearBuckets() {
          numFiniteBuckets_ = 0L;
          width_ = 0L;
          offset_ = 0L;
        }

        @java.lang.Override
        public final com.google.protobuf.UnknownFieldSet
        getUnknownFields() {
          return this.unknownFields;
        }
        private LinearBuckets(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          this();
          if (extensionRegistry == null) {
            throw new java.lang.NullPointerException();
          }
          int mutable_bitField0_ = 0;
          com.google.protobuf.UnknownFieldSet.Builder unknownFields =
              com.google.protobuf.UnknownFieldSet.newBuilder();
          try {
            boolean done = false;
            while (!done) {
              int tag = input.readTag();
              switch (tag) {
                case 0:
                  done = true;
                  break;
                case 8: {

                  numFiniteBuckets_ = input.readInt64();
                  break;
                }
                case 16: {

                  width_ = input.readInt64();
                  break;
                }
                case 24: {

                  offset_ = input.readInt64();
                  break;
                }
                default: {
                  if (!parseUnknownFieldProto3(
                      input, unknownFields, extensionRegistry, tag)) {
                    done = true;
                  }
                  break;
                }
              }
            }
          } catch (com.google.protobuf.InvalidProtocolBufferException e) {
            throw e.setUnfinishedMessage(this);
          } catch (java.io.IOException e) {
            throw new com.google.protobuf.InvalidProtocolBufferException(
                e).setUnfinishedMessage(this);
          } finally {
            this.unknownFields = unknownFields.build();
            makeExtensionsImmutable();
          }
        }
        public static final com.google.protobuf.Descriptors.Descriptor
            getDescriptor() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_descriptor;
        }

        @java.lang.Override
        protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
            internalGetFieldAccessorTable() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_fieldAccessorTable
              .ensureFieldAccessorsInitialized(
                  POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets.Builder.class);
        }

        public static final int NUM_FINITE_BUCKETS_FIELD_NUMBER = 1;
        private long numFiniteBuckets_;
        /**
         * int64 num_finite_buckets = 1;
         */
        public long getNumFiniteBuckets() {
          return numFiniteBuckets_;
        }

        public static final int WIDTH_FIELD_NUMBER = 2;
        private long width_;
        /**
         * int64 width = 2;
         */
        public long getWidth() {
          return width_;
        }

        public static final int OFFSET_FIELD_NUMBER = 3;
        private long offset_;
        /**
         * int64 offset = 3;
         */
        public long getOffset() {
          return offset_;
        }

        private byte memoizedIsInitialized = -1;
        @java.lang.Override
        public final boolean isInitialized() {
          byte isInitialized = memoizedIsInitialized;
          if (isInitialized == 1) return true;
          if (isInitialized == 0) return false;

          memoizedIsInitialized = 1;
          return true;
        }

        @java.lang.Override
        public void writeTo(com.google.protobuf.CodedOutputStream output)
                            throws java.io.IOException {
          if (numFiniteBuckets_ != 0L) {
            output.writeInt64(1, numFiniteBuckets_);
          }
          if (width_ != 0L) {
            output.writeInt64(2, width_);
          }
          if (offset_ != 0L) {
            output.writeInt64(3, offset_);
          }
          unknownFields.writeTo(output);
        }

        @java.lang.Override
        public int getSerializedSize() {
          int size = memoizedSize;
          if (size != -1) return size;

          size = 0;
          if (numFiniteBuckets_ != 0L) {
            size += com.google.protobuf.CodedOutputStream
              .computeInt64Size(1, numFiniteBuckets_);
          }
          if (width_ != 0L) {
            size += com.google.protobuf.CodedOutputStream
              .computeInt64Size(2, width_);
          }
          if (offset_ != 0L) {
            size += com.google.protobuf.CodedOutputStream
              .computeInt64Size(3, offset_);
          }
          size += unknownFields.getSerializedSize();
          memoizedSize = size;
          return size;
        }

        @java.lang.Override
        public boolean equals(final java.lang.Object obj) {
          if (obj == this) {
           return true;
          }
          if (!(obj instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets)) {
            return super.equals(obj);
          }
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets other = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets) obj;

          boolean result = true;
          result = result && (getNumFiniteBuckets()
              == other.getNumFiniteBuckets());
          result = result && (getWidth()
              == other.getWidth());
          result = result && (getOffset()
              == other.getOffset());
          result = result && unknownFields.equals(other.unknownFields);
          return result;
        }

        @java.lang.Override
        public int hashCode() {
          if (memoizedHashCode != 0) {
            return memoizedHashCode;
          }
          int hash = 41;
          hash = (19 * hash) + getDescriptor().hashCode();
          hash = (37 * hash) + NUM_FINITE_BUCKETS_FIELD_NUMBER;
          hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
              getNumFiniteBuckets());
          hash = (37 * hash) + WIDTH_FIELD_NUMBER;
          hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
              getWidth());
          hash = (37 * hash) + OFFSET_FIELD_NUMBER;
          hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
              getOffset());
          hash = (29 * hash) + unknownFields.hashCode();
          memoizedHashCode = hash;
          return hash;
        }

        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(
            java.nio.ByteBuffer data)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(
            java.nio.ByteBuffer data,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(
            com.google.protobuf.ByteString data)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(
            com.google.protobuf.ByteString data,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(byte[] data)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(
            byte[] data,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return PARSER.parseFrom(data, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(java.io.InputStream input)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(
            java.io.InputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseDelimitedFrom(java.io.InputStream input)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseDelimitedWithIOException(PARSER, input);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseDelimitedFrom(
            java.io.InputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseDelimitedWithIOException(PARSER, input, extensionRegistry);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(
            com.google.protobuf.CodedInputStream input)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input);
        }
        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parseFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          return com.google.protobuf.GeneratedMessageV3
              .parseWithIOException(PARSER, input, extensionRegistry);
        }

        @java.lang.Override
        public Builder newBuilderForType() { return newBuilder(); }
        public static Builder newBuilder() {
          return DEFAULT_INSTANCE.toBuilder();
        }
        public static Builder newBuilder(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets prototype) {
          return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
        }
        @java.lang.Override
        public Builder toBuilder() {
          return this == DEFAULT_INSTANCE
              ? new Builder() : new Builder().mergeFrom(this);
        }

        @java.lang.Override
        protected Builder newBuilderForType(
            com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
          Builder builder = new Builder(parent);
          return builder;
        }
        /**
         * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.BucketOptions.LinearBuckets}
         */
        public static final class Builder extends
            com.google.protobuf.GeneratedMessageV3.Builder implements
            // @@protoc_insertion_point(builder_implements:POGOProtos.Data.Telemetry.Distribution.BucketOptions.LinearBuckets)
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBucketsOrBuilder {
          public static final com.google.protobuf.Descriptors.Descriptor
              getDescriptor() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_descriptor;
          }

          @java.lang.Override
          protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
              internalGetFieldAccessorTable() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_fieldAccessorTable
                .ensureFieldAccessorsInitialized(
                    POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets.Builder.class);
          }

          // Construct using POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets.newBuilder()
          private Builder() {
            maybeForceBuilderInitialization();
          }

          private Builder(
              com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
            super(parent);
            maybeForceBuilderInitialization();
          }
          private void maybeForceBuilderInitialization() {
            if (com.google.protobuf.GeneratedMessageV3
                    .alwaysUseFieldBuilders) {
            }
          }
          @java.lang.Override
          public Builder clear() {
            super.clear();
            numFiniteBuckets_ = 0L;

            width_ = 0L;

            offset_ = 0L;

            return this;
          }

          @java.lang.Override
          public com.google.protobuf.Descriptors.Descriptor
              getDescriptorForType() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_descriptor;
          }

          @java.lang.Override
          public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets getDefaultInstanceForType() {
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets.getDefaultInstance();
          }

          @java.lang.Override
          public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets build() {
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets result = buildPartial();
            if (!result.isInitialized()) {
              throw newUninitializedMessageException(result);
            }
            return result;
          }

          @java.lang.Override
          public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets buildPartial() {
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets result = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets(this);
            result.numFiniteBuckets_ = numFiniteBuckets_;
            result.width_ = width_;
            result.offset_ = offset_;
            onBuilt();
            return result;
          }

          @java.lang.Override
          public Builder clone() {
            return (Builder) super.clone();
          }
          @java.lang.Override
          public Builder setField(
              com.google.protobuf.Descriptors.FieldDescriptor field,
              java.lang.Object value) {
            return (Builder) super.setField(field, value);
          }
          @java.lang.Override
          public Builder clearField(
              com.google.protobuf.Descriptors.FieldDescriptor field) {
            return (Builder) super.clearField(field);
          }
          @java.lang.Override
          public Builder clearOneof(
              com.google.protobuf.Descriptors.OneofDescriptor oneof) {
            return (Builder) super.clearOneof(oneof);
          }
          @java.lang.Override
          public Builder setRepeatedField(
              com.google.protobuf.Descriptors.FieldDescriptor field,
              int index, java.lang.Object value) {
            return (Builder) super.setRepeatedField(field, index, value);
          }
          @java.lang.Override
          public Builder addRepeatedField(
              com.google.protobuf.Descriptors.FieldDescriptor field,
              java.lang.Object value) {
            return (Builder) super.addRepeatedField(field, value);
          }
          @java.lang.Override
          public Builder mergeFrom(com.google.protobuf.Message other) {
            if (other instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets) {
              return mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets)other);
            } else {
              super.mergeFrom(other);
              return this;
            }
          }

          public Builder mergeFrom(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets other) {
            if (other == POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets.getDefaultInstance()) return this;
            if (other.getNumFiniteBuckets() != 0L) {
              setNumFiniteBuckets(other.getNumFiniteBuckets());
            }
            if (other.getWidth() != 0L) {
              setWidth(other.getWidth());
            }
            if (other.getOffset() != 0L) {
              setOffset(other.getOffset());
            }
            this.mergeUnknownFields(other.unknownFields);
            onChanged();
            return this;
          }

          @java.lang.Override
          public final boolean isInitialized() {
            return true;
          }

          @java.lang.Override
          public Builder mergeFrom(
              com.google.protobuf.CodedInputStream input,
              com.google.protobuf.ExtensionRegistryLite extensionRegistry)
              throws java.io.IOException {
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets parsedMessage = null;
            try {
              parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
            } catch (com.google.protobuf.InvalidProtocolBufferException e) {
              parsedMessage = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets) e.getUnfinishedMessage();
              throw e.unwrapIOException();
            } finally {
              if (parsedMessage != null) {
                mergeFrom(parsedMessage);
              }
            }
            return this;
          }

          private long numFiniteBuckets_ ;
          /**
           * int64 num_finite_buckets = 1;
           */
          public long getNumFiniteBuckets() {
            return numFiniteBuckets_;
          }
          /**
           * int64 num_finite_buckets = 1;
           */
          public Builder setNumFiniteBuckets(long value) {
            
            numFiniteBuckets_ = value;
            onChanged();
            return this;
          }
          /**
           * int64 num_finite_buckets = 1;
           */
          public Builder clearNumFiniteBuckets() {
            
            numFiniteBuckets_ = 0L;
            onChanged();
            return this;
          }

          private long width_ ;
          /**
           * int64 width = 2;
           */
          public long getWidth() {
            return width_;
          }
          /**
           * int64 width = 2;
           */
          public Builder setWidth(long value) {
            
            width_ = value;
            onChanged();
            return this;
          }
          /**
           * int64 width = 2;
           */
          public Builder clearWidth() {
            
            width_ = 0L;
            onChanged();
            return this;
          }

          private long offset_ ;
          /**
           * int64 offset = 3;
           */
          public long getOffset() {
            return offset_;
          }
          /**
           * int64 offset = 3;
           */
          public Builder setOffset(long value) {
            
            offset_ = value;
            onChanged();
            return this;
          }
          /**
           * int64 offset = 3;
           */
          public Builder clearOffset() {
            
            offset_ = 0L;
            onChanged();
            return this;
          }
          @java.lang.Override
          public final Builder setUnknownFields(
              final com.google.protobuf.UnknownFieldSet unknownFields) {
            return super.setUnknownFieldsProto3(unknownFields);
          }

          @java.lang.Override
          public final Builder mergeUnknownFields(
              final com.google.protobuf.UnknownFieldSet unknownFields) {
            return super.mergeUnknownFields(unknownFields);
          }


          // @@protoc_insertion_point(builder_scope:POGOProtos.Data.Telemetry.Distribution.BucketOptions.LinearBuckets)
        }

        // @@protoc_insertion_point(class_scope:POGOProtos.Data.Telemetry.Distribution.BucketOptions.LinearBuckets)
        private static final POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets DEFAULT_INSTANCE;
        static {
          DEFAULT_INSTANCE = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets();
        }

        public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets getDefaultInstance() {
          return DEFAULT_INSTANCE;
        }

        private static final com.google.protobuf.Parser
            PARSER = new com.google.protobuf.AbstractParser() {
          @java.lang.Override
          public LinearBuckets parsePartialFrom(
              com.google.protobuf.CodedInputStream input,
              com.google.protobuf.ExtensionRegistryLite extensionRegistry)
              throws com.google.protobuf.InvalidProtocolBufferException {
            return new LinearBuckets(input, extensionRegistry);
          }
        };

        public static com.google.protobuf.Parser parser() {
          return PARSER;
        }

        @java.lang.Override
        public com.google.protobuf.Parser getParserForType() {
          return PARSER;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.LinearBuckets getDefaultInstanceForType() {
          return DEFAULT_INSTANCE;
        }

      }

      private int bucketTypeCase_ = 0;
      private java.lang.Object bucketType_;
      public enum BucketTypeCase
          implements com.google.protobuf.Internal.EnumLite {
        LINEAR_BUCKETS(1),
        EXPONENTIAL_BUCKETS(2),
        EXPLICIT_BUCKETS(3),
        BUCKETTYPE_NOT_SET(0);
        private final int value;
        private BucketTypeCase(int value) {
          this.value = value;
        }
        /**
         * @deprecated Use {@link #forNumber(int)} instead.
         */
        @java.lang.Deprecated
        public static BucketTypeCase valueOf(int value) {
          return forNumber(value);
        }

        public static BucketTypeCase forNumber(int value) {
          switch (value) {
            case 1: return LINEAR_BUCKETS;
            case 2: return EXPONENTIAL_BUCKETS;
            case 3: return EXPLICIT_BUCKETS;
            case 0: return BUCKETTYPE_NOT_SET;
            default: return null;
          }
        }
        public int getNumber() {
          return this.value;
        }
      };

      public BucketTypeCase
      getBucketTypeCase() {
        return BucketTypeCase.forNumber(
            bucketTypeCase_);
      }

      public static final int LINEAR_BUCKETS_FIELD_NUMBER = 1;
      /**
       * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
       */
      public boolean hasLinearBuckets() {
        return bucketTypeCase_ == 1;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets getLinearBuckets() {
        if (bucketTypeCase_ == 1) {
           return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_;
        }
        return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.getDefaultInstance();
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBucketsOrBuilder getLinearBucketsOrBuilder() {
        if (bucketTypeCase_ == 1) {
           return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_;
        }
        return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.getDefaultInstance();
      }

      public static final int EXPONENTIAL_BUCKETS_FIELD_NUMBER = 2;
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
       */
      public boolean hasExponentialBuckets() {
        return bucketTypeCase_ == 2;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets getExponentialBuckets() {
        if (bucketTypeCase_ == 2) {
           return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_;
        }
        return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.getDefaultInstance();
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBucketsOrBuilder getExponentialBucketsOrBuilder() {
        if (bucketTypeCase_ == 2) {
           return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_;
        }
        return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.getDefaultInstance();
      }

      public static final int EXPLICIT_BUCKETS_FIELD_NUMBER = 3;
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
       */
      public boolean hasExplicitBuckets() {
        return bucketTypeCase_ == 3;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets getExplicitBuckets() {
        if (bucketTypeCase_ == 3) {
           return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_;
        }
        return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.getDefaultInstance();
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBucketsOrBuilder getExplicitBucketsOrBuilder() {
        if (bucketTypeCase_ == 3) {
           return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_;
        }
        return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.getDefaultInstance();
      }

      private byte memoizedIsInitialized = -1;
      @java.lang.Override
      public final boolean isInitialized() {
        byte isInitialized = memoizedIsInitialized;
        if (isInitialized == 1) return true;
        if (isInitialized == 0) return false;

        memoizedIsInitialized = 1;
        return true;
      }

      @java.lang.Override
      public void writeTo(com.google.protobuf.CodedOutputStream output)
                          throws java.io.IOException {
        if (bucketTypeCase_ == 1) {
          output.writeMessage(1, (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_);
        }
        if (bucketTypeCase_ == 2) {
          output.writeMessage(2, (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_);
        }
        if (bucketTypeCase_ == 3) {
          output.writeMessage(3, (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_);
        }
        unknownFields.writeTo(output);
      }

      @java.lang.Override
      public int getSerializedSize() {
        int size = memoizedSize;
        if (size != -1) return size;

        size = 0;
        if (bucketTypeCase_ == 1) {
          size += com.google.protobuf.CodedOutputStream
            .computeMessageSize(1, (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_);
        }
        if (bucketTypeCase_ == 2) {
          size += com.google.protobuf.CodedOutputStream
            .computeMessageSize(2, (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_);
        }
        if (bucketTypeCase_ == 3) {
          size += com.google.protobuf.CodedOutputStream
            .computeMessageSize(3, (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_);
        }
        size += unknownFields.getSerializedSize();
        memoizedSize = size;
        return size;
      }

      @java.lang.Override
      public boolean equals(final java.lang.Object obj) {
        if (obj == this) {
         return true;
        }
        if (!(obj instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions)) {
          return super.equals(obj);
        }
        POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions other = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions) obj;

        boolean result = true;
        result = result && getBucketTypeCase().equals(
            other.getBucketTypeCase());
        if (!result) return false;
        switch (bucketTypeCase_) {
          case 1:
            result = result && getLinearBuckets()
                .equals(other.getLinearBuckets());
            break;
          case 2:
            result = result && getExponentialBuckets()
                .equals(other.getExponentialBuckets());
            break;
          case 3:
            result = result && getExplicitBuckets()
                .equals(other.getExplicitBuckets());
            break;
          case 0:
          default:
        }
        result = result && unknownFields.equals(other.unknownFields);
        return result;
      }

      @java.lang.Override
      public int hashCode() {
        if (memoizedHashCode != 0) {
          return memoizedHashCode;
        }
        int hash = 41;
        hash = (19 * hash) + getDescriptor().hashCode();
        switch (bucketTypeCase_) {
          case 1:
            hash = (37 * hash) + LINEAR_BUCKETS_FIELD_NUMBER;
            hash = (53 * hash) + getLinearBuckets().hashCode();
            break;
          case 2:
            hash = (37 * hash) + EXPONENTIAL_BUCKETS_FIELD_NUMBER;
            hash = (53 * hash) + getExponentialBuckets().hashCode();
            break;
          case 3:
            hash = (37 * hash) + EXPLICIT_BUCKETS_FIELD_NUMBER;
            hash = (53 * hash) + getExplicitBuckets().hashCode();
            break;
          case 0:
          default:
        }
        hash = (29 * hash) + unknownFields.hashCode();
        memoizedHashCode = hash;
        return hash;
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(
          java.nio.ByteBuffer data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(
          java.nio.ByteBuffer data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(
          com.google.protobuf.ByteString data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(
          com.google.protobuf.ByteString data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(byte[] data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(
          byte[] data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseDelimitedFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseDelimitedFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(
          com.google.protobuf.CodedInputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parseFrom(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }

      @java.lang.Override
      public Builder newBuilderForType() { return newBuilder(); }
      public static Builder newBuilder() {
        return DEFAULT_INSTANCE.toBuilder();
      }
      public static Builder newBuilder(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions prototype) {
        return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
      }
      @java.lang.Override
      public Builder toBuilder() {
        return this == DEFAULT_INSTANCE
            ? new Builder() : new Builder().mergeFrom(this);
      }

      @java.lang.Override
      protected Builder newBuilderForType(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        Builder builder = new Builder(parent);
        return builder;
      }
      /**
       * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.BucketOptions}
       */
      public static final class Builder extends
          com.google.protobuf.GeneratedMessageV3.Builder implements
          // @@protoc_insertion_point(builder_implements:POGOProtos.Data.Telemetry.Distribution.BucketOptions)
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptionsOrBuilder {
        public static final com.google.protobuf.Descriptors.Descriptor
            getDescriptor() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_descriptor;
        }

        @java.lang.Override
        protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
            internalGetFieldAccessorTable() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_fieldAccessorTable
              .ensureFieldAccessorsInitialized(
                  POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.Builder.class);
        }

        // Construct using POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.newBuilder()
        private Builder() {
          maybeForceBuilderInitialization();
        }

        private Builder(
            com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
          super(parent);
          maybeForceBuilderInitialization();
        }
        private void maybeForceBuilderInitialization() {
          if (com.google.protobuf.GeneratedMessageV3
                  .alwaysUseFieldBuilders) {
          }
        }
        @java.lang.Override
        public Builder clear() {
          super.clear();
          bucketTypeCase_ = 0;
          bucketType_ = null;
          return this;
        }

        @java.lang.Override
        public com.google.protobuf.Descriptors.Descriptor
            getDescriptorForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_descriptor;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions getDefaultInstanceForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.getDefaultInstance();
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions build() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions result = buildPartial();
          if (!result.isInitialized()) {
            throw newUninitializedMessageException(result);
          }
          return result;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions buildPartial() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions result = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions(this);
          if (bucketTypeCase_ == 1) {
            if (linearBucketsBuilder_ == null) {
              result.bucketType_ = bucketType_;
            } else {
              result.bucketType_ = linearBucketsBuilder_.build();
            }
          }
          if (bucketTypeCase_ == 2) {
            if (exponentialBucketsBuilder_ == null) {
              result.bucketType_ = bucketType_;
            } else {
              result.bucketType_ = exponentialBucketsBuilder_.build();
            }
          }
          if (bucketTypeCase_ == 3) {
            if (explicitBucketsBuilder_ == null) {
              result.bucketType_ = bucketType_;
            } else {
              result.bucketType_ = explicitBucketsBuilder_.build();
            }
          }
          result.bucketTypeCase_ = bucketTypeCase_;
          onBuilt();
          return result;
        }

        @java.lang.Override
        public Builder clone() {
          return (Builder) super.clone();
        }
        @java.lang.Override
        public Builder setField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.setField(field, value);
        }
        @java.lang.Override
        public Builder clearField(
            com.google.protobuf.Descriptors.FieldDescriptor field) {
          return (Builder) super.clearField(field);
        }
        @java.lang.Override
        public Builder clearOneof(
            com.google.protobuf.Descriptors.OneofDescriptor oneof) {
          return (Builder) super.clearOneof(oneof);
        }
        @java.lang.Override
        public Builder setRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            int index, java.lang.Object value) {
          return (Builder) super.setRepeatedField(field, index, value);
        }
        @java.lang.Override
        public Builder addRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.addRepeatedField(field, value);
        }
        @java.lang.Override
        public Builder mergeFrom(com.google.protobuf.Message other) {
          if (other instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions) {
            return mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions)other);
          } else {
            super.mergeFrom(other);
            return this;
          }
        }

        public Builder mergeFrom(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions other) {
          if (other == POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.getDefaultInstance()) return this;
          switch (other.getBucketTypeCase()) {
            case LINEAR_BUCKETS: {
              mergeLinearBuckets(other.getLinearBuckets());
              break;
            }
            case EXPONENTIAL_BUCKETS: {
              mergeExponentialBuckets(other.getExponentialBuckets());
              break;
            }
            case EXPLICIT_BUCKETS: {
              mergeExplicitBuckets(other.getExplicitBuckets());
              break;
            }
            case BUCKETTYPE_NOT_SET: {
              break;
            }
          }
          this.mergeUnknownFields(other.unknownFields);
          onChanged();
          return this;
        }

        @java.lang.Override
        public final boolean isInitialized() {
          return true;
        }

        @java.lang.Override
        public Builder mergeFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions parsedMessage = null;
          try {
            parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
          } catch (com.google.protobuf.InvalidProtocolBufferException e) {
            parsedMessage = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions) e.getUnfinishedMessage();
            throw e.unwrapIOException();
          } finally {
            if (parsedMessage != null) {
              mergeFrom(parsedMessage);
            }
          }
          return this;
        }
        private int bucketTypeCase_ = 0;
        private java.lang.Object bucketType_;
        public BucketTypeCase
            getBucketTypeCase() {
          return BucketTypeCase.forNumber(
              bucketTypeCase_);
        }

        public Builder clearBucketType() {
          bucketTypeCase_ = 0;
          bucketType_ = null;
          onChanged();
          return this;
        }


        private com.google.protobuf.SingleFieldBuilderV3<
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBucketsOrBuilder> linearBucketsBuilder_;
        /**
         * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
         */
        public boolean hasLinearBuckets() {
          return bucketTypeCase_ == 1;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
         */
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets getLinearBuckets() {
          if (linearBucketsBuilder_ == null) {
            if (bucketTypeCase_ == 1) {
              return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_;
            }
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.getDefaultInstance();
          } else {
            if (bucketTypeCase_ == 1) {
              return linearBucketsBuilder_.getMessage();
            }
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.getDefaultInstance();
          }
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
         */
        public Builder setLinearBuckets(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets value) {
          if (linearBucketsBuilder_ == null) {
            if (value == null) {
              throw new NullPointerException();
            }
            bucketType_ = value;
            onChanged();
          } else {
            linearBucketsBuilder_.setMessage(value);
          }
          bucketTypeCase_ = 1;
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
         */
        public Builder setLinearBuckets(
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.Builder builderForValue) {
          if (linearBucketsBuilder_ == null) {
            bucketType_ = builderForValue.build();
            onChanged();
          } else {
            linearBucketsBuilder_.setMessage(builderForValue.build());
          }
          bucketTypeCase_ = 1;
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
         */
        public Builder mergeLinearBuckets(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets value) {
          if (linearBucketsBuilder_ == null) {
            if (bucketTypeCase_ == 1 &&
                bucketType_ != POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.getDefaultInstance()) {
              bucketType_ = POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.newBuilder((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_)
                  .mergeFrom(value).buildPartial();
            } else {
              bucketType_ = value;
            }
            onChanged();
          } else {
            if (bucketTypeCase_ == 1) {
              linearBucketsBuilder_.mergeFrom(value);
            }
            linearBucketsBuilder_.setMessage(value);
          }
          bucketTypeCase_ = 1;
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
         */
        public Builder clearLinearBuckets() {
          if (linearBucketsBuilder_ == null) {
            if (bucketTypeCase_ == 1) {
              bucketTypeCase_ = 0;
              bucketType_ = null;
              onChanged();
            }
          } else {
            if (bucketTypeCase_ == 1) {
              bucketTypeCase_ = 0;
              bucketType_ = null;
            }
            linearBucketsBuilder_.clear();
          }
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
         */
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.Builder getLinearBucketsBuilder() {
          return getLinearBucketsFieldBuilder().getBuilder();
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
         */
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBucketsOrBuilder getLinearBucketsOrBuilder() {
          if ((bucketTypeCase_ == 1) && (linearBucketsBuilder_ != null)) {
            return linearBucketsBuilder_.getMessageOrBuilder();
          } else {
            if (bucketTypeCase_ == 1) {
              return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_;
            }
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.getDefaultInstance();
          }
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.LinearBuckets linear_buckets = 1;
         */
        private com.google.protobuf.SingleFieldBuilderV3<
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBucketsOrBuilder> 
            getLinearBucketsFieldBuilder() {
          if (linearBucketsBuilder_ == null) {
            if (!(bucketTypeCase_ == 1)) {
              bucketType_ = POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.getDefaultInstance();
            }
            linearBucketsBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBucketsOrBuilder>(
                    (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) bucketType_,
                    getParentForChildren(),
                    isClean());
            bucketType_ = null;
          }
          bucketTypeCase_ = 1;
          onChanged();;
          return linearBucketsBuilder_;
        }

        private com.google.protobuf.SingleFieldBuilderV3<
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBucketsOrBuilder> exponentialBucketsBuilder_;
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
         */
        public boolean hasExponentialBuckets() {
          return bucketTypeCase_ == 2;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
         */
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets getExponentialBuckets() {
          if (exponentialBucketsBuilder_ == null) {
            if (bucketTypeCase_ == 2) {
              return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_;
            }
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.getDefaultInstance();
          } else {
            if (bucketTypeCase_ == 2) {
              return exponentialBucketsBuilder_.getMessage();
            }
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.getDefaultInstance();
          }
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
         */
        public Builder setExponentialBuckets(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets value) {
          if (exponentialBucketsBuilder_ == null) {
            if (value == null) {
              throw new NullPointerException();
            }
            bucketType_ = value;
            onChanged();
          } else {
            exponentialBucketsBuilder_.setMessage(value);
          }
          bucketTypeCase_ = 2;
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
         */
        public Builder setExponentialBuckets(
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.Builder builderForValue) {
          if (exponentialBucketsBuilder_ == null) {
            bucketType_ = builderForValue.build();
            onChanged();
          } else {
            exponentialBucketsBuilder_.setMessage(builderForValue.build());
          }
          bucketTypeCase_ = 2;
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
         */
        public Builder mergeExponentialBuckets(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets value) {
          if (exponentialBucketsBuilder_ == null) {
            if (bucketTypeCase_ == 2 &&
                bucketType_ != POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.getDefaultInstance()) {
              bucketType_ = POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.newBuilder((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_)
                  .mergeFrom(value).buildPartial();
            } else {
              bucketType_ = value;
            }
            onChanged();
          } else {
            if (bucketTypeCase_ == 2) {
              exponentialBucketsBuilder_.mergeFrom(value);
            }
            exponentialBucketsBuilder_.setMessage(value);
          }
          bucketTypeCase_ = 2;
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
         */
        public Builder clearExponentialBuckets() {
          if (exponentialBucketsBuilder_ == null) {
            if (bucketTypeCase_ == 2) {
              bucketTypeCase_ = 0;
              bucketType_ = null;
              onChanged();
            }
          } else {
            if (bucketTypeCase_ == 2) {
              bucketTypeCase_ = 0;
              bucketType_ = null;
            }
            exponentialBucketsBuilder_.clear();
          }
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
         */
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.Builder getExponentialBucketsBuilder() {
          return getExponentialBucketsFieldBuilder().getBuilder();
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
         */
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBucketsOrBuilder getExponentialBucketsOrBuilder() {
          if ((bucketTypeCase_ == 2) && (exponentialBucketsBuilder_ != null)) {
            return exponentialBucketsBuilder_.getMessageOrBuilder();
          } else {
            if (bucketTypeCase_ == 2) {
              return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_;
            }
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.getDefaultInstance();
          }
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets exponential_buckets = 2;
         */
        private com.google.protobuf.SingleFieldBuilderV3<
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBucketsOrBuilder> 
            getExponentialBucketsFieldBuilder() {
          if (exponentialBucketsBuilder_ == null) {
            if (!(bucketTypeCase_ == 2)) {
              bucketType_ = POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.getDefaultInstance();
            }
            exponentialBucketsBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBucketsOrBuilder>(
                    (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) bucketType_,
                    getParentForChildren(),
                    isClean());
            bucketType_ = null;
          }
          bucketTypeCase_ = 2;
          onChanged();;
          return exponentialBucketsBuilder_;
        }

        private com.google.protobuf.SingleFieldBuilderV3<
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBucketsOrBuilder> explicitBucketsBuilder_;
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
         */
        public boolean hasExplicitBuckets() {
          return bucketTypeCase_ == 3;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
         */
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets getExplicitBuckets() {
          if (explicitBucketsBuilder_ == null) {
            if (bucketTypeCase_ == 3) {
              return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_;
            }
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.getDefaultInstance();
          } else {
            if (bucketTypeCase_ == 3) {
              return explicitBucketsBuilder_.getMessage();
            }
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.getDefaultInstance();
          }
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
         */
        public Builder setExplicitBuckets(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets value) {
          if (explicitBucketsBuilder_ == null) {
            if (value == null) {
              throw new NullPointerException();
            }
            bucketType_ = value;
            onChanged();
          } else {
            explicitBucketsBuilder_.setMessage(value);
          }
          bucketTypeCase_ = 3;
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
         */
        public Builder setExplicitBuckets(
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.Builder builderForValue) {
          if (explicitBucketsBuilder_ == null) {
            bucketType_ = builderForValue.build();
            onChanged();
          } else {
            explicitBucketsBuilder_.setMessage(builderForValue.build());
          }
          bucketTypeCase_ = 3;
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
         */
        public Builder mergeExplicitBuckets(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets value) {
          if (explicitBucketsBuilder_ == null) {
            if (bucketTypeCase_ == 3 &&
                bucketType_ != POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.getDefaultInstance()) {
              bucketType_ = POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.newBuilder((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_)
                  .mergeFrom(value).buildPartial();
            } else {
              bucketType_ = value;
            }
            onChanged();
          } else {
            if (bucketTypeCase_ == 3) {
              explicitBucketsBuilder_.mergeFrom(value);
            }
            explicitBucketsBuilder_.setMessage(value);
          }
          bucketTypeCase_ = 3;
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
         */
        public Builder clearExplicitBuckets() {
          if (explicitBucketsBuilder_ == null) {
            if (bucketTypeCase_ == 3) {
              bucketTypeCase_ = 0;
              bucketType_ = null;
              onChanged();
            }
          } else {
            if (bucketTypeCase_ == 3) {
              bucketTypeCase_ = 0;
              bucketType_ = null;
            }
            explicitBucketsBuilder_.clear();
          }
          return this;
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
         */
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.Builder getExplicitBucketsBuilder() {
          return getExplicitBucketsFieldBuilder().getBuilder();
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
         */
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBucketsOrBuilder getExplicitBucketsOrBuilder() {
          if ((bucketTypeCase_ == 3) && (explicitBucketsBuilder_ != null)) {
            return explicitBucketsBuilder_.getMessageOrBuilder();
          } else {
            if (bucketTypeCase_ == 3) {
              return (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_;
            }
            return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.getDefaultInstance();
          }
        }
        /**
         * .POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets explicit_buckets = 3;
         */
        private com.google.protobuf.SingleFieldBuilderV3<
            POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBucketsOrBuilder> 
            getExplicitBucketsFieldBuilder() {
          if (explicitBucketsBuilder_ == null) {
            if (!(bucketTypeCase_ == 3)) {
              bucketType_ = POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.getDefaultInstance();
            }
            explicitBucketsBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBucketsOrBuilder>(
                    (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) bucketType_,
                    getParentForChildren(),
                    isClean());
            bucketType_ = null;
          }
          bucketTypeCase_ = 3;
          onChanged();;
          return explicitBucketsBuilder_;
        }
        @java.lang.Override
        public final Builder setUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.setUnknownFieldsProto3(unknownFields);
        }

        @java.lang.Override
        public final Builder mergeUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.mergeUnknownFields(unknownFields);
        }


        // @@protoc_insertion_point(builder_scope:POGOProtos.Data.Telemetry.Distribution.BucketOptions)
      }

      // @@protoc_insertion_point(class_scope:POGOProtos.Data.Telemetry.Distribution.BucketOptions)
      private static final POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions DEFAULT_INSTANCE;
      static {
        DEFAULT_INSTANCE = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions();
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions getDefaultInstance() {
        return DEFAULT_INSTANCE;
      }

      private static final com.google.protobuf.Parser
          PARSER = new com.google.protobuf.AbstractParser() {
        @java.lang.Override
        public BucketOptions parsePartialFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return new BucketOptions(input, extensionRegistry);
        }
      };

      public static com.google.protobuf.Parser parser() {
        return PARSER;
      }

      @java.lang.Override
      public com.google.protobuf.Parser getParserForType() {
        return PARSER;
      }

      @java.lang.Override
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions getDefaultInstanceForType() {
        return DEFAULT_INSTANCE;
      }

    }

    public interface ExplicitBucketsOrBuilder extends
        // @@protoc_insertion_point(interface_extends:POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets)
        com.google.protobuf.MessageOrBuilder {

      /**
       * repeated int64 bounds = 1;
       */
      java.util.List getBoundsList();
      /**
       * repeated int64 bounds = 1;
       */
      int getBoundsCount();
      /**
       * repeated int64 bounds = 1;
       */
      long getBounds(int index);
    }
    /**
     * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets}
     */
    public  static final class ExplicitBuckets extends
        com.google.protobuf.GeneratedMessageV3 implements
        // @@protoc_insertion_point(message_implements:POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets)
        ExplicitBucketsOrBuilder {
    private static final long serialVersionUID = 0L;
      // Use ExplicitBuckets.newBuilder() to construct.
      private ExplicitBuckets(com.google.protobuf.GeneratedMessageV3.Builder builder) {
        super(builder);
      }
      private ExplicitBuckets() {
        bounds_ = java.util.Collections.emptyList();
      }

      @java.lang.Override
      public final com.google.protobuf.UnknownFieldSet
      getUnknownFields() {
        return this.unknownFields;
      }
      private ExplicitBuckets(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        this();
        if (extensionRegistry == null) {
          throw new java.lang.NullPointerException();
        }
        int mutable_bitField0_ = 0;
        com.google.protobuf.UnknownFieldSet.Builder unknownFields =
            com.google.protobuf.UnknownFieldSet.newBuilder();
        try {
          boolean done = false;
          while (!done) {
            int tag = input.readTag();
            switch (tag) {
              case 0:
                done = true;
                break;
              case 8: {
                if (!((mutable_bitField0_ & 0x00000001) == 0x00000001)) {
                  bounds_ = new java.util.ArrayList();
                  mutable_bitField0_ |= 0x00000001;
                }
                bounds_.add(input.readInt64());
                break;
              }
              case 10: {
                int length = input.readRawVarint32();
                int limit = input.pushLimit(length);
                if (!((mutable_bitField0_ & 0x00000001) == 0x00000001) && input.getBytesUntilLimit() > 0) {
                  bounds_ = new java.util.ArrayList();
                  mutable_bitField0_ |= 0x00000001;
                }
                while (input.getBytesUntilLimit() > 0) {
                  bounds_.add(input.readInt64());
                }
                input.popLimit(limit);
                break;
              }
              default: {
                if (!parseUnknownFieldProto3(
                    input, unknownFields, extensionRegistry, tag)) {
                  done = true;
                }
                break;
              }
            }
          }
        } catch (com.google.protobuf.InvalidProtocolBufferException e) {
          throw e.setUnfinishedMessage(this);
        } catch (java.io.IOException e) {
          throw new com.google.protobuf.InvalidProtocolBufferException(
              e).setUnfinishedMessage(this);
        } finally {
          if (((mutable_bitField0_ & 0x00000001) == 0x00000001)) {
            bounds_ = java.util.Collections.unmodifiableList(bounds_);
          }
          this.unknownFields = unknownFields.build();
          makeExtensionsImmutable();
        }
      }
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.Builder.class);
      }

      public static final int BOUNDS_FIELD_NUMBER = 1;
      private java.util.List bounds_;
      /**
       * repeated int64 bounds = 1;
       */
      public java.util.List
          getBoundsList() {
        return bounds_;
      }
      /**
       * repeated int64 bounds = 1;
       */
      public int getBoundsCount() {
        return bounds_.size();
      }
      /**
       * repeated int64 bounds = 1;
       */
      public long getBounds(int index) {
        return bounds_.get(index);
      }
      private int boundsMemoizedSerializedSize = -1;

      private byte memoizedIsInitialized = -1;
      @java.lang.Override
      public final boolean isInitialized() {
        byte isInitialized = memoizedIsInitialized;
        if (isInitialized == 1) return true;
        if (isInitialized == 0) return false;

        memoizedIsInitialized = 1;
        return true;
      }

      @java.lang.Override
      public void writeTo(com.google.protobuf.CodedOutputStream output)
                          throws java.io.IOException {
        getSerializedSize();
        if (getBoundsList().size() > 0) {
          output.writeUInt32NoTag(10);
          output.writeUInt32NoTag(boundsMemoizedSerializedSize);
        }
        for (int i = 0; i < bounds_.size(); i++) {
          output.writeInt64NoTag(bounds_.get(i));
        }
        unknownFields.writeTo(output);
      }

      @java.lang.Override
      public int getSerializedSize() {
        int size = memoizedSize;
        if (size != -1) return size;

        size = 0;
        {
          int dataSize = 0;
          for (int i = 0; i < bounds_.size(); i++) {
            dataSize += com.google.protobuf.CodedOutputStream
              .computeInt64SizeNoTag(bounds_.get(i));
          }
          size += dataSize;
          if (!getBoundsList().isEmpty()) {
            size += 1;
            size += com.google.protobuf.CodedOutputStream
                .computeInt32SizeNoTag(dataSize);
          }
          boundsMemoizedSerializedSize = dataSize;
        }
        size += unknownFields.getSerializedSize();
        memoizedSize = size;
        return size;
      }

      @java.lang.Override
      public boolean equals(final java.lang.Object obj) {
        if (obj == this) {
         return true;
        }
        if (!(obj instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets)) {
          return super.equals(obj);
        }
        POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets other = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) obj;

        boolean result = true;
        result = result && getBoundsList()
            .equals(other.getBoundsList());
        result = result && unknownFields.equals(other.unknownFields);
        return result;
      }

      @java.lang.Override
      public int hashCode() {
        if (memoizedHashCode != 0) {
          return memoizedHashCode;
        }
        int hash = 41;
        hash = (19 * hash) + getDescriptor().hashCode();
        if (getBoundsCount() > 0) {
          hash = (37 * hash) + BOUNDS_FIELD_NUMBER;
          hash = (53 * hash) + getBoundsList().hashCode();
        }
        hash = (29 * hash) + unknownFields.hashCode();
        memoizedHashCode = hash;
        return hash;
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(
          java.nio.ByteBuffer data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(
          java.nio.ByteBuffer data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(
          com.google.protobuf.ByteString data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(
          com.google.protobuf.ByteString data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(byte[] data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(
          byte[] data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseDelimitedFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseDelimitedFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(
          com.google.protobuf.CodedInputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parseFrom(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }

      @java.lang.Override
      public Builder newBuilderForType() { return newBuilder(); }
      public static Builder newBuilder() {
        return DEFAULT_INSTANCE.toBuilder();
      }
      public static Builder newBuilder(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets prototype) {
        return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
      }
      @java.lang.Override
      public Builder toBuilder() {
        return this == DEFAULT_INSTANCE
            ? new Builder() : new Builder().mergeFrom(this);
      }

      @java.lang.Override
      protected Builder newBuilderForType(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        Builder builder = new Builder(parent);
        return builder;
      }
      /**
       * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets}
       */
      public static final class Builder extends
          com.google.protobuf.GeneratedMessageV3.Builder implements
          // @@protoc_insertion_point(builder_implements:POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets)
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBucketsOrBuilder {
        public static final com.google.protobuf.Descriptors.Descriptor
            getDescriptor() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_descriptor;
        }

        @java.lang.Override
        protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
            internalGetFieldAccessorTable() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_fieldAccessorTable
              .ensureFieldAccessorsInitialized(
                  POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.Builder.class);
        }

        // Construct using POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.newBuilder()
        private Builder() {
          maybeForceBuilderInitialization();
        }

        private Builder(
            com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
          super(parent);
          maybeForceBuilderInitialization();
        }
        private void maybeForceBuilderInitialization() {
          if (com.google.protobuf.GeneratedMessageV3
                  .alwaysUseFieldBuilders) {
          }
        }
        @java.lang.Override
        public Builder clear() {
          super.clear();
          bounds_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000001);
          return this;
        }

        @java.lang.Override
        public com.google.protobuf.Descriptors.Descriptor
            getDescriptorForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_descriptor;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets getDefaultInstanceForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.getDefaultInstance();
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets build() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets result = buildPartial();
          if (!result.isInitialized()) {
            throw newUninitializedMessageException(result);
          }
          return result;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets buildPartial() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets result = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets(this);
          int from_bitField0_ = bitField0_;
          if (((bitField0_ & 0x00000001) == 0x00000001)) {
            bounds_ = java.util.Collections.unmodifiableList(bounds_);
            bitField0_ = (bitField0_ & ~0x00000001);
          }
          result.bounds_ = bounds_;
          onBuilt();
          return result;
        }

        @java.lang.Override
        public Builder clone() {
          return (Builder) super.clone();
        }
        @java.lang.Override
        public Builder setField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.setField(field, value);
        }
        @java.lang.Override
        public Builder clearField(
            com.google.protobuf.Descriptors.FieldDescriptor field) {
          return (Builder) super.clearField(field);
        }
        @java.lang.Override
        public Builder clearOneof(
            com.google.protobuf.Descriptors.OneofDescriptor oneof) {
          return (Builder) super.clearOneof(oneof);
        }
        @java.lang.Override
        public Builder setRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            int index, java.lang.Object value) {
          return (Builder) super.setRepeatedField(field, index, value);
        }
        @java.lang.Override
        public Builder addRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.addRepeatedField(field, value);
        }
        @java.lang.Override
        public Builder mergeFrom(com.google.protobuf.Message other) {
          if (other instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) {
            return mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets)other);
          } else {
            super.mergeFrom(other);
            return this;
          }
        }

        public Builder mergeFrom(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets other) {
          if (other == POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets.getDefaultInstance()) return this;
          if (!other.bounds_.isEmpty()) {
            if (bounds_.isEmpty()) {
              bounds_ = other.bounds_;
              bitField0_ = (bitField0_ & ~0x00000001);
            } else {
              ensureBoundsIsMutable();
              bounds_.addAll(other.bounds_);
            }
            onChanged();
          }
          this.mergeUnknownFields(other.unknownFields);
          onChanged();
          return this;
        }

        @java.lang.Override
        public final boolean isInitialized() {
          return true;
        }

        @java.lang.Override
        public Builder mergeFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets parsedMessage = null;
          try {
            parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
          } catch (com.google.protobuf.InvalidProtocolBufferException e) {
            parsedMessage = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets) e.getUnfinishedMessage();
            throw e.unwrapIOException();
          } finally {
            if (parsedMessage != null) {
              mergeFrom(parsedMessage);
            }
          }
          return this;
        }
        private int bitField0_;

        private java.util.List bounds_ = java.util.Collections.emptyList();
        private void ensureBoundsIsMutable() {
          if (!((bitField0_ & 0x00000001) == 0x00000001)) {
            bounds_ = new java.util.ArrayList(bounds_);
            bitField0_ |= 0x00000001;
           }
        }
        /**
         * repeated int64 bounds = 1;
         */
        public java.util.List
            getBoundsList() {
          return java.util.Collections.unmodifiableList(bounds_);
        }
        /**
         * repeated int64 bounds = 1;
         */
        public int getBoundsCount() {
          return bounds_.size();
        }
        /**
         * repeated int64 bounds = 1;
         */
        public long getBounds(int index) {
          return bounds_.get(index);
        }
        /**
         * repeated int64 bounds = 1;
         */
        public Builder setBounds(
            int index, long value) {
          ensureBoundsIsMutable();
          bounds_.set(index, value);
          onChanged();
          return this;
        }
        /**
         * repeated int64 bounds = 1;
         */
        public Builder addBounds(long value) {
          ensureBoundsIsMutable();
          bounds_.add(value);
          onChanged();
          return this;
        }
        /**
         * repeated int64 bounds = 1;
         */
        public Builder addAllBounds(
            java.lang.Iterable values) {
          ensureBoundsIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, bounds_);
          onChanged();
          return this;
        }
        /**
         * repeated int64 bounds = 1;
         */
        public Builder clearBounds() {
          bounds_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000001);
          onChanged();
          return this;
        }
        @java.lang.Override
        public final Builder setUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.setUnknownFieldsProto3(unknownFields);
        }

        @java.lang.Override
        public final Builder mergeUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.mergeUnknownFields(unknownFields);
        }


        // @@protoc_insertion_point(builder_scope:POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets)
      }

      // @@protoc_insertion_point(class_scope:POGOProtos.Data.Telemetry.Distribution.ExplicitBuckets)
      private static final POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets DEFAULT_INSTANCE;
      static {
        DEFAULT_INSTANCE = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets();
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets getDefaultInstance() {
        return DEFAULT_INSTANCE;
      }

      private static final com.google.protobuf.Parser
          PARSER = new com.google.protobuf.AbstractParser() {
        @java.lang.Override
        public ExplicitBuckets parsePartialFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return new ExplicitBuckets(input, extensionRegistry);
        }
      };

      public static com.google.protobuf.Parser parser() {
        return PARSER;
      }

      @java.lang.Override
      public com.google.protobuf.Parser getParserForType() {
        return PARSER;
      }

      @java.lang.Override
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExplicitBuckets getDefaultInstanceForType() {
        return DEFAULT_INSTANCE;
      }

    }

    public interface ExponentialBucketsOrBuilder extends
        // @@protoc_insertion_point(interface_extends:POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets)
        com.google.protobuf.MessageOrBuilder {

      /**
       * int64 num_finite_buckets = 1;
       */
      long getNumFiniteBuckets();

      /**
       * float growth_factor = 2;
       */
      float getGrowthFactor();

      /**
       * float scale = 3;
       */
      float getScale();
    }
    /**
     * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets}
     */
    public  static final class ExponentialBuckets extends
        com.google.protobuf.GeneratedMessageV3 implements
        // @@protoc_insertion_point(message_implements:POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets)
        ExponentialBucketsOrBuilder {
    private static final long serialVersionUID = 0L;
      // Use ExponentialBuckets.newBuilder() to construct.
      private ExponentialBuckets(com.google.protobuf.GeneratedMessageV3.Builder builder) {
        super(builder);
      }
      private ExponentialBuckets() {
        numFiniteBuckets_ = 0L;
        growthFactor_ = 0F;
        scale_ = 0F;
      }

      @java.lang.Override
      public final com.google.protobuf.UnknownFieldSet
      getUnknownFields() {
        return this.unknownFields;
      }
      private ExponentialBuckets(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        this();
        if (extensionRegistry == null) {
          throw new java.lang.NullPointerException();
        }
        int mutable_bitField0_ = 0;
        com.google.protobuf.UnknownFieldSet.Builder unknownFields =
            com.google.protobuf.UnknownFieldSet.newBuilder();
        try {
          boolean done = false;
          while (!done) {
            int tag = input.readTag();
            switch (tag) {
              case 0:
                done = true;
                break;
              case 8: {

                numFiniteBuckets_ = input.readInt64();
                break;
              }
              case 21: {

                growthFactor_ = input.readFloat();
                break;
              }
              case 29: {

                scale_ = input.readFloat();
                break;
              }
              default: {
                if (!parseUnknownFieldProto3(
                    input, unknownFields, extensionRegistry, tag)) {
                  done = true;
                }
                break;
              }
            }
          }
        } catch (com.google.protobuf.InvalidProtocolBufferException e) {
          throw e.setUnfinishedMessage(this);
        } catch (java.io.IOException e) {
          throw new com.google.protobuf.InvalidProtocolBufferException(
              e).setUnfinishedMessage(this);
        } finally {
          this.unknownFields = unknownFields.build();
          makeExtensionsImmutable();
        }
      }
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.Builder.class);
      }

      public static final int NUM_FINITE_BUCKETS_FIELD_NUMBER = 1;
      private long numFiniteBuckets_;
      /**
       * int64 num_finite_buckets = 1;
       */
      public long getNumFiniteBuckets() {
        return numFiniteBuckets_;
      }

      public static final int GROWTH_FACTOR_FIELD_NUMBER = 2;
      private float growthFactor_;
      /**
       * float growth_factor = 2;
       */
      public float getGrowthFactor() {
        return growthFactor_;
      }

      public static final int SCALE_FIELD_NUMBER = 3;
      private float scale_;
      /**
       * float scale = 3;
       */
      public float getScale() {
        return scale_;
      }

      private byte memoizedIsInitialized = -1;
      @java.lang.Override
      public final boolean isInitialized() {
        byte isInitialized = memoizedIsInitialized;
        if (isInitialized == 1) return true;
        if (isInitialized == 0) return false;

        memoizedIsInitialized = 1;
        return true;
      }

      @java.lang.Override
      public void writeTo(com.google.protobuf.CodedOutputStream output)
                          throws java.io.IOException {
        if (numFiniteBuckets_ != 0L) {
          output.writeInt64(1, numFiniteBuckets_);
        }
        if (growthFactor_ != 0F) {
          output.writeFloat(2, growthFactor_);
        }
        if (scale_ != 0F) {
          output.writeFloat(3, scale_);
        }
        unknownFields.writeTo(output);
      }

      @java.lang.Override
      public int getSerializedSize() {
        int size = memoizedSize;
        if (size != -1) return size;

        size = 0;
        if (numFiniteBuckets_ != 0L) {
          size += com.google.protobuf.CodedOutputStream
            .computeInt64Size(1, numFiniteBuckets_);
        }
        if (growthFactor_ != 0F) {
          size += com.google.protobuf.CodedOutputStream
            .computeFloatSize(2, growthFactor_);
        }
        if (scale_ != 0F) {
          size += com.google.protobuf.CodedOutputStream
            .computeFloatSize(3, scale_);
        }
        size += unknownFields.getSerializedSize();
        memoizedSize = size;
        return size;
      }

      @java.lang.Override
      public boolean equals(final java.lang.Object obj) {
        if (obj == this) {
         return true;
        }
        if (!(obj instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets)) {
          return super.equals(obj);
        }
        POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets other = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) obj;

        boolean result = true;
        result = result && (getNumFiniteBuckets()
            == other.getNumFiniteBuckets());
        result = result && (
            java.lang.Float.floatToIntBits(getGrowthFactor())
            == java.lang.Float.floatToIntBits(
                other.getGrowthFactor()));
        result = result && (
            java.lang.Float.floatToIntBits(getScale())
            == java.lang.Float.floatToIntBits(
                other.getScale()));
        result = result && unknownFields.equals(other.unknownFields);
        return result;
      }

      @java.lang.Override
      public int hashCode() {
        if (memoizedHashCode != 0) {
          return memoizedHashCode;
        }
        int hash = 41;
        hash = (19 * hash) + getDescriptor().hashCode();
        hash = (37 * hash) + NUM_FINITE_BUCKETS_FIELD_NUMBER;
        hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
            getNumFiniteBuckets());
        hash = (37 * hash) + GROWTH_FACTOR_FIELD_NUMBER;
        hash = (53 * hash) + java.lang.Float.floatToIntBits(
            getGrowthFactor());
        hash = (37 * hash) + SCALE_FIELD_NUMBER;
        hash = (53 * hash) + java.lang.Float.floatToIntBits(
            getScale());
        hash = (29 * hash) + unknownFields.hashCode();
        memoizedHashCode = hash;
        return hash;
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(
          java.nio.ByteBuffer data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(
          java.nio.ByteBuffer data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(
          com.google.protobuf.ByteString data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(
          com.google.protobuf.ByteString data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(byte[] data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(
          byte[] data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseDelimitedFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseDelimitedFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(
          com.google.protobuf.CodedInputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parseFrom(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }

      @java.lang.Override
      public Builder newBuilderForType() { return newBuilder(); }
      public static Builder newBuilder() {
        return DEFAULT_INSTANCE.toBuilder();
      }
      public static Builder newBuilder(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets prototype) {
        return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
      }
      @java.lang.Override
      public Builder toBuilder() {
        return this == DEFAULT_INSTANCE
            ? new Builder() : new Builder().mergeFrom(this);
      }

      @java.lang.Override
      protected Builder newBuilderForType(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        Builder builder = new Builder(parent);
        return builder;
      }
      /**
       * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets}
       */
      public static final class Builder extends
          com.google.protobuf.GeneratedMessageV3.Builder implements
          // @@protoc_insertion_point(builder_implements:POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets)
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBucketsOrBuilder {
        public static final com.google.protobuf.Descriptors.Descriptor
            getDescriptor() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_descriptor;
        }

        @java.lang.Override
        protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
            internalGetFieldAccessorTable() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_fieldAccessorTable
              .ensureFieldAccessorsInitialized(
                  POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.Builder.class);
        }

        // Construct using POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.newBuilder()
        private Builder() {
          maybeForceBuilderInitialization();
        }

        private Builder(
            com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
          super(parent);
          maybeForceBuilderInitialization();
        }
        private void maybeForceBuilderInitialization() {
          if (com.google.protobuf.GeneratedMessageV3
                  .alwaysUseFieldBuilders) {
          }
        }
        @java.lang.Override
        public Builder clear() {
          super.clear();
          numFiniteBuckets_ = 0L;

          growthFactor_ = 0F;

          scale_ = 0F;

          return this;
        }

        @java.lang.Override
        public com.google.protobuf.Descriptors.Descriptor
            getDescriptorForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_descriptor;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets getDefaultInstanceForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.getDefaultInstance();
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets build() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets result = buildPartial();
          if (!result.isInitialized()) {
            throw newUninitializedMessageException(result);
          }
          return result;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets buildPartial() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets result = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets(this);
          result.numFiniteBuckets_ = numFiniteBuckets_;
          result.growthFactor_ = growthFactor_;
          result.scale_ = scale_;
          onBuilt();
          return result;
        }

        @java.lang.Override
        public Builder clone() {
          return (Builder) super.clone();
        }
        @java.lang.Override
        public Builder setField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.setField(field, value);
        }
        @java.lang.Override
        public Builder clearField(
            com.google.protobuf.Descriptors.FieldDescriptor field) {
          return (Builder) super.clearField(field);
        }
        @java.lang.Override
        public Builder clearOneof(
            com.google.protobuf.Descriptors.OneofDescriptor oneof) {
          return (Builder) super.clearOneof(oneof);
        }
        @java.lang.Override
        public Builder setRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            int index, java.lang.Object value) {
          return (Builder) super.setRepeatedField(field, index, value);
        }
        @java.lang.Override
        public Builder addRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.addRepeatedField(field, value);
        }
        @java.lang.Override
        public Builder mergeFrom(com.google.protobuf.Message other) {
          if (other instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) {
            return mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets)other);
          } else {
            super.mergeFrom(other);
            return this;
          }
        }

        public Builder mergeFrom(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets other) {
          if (other == POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets.getDefaultInstance()) return this;
          if (other.getNumFiniteBuckets() != 0L) {
            setNumFiniteBuckets(other.getNumFiniteBuckets());
          }
          if (other.getGrowthFactor() != 0F) {
            setGrowthFactor(other.getGrowthFactor());
          }
          if (other.getScale() != 0F) {
            setScale(other.getScale());
          }
          this.mergeUnknownFields(other.unknownFields);
          onChanged();
          return this;
        }

        @java.lang.Override
        public final boolean isInitialized() {
          return true;
        }

        @java.lang.Override
        public Builder mergeFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets parsedMessage = null;
          try {
            parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
          } catch (com.google.protobuf.InvalidProtocolBufferException e) {
            parsedMessage = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets) e.getUnfinishedMessage();
            throw e.unwrapIOException();
          } finally {
            if (parsedMessage != null) {
              mergeFrom(parsedMessage);
            }
          }
          return this;
        }

        private long numFiniteBuckets_ ;
        /**
         * int64 num_finite_buckets = 1;
         */
        public long getNumFiniteBuckets() {
          return numFiniteBuckets_;
        }
        /**
         * int64 num_finite_buckets = 1;
         */
        public Builder setNumFiniteBuckets(long value) {
          
          numFiniteBuckets_ = value;
          onChanged();
          return this;
        }
        /**
         * int64 num_finite_buckets = 1;
         */
        public Builder clearNumFiniteBuckets() {
          
          numFiniteBuckets_ = 0L;
          onChanged();
          return this;
        }

        private float growthFactor_ ;
        /**
         * float growth_factor = 2;
         */
        public float getGrowthFactor() {
          return growthFactor_;
        }
        /**
         * float growth_factor = 2;
         */
        public Builder setGrowthFactor(float value) {
          
          growthFactor_ = value;
          onChanged();
          return this;
        }
        /**
         * float growth_factor = 2;
         */
        public Builder clearGrowthFactor() {
          
          growthFactor_ = 0F;
          onChanged();
          return this;
        }

        private float scale_ ;
        /**
         * float scale = 3;
         */
        public float getScale() {
          return scale_;
        }
        /**
         * float scale = 3;
         */
        public Builder setScale(float value) {
          
          scale_ = value;
          onChanged();
          return this;
        }
        /**
         * float scale = 3;
         */
        public Builder clearScale() {
          
          scale_ = 0F;
          onChanged();
          return this;
        }
        @java.lang.Override
        public final Builder setUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.setUnknownFieldsProto3(unknownFields);
        }

        @java.lang.Override
        public final Builder mergeUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.mergeUnknownFields(unknownFields);
        }


        // @@protoc_insertion_point(builder_scope:POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets)
      }

      // @@protoc_insertion_point(class_scope:POGOProtos.Data.Telemetry.Distribution.ExponentialBuckets)
      private static final POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets DEFAULT_INSTANCE;
      static {
        DEFAULT_INSTANCE = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets();
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets getDefaultInstance() {
        return DEFAULT_INSTANCE;
      }

      private static final com.google.protobuf.Parser
          PARSER = new com.google.protobuf.AbstractParser() {
        @java.lang.Override
        public ExponentialBuckets parsePartialFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return new ExponentialBuckets(input, extensionRegistry);
        }
      };

      public static com.google.protobuf.Parser parser() {
        return PARSER;
      }

      @java.lang.Override
      public com.google.protobuf.Parser getParserForType() {
        return PARSER;
      }

      @java.lang.Override
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.ExponentialBuckets getDefaultInstanceForType() {
        return DEFAULT_INSTANCE;
      }

    }

    public interface LinearBucketsOrBuilder extends
        // @@protoc_insertion_point(interface_extends:POGOProtos.Data.Telemetry.Distribution.LinearBuckets)
        com.google.protobuf.MessageOrBuilder {

      /**
       * int64 num_finite_buckets = 1;
       */
      long getNumFiniteBuckets();

      /**
       * int64 width = 2;
       */
      long getWidth();

      /**
       * int64 offset = 3;
       */
      long getOffset();
    }
    /**
     * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.LinearBuckets}
     */
    public  static final class LinearBuckets extends
        com.google.protobuf.GeneratedMessageV3 implements
        // @@protoc_insertion_point(message_implements:POGOProtos.Data.Telemetry.Distribution.LinearBuckets)
        LinearBucketsOrBuilder {
    private static final long serialVersionUID = 0L;
      // Use LinearBuckets.newBuilder() to construct.
      private LinearBuckets(com.google.protobuf.GeneratedMessageV3.Builder builder) {
        super(builder);
      }
      private LinearBuckets() {
        numFiniteBuckets_ = 0L;
        width_ = 0L;
        offset_ = 0L;
      }

      @java.lang.Override
      public final com.google.protobuf.UnknownFieldSet
      getUnknownFields() {
        return this.unknownFields;
      }
      private LinearBuckets(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        this();
        if (extensionRegistry == null) {
          throw new java.lang.NullPointerException();
        }
        int mutable_bitField0_ = 0;
        com.google.protobuf.UnknownFieldSet.Builder unknownFields =
            com.google.protobuf.UnknownFieldSet.newBuilder();
        try {
          boolean done = false;
          while (!done) {
            int tag = input.readTag();
            switch (tag) {
              case 0:
                done = true;
                break;
              case 8: {

                numFiniteBuckets_ = input.readInt64();
                break;
              }
              case 16: {

                width_ = input.readInt64();
                break;
              }
              case 24: {

                offset_ = input.readInt64();
                break;
              }
              default: {
                if (!parseUnknownFieldProto3(
                    input, unknownFields, extensionRegistry, tag)) {
                  done = true;
                }
                break;
              }
            }
          }
        } catch (com.google.protobuf.InvalidProtocolBufferException e) {
          throw e.setUnfinishedMessage(this);
        } catch (java.io.IOException e) {
          throw new com.google.protobuf.InvalidProtocolBufferException(
              e).setUnfinishedMessage(this);
        } finally {
          this.unknownFields = unknownFields.build();
          makeExtensionsImmutable();
        }
      }
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.Builder.class);
      }

      public static final int NUM_FINITE_BUCKETS_FIELD_NUMBER = 1;
      private long numFiniteBuckets_;
      /**
       * int64 num_finite_buckets = 1;
       */
      public long getNumFiniteBuckets() {
        return numFiniteBuckets_;
      }

      public static final int WIDTH_FIELD_NUMBER = 2;
      private long width_;
      /**
       * int64 width = 2;
       */
      public long getWidth() {
        return width_;
      }

      public static final int OFFSET_FIELD_NUMBER = 3;
      private long offset_;
      /**
       * int64 offset = 3;
       */
      public long getOffset() {
        return offset_;
      }

      private byte memoizedIsInitialized = -1;
      @java.lang.Override
      public final boolean isInitialized() {
        byte isInitialized = memoizedIsInitialized;
        if (isInitialized == 1) return true;
        if (isInitialized == 0) return false;

        memoizedIsInitialized = 1;
        return true;
      }

      @java.lang.Override
      public void writeTo(com.google.protobuf.CodedOutputStream output)
                          throws java.io.IOException {
        if (numFiniteBuckets_ != 0L) {
          output.writeInt64(1, numFiniteBuckets_);
        }
        if (width_ != 0L) {
          output.writeInt64(2, width_);
        }
        if (offset_ != 0L) {
          output.writeInt64(3, offset_);
        }
        unknownFields.writeTo(output);
      }

      @java.lang.Override
      public int getSerializedSize() {
        int size = memoizedSize;
        if (size != -1) return size;

        size = 0;
        if (numFiniteBuckets_ != 0L) {
          size += com.google.protobuf.CodedOutputStream
            .computeInt64Size(1, numFiniteBuckets_);
        }
        if (width_ != 0L) {
          size += com.google.protobuf.CodedOutputStream
            .computeInt64Size(2, width_);
        }
        if (offset_ != 0L) {
          size += com.google.protobuf.CodedOutputStream
            .computeInt64Size(3, offset_);
        }
        size += unknownFields.getSerializedSize();
        memoizedSize = size;
        return size;
      }

      @java.lang.Override
      public boolean equals(final java.lang.Object obj) {
        if (obj == this) {
         return true;
        }
        if (!(obj instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets)) {
          return super.equals(obj);
        }
        POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets other = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) obj;

        boolean result = true;
        result = result && (getNumFiniteBuckets()
            == other.getNumFiniteBuckets());
        result = result && (getWidth()
            == other.getWidth());
        result = result && (getOffset()
            == other.getOffset());
        result = result && unknownFields.equals(other.unknownFields);
        return result;
      }

      @java.lang.Override
      public int hashCode() {
        if (memoizedHashCode != 0) {
          return memoizedHashCode;
        }
        int hash = 41;
        hash = (19 * hash) + getDescriptor().hashCode();
        hash = (37 * hash) + NUM_FINITE_BUCKETS_FIELD_NUMBER;
        hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
            getNumFiniteBuckets());
        hash = (37 * hash) + WIDTH_FIELD_NUMBER;
        hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
            getWidth());
        hash = (37 * hash) + OFFSET_FIELD_NUMBER;
        hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
            getOffset());
        hash = (29 * hash) + unknownFields.hashCode();
        memoizedHashCode = hash;
        return hash;
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(
          java.nio.ByteBuffer data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(
          java.nio.ByteBuffer data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(
          com.google.protobuf.ByteString data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(
          com.google.protobuf.ByteString data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(byte[] data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(
          byte[] data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseDelimitedFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseDelimitedFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(
          com.google.protobuf.CodedInputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parseFrom(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }

      @java.lang.Override
      public Builder newBuilderForType() { return newBuilder(); }
      public static Builder newBuilder() {
        return DEFAULT_INSTANCE.toBuilder();
      }
      public static Builder newBuilder(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets prototype) {
        return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
      }
      @java.lang.Override
      public Builder toBuilder() {
        return this == DEFAULT_INSTANCE
            ? new Builder() : new Builder().mergeFrom(this);
      }

      @java.lang.Override
      protected Builder newBuilderForType(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        Builder builder = new Builder(parent);
        return builder;
      }
      /**
       * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.LinearBuckets}
       */
      public static final class Builder extends
          com.google.protobuf.GeneratedMessageV3.Builder implements
          // @@protoc_insertion_point(builder_implements:POGOProtos.Data.Telemetry.Distribution.LinearBuckets)
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBucketsOrBuilder {
        public static final com.google.protobuf.Descriptors.Descriptor
            getDescriptor() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_descriptor;
        }

        @java.lang.Override
        protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
            internalGetFieldAccessorTable() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_fieldAccessorTable
              .ensureFieldAccessorsInitialized(
                  POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.Builder.class);
        }

        // Construct using POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.newBuilder()
        private Builder() {
          maybeForceBuilderInitialization();
        }

        private Builder(
            com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
          super(parent);
          maybeForceBuilderInitialization();
        }
        private void maybeForceBuilderInitialization() {
          if (com.google.protobuf.GeneratedMessageV3
                  .alwaysUseFieldBuilders) {
          }
        }
        @java.lang.Override
        public Builder clear() {
          super.clear();
          numFiniteBuckets_ = 0L;

          width_ = 0L;

          offset_ = 0L;

          return this;
        }

        @java.lang.Override
        public com.google.protobuf.Descriptors.Descriptor
            getDescriptorForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_descriptor;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets getDefaultInstanceForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.getDefaultInstance();
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets build() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets result = buildPartial();
          if (!result.isInitialized()) {
            throw newUninitializedMessageException(result);
          }
          return result;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets buildPartial() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets result = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets(this);
          result.numFiniteBuckets_ = numFiniteBuckets_;
          result.width_ = width_;
          result.offset_ = offset_;
          onBuilt();
          return result;
        }

        @java.lang.Override
        public Builder clone() {
          return (Builder) super.clone();
        }
        @java.lang.Override
        public Builder setField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.setField(field, value);
        }
        @java.lang.Override
        public Builder clearField(
            com.google.protobuf.Descriptors.FieldDescriptor field) {
          return (Builder) super.clearField(field);
        }
        @java.lang.Override
        public Builder clearOneof(
            com.google.protobuf.Descriptors.OneofDescriptor oneof) {
          return (Builder) super.clearOneof(oneof);
        }
        @java.lang.Override
        public Builder setRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            int index, java.lang.Object value) {
          return (Builder) super.setRepeatedField(field, index, value);
        }
        @java.lang.Override
        public Builder addRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.addRepeatedField(field, value);
        }
        @java.lang.Override
        public Builder mergeFrom(com.google.protobuf.Message other) {
          if (other instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) {
            return mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets)other);
          } else {
            super.mergeFrom(other);
            return this;
          }
        }

        public Builder mergeFrom(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets other) {
          if (other == POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets.getDefaultInstance()) return this;
          if (other.getNumFiniteBuckets() != 0L) {
            setNumFiniteBuckets(other.getNumFiniteBuckets());
          }
          if (other.getWidth() != 0L) {
            setWidth(other.getWidth());
          }
          if (other.getOffset() != 0L) {
            setOffset(other.getOffset());
          }
          this.mergeUnknownFields(other.unknownFields);
          onChanged();
          return this;
        }

        @java.lang.Override
        public final boolean isInitialized() {
          return true;
        }

        @java.lang.Override
        public Builder mergeFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets parsedMessage = null;
          try {
            parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
          } catch (com.google.protobuf.InvalidProtocolBufferException e) {
            parsedMessage = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets) e.getUnfinishedMessage();
            throw e.unwrapIOException();
          } finally {
            if (parsedMessage != null) {
              mergeFrom(parsedMessage);
            }
          }
          return this;
        }

        private long numFiniteBuckets_ ;
        /**
         * int64 num_finite_buckets = 1;
         */
        public long getNumFiniteBuckets() {
          return numFiniteBuckets_;
        }
        /**
         * int64 num_finite_buckets = 1;
         */
        public Builder setNumFiniteBuckets(long value) {
          
          numFiniteBuckets_ = value;
          onChanged();
          return this;
        }
        /**
         * int64 num_finite_buckets = 1;
         */
        public Builder clearNumFiniteBuckets() {
          
          numFiniteBuckets_ = 0L;
          onChanged();
          return this;
        }

        private long width_ ;
        /**
         * int64 width = 2;
         */
        public long getWidth() {
          return width_;
        }
        /**
         * int64 width = 2;
         */
        public Builder setWidth(long value) {
          
          width_ = value;
          onChanged();
          return this;
        }
        /**
         * int64 width = 2;
         */
        public Builder clearWidth() {
          
          width_ = 0L;
          onChanged();
          return this;
        }

        private long offset_ ;
        /**
         * int64 offset = 3;
         */
        public long getOffset() {
          return offset_;
        }
        /**
         * int64 offset = 3;
         */
        public Builder setOffset(long value) {
          
          offset_ = value;
          onChanged();
          return this;
        }
        /**
         * int64 offset = 3;
         */
        public Builder clearOffset() {
          
          offset_ = 0L;
          onChanged();
          return this;
        }
        @java.lang.Override
        public final Builder setUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.setUnknownFieldsProto3(unknownFields);
        }

        @java.lang.Override
        public final Builder mergeUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.mergeUnknownFields(unknownFields);
        }


        // @@protoc_insertion_point(builder_scope:POGOProtos.Data.Telemetry.Distribution.LinearBuckets)
      }

      // @@protoc_insertion_point(class_scope:POGOProtos.Data.Telemetry.Distribution.LinearBuckets)
      private static final POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets DEFAULT_INSTANCE;
      static {
        DEFAULT_INSTANCE = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets();
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets getDefaultInstance() {
        return DEFAULT_INSTANCE;
      }

      private static final com.google.protobuf.Parser
          PARSER = new com.google.protobuf.AbstractParser() {
        @java.lang.Override
        public LinearBuckets parsePartialFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return new LinearBuckets(input, extensionRegistry);
        }
      };

      public static com.google.protobuf.Parser parser() {
        return PARSER;
      }

      @java.lang.Override
      public com.google.protobuf.Parser getParserForType() {
        return PARSER;
      }

      @java.lang.Override
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.LinearBuckets getDefaultInstanceForType() {
        return DEFAULT_INSTANCE;
      }

    }

    public interface RangeOrBuilder extends
        // @@protoc_insertion_point(interface_extends:POGOProtos.Data.Telemetry.Distribution.Range)
        com.google.protobuf.MessageOrBuilder {

      /**
       * int64 min = 1;
       */
      long getMin();

      /**
       * int64 max = 2;
       */
      long getMax();
    }
    /**
     * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.Range}
     */
    public  static final class Range extends
        com.google.protobuf.GeneratedMessageV3 implements
        // @@protoc_insertion_point(message_implements:POGOProtos.Data.Telemetry.Distribution.Range)
        RangeOrBuilder {
    private static final long serialVersionUID = 0L;
      // Use Range.newBuilder() to construct.
      private Range(com.google.protobuf.GeneratedMessageV3.Builder builder) {
        super(builder);
      }
      private Range() {
        min_ = 0L;
        max_ = 0L;
      }

      @java.lang.Override
      public final com.google.protobuf.UnknownFieldSet
      getUnknownFields() {
        return this.unknownFields;
      }
      private Range(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        this();
        if (extensionRegistry == null) {
          throw new java.lang.NullPointerException();
        }
        int mutable_bitField0_ = 0;
        com.google.protobuf.UnknownFieldSet.Builder unknownFields =
            com.google.protobuf.UnknownFieldSet.newBuilder();
        try {
          boolean done = false;
          while (!done) {
            int tag = input.readTag();
            switch (tag) {
              case 0:
                done = true;
                break;
              case 8: {

                min_ = input.readInt64();
                break;
              }
              case 16: {

                max_ = input.readInt64();
                break;
              }
              default: {
                if (!parseUnknownFieldProto3(
                    input, unknownFields, extensionRegistry, tag)) {
                  done = true;
                }
                break;
              }
            }
          }
        } catch (com.google.protobuf.InvalidProtocolBufferException e) {
          throw e.setUnfinishedMessage(this);
        } catch (java.io.IOException e) {
          throw new com.google.protobuf.InvalidProtocolBufferException(
              e).setUnfinishedMessage(this);
        } finally {
          this.unknownFields = unknownFields.build();
          makeExtensionsImmutable();
        }
      }
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_Range_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_Range_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.Builder.class);
      }

      public static final int MIN_FIELD_NUMBER = 1;
      private long min_;
      /**
       * int64 min = 1;
       */
      public long getMin() {
        return min_;
      }

      public static final int MAX_FIELD_NUMBER = 2;
      private long max_;
      /**
       * int64 max = 2;
       */
      public long getMax() {
        return max_;
      }

      private byte memoizedIsInitialized = -1;
      @java.lang.Override
      public final boolean isInitialized() {
        byte isInitialized = memoizedIsInitialized;
        if (isInitialized == 1) return true;
        if (isInitialized == 0) return false;

        memoizedIsInitialized = 1;
        return true;
      }

      @java.lang.Override
      public void writeTo(com.google.protobuf.CodedOutputStream output)
                          throws java.io.IOException {
        if (min_ != 0L) {
          output.writeInt64(1, min_);
        }
        if (max_ != 0L) {
          output.writeInt64(2, max_);
        }
        unknownFields.writeTo(output);
      }

      @java.lang.Override
      public int getSerializedSize() {
        int size = memoizedSize;
        if (size != -1) return size;

        size = 0;
        if (min_ != 0L) {
          size += com.google.protobuf.CodedOutputStream
            .computeInt64Size(1, min_);
        }
        if (max_ != 0L) {
          size += com.google.protobuf.CodedOutputStream
            .computeInt64Size(2, max_);
        }
        size += unknownFields.getSerializedSize();
        memoizedSize = size;
        return size;
      }

      @java.lang.Override
      public boolean equals(final java.lang.Object obj) {
        if (obj == this) {
         return true;
        }
        if (!(obj instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range)) {
          return super.equals(obj);
        }
        POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range other = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range) obj;

        boolean result = true;
        result = result && (getMin()
            == other.getMin());
        result = result && (getMax()
            == other.getMax());
        result = result && unknownFields.equals(other.unknownFields);
        return result;
      }

      @java.lang.Override
      public int hashCode() {
        if (memoizedHashCode != 0) {
          return memoizedHashCode;
        }
        int hash = 41;
        hash = (19 * hash) + getDescriptor().hashCode();
        hash = (37 * hash) + MIN_FIELD_NUMBER;
        hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
            getMin());
        hash = (37 * hash) + MAX_FIELD_NUMBER;
        hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
            getMax());
        hash = (29 * hash) + unknownFields.hashCode();
        memoizedHashCode = hash;
        return hash;
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(
          java.nio.ByteBuffer data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(
          java.nio.ByteBuffer data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(
          com.google.protobuf.ByteString data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(
          com.google.protobuf.ByteString data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(byte[] data)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(
          byte[] data,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return PARSER.parseFrom(data, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseDelimitedFrom(java.io.InputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseDelimitedFrom(
          java.io.InputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseDelimitedWithIOException(PARSER, input, extensionRegistry);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(
          com.google.protobuf.CodedInputStream input)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input);
      }
      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parseFrom(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        return com.google.protobuf.GeneratedMessageV3
            .parseWithIOException(PARSER, input, extensionRegistry);
      }

      @java.lang.Override
      public Builder newBuilderForType() { return newBuilder(); }
      public static Builder newBuilder() {
        return DEFAULT_INSTANCE.toBuilder();
      }
      public static Builder newBuilder(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range prototype) {
        return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
      }
      @java.lang.Override
      public Builder toBuilder() {
        return this == DEFAULT_INSTANCE
            ? new Builder() : new Builder().mergeFrom(this);
      }

      @java.lang.Override
      protected Builder newBuilderForType(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        Builder builder = new Builder(parent);
        return builder;
      }
      /**
       * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution.Range}
       */
      public static final class Builder extends
          com.google.protobuf.GeneratedMessageV3.Builder implements
          // @@protoc_insertion_point(builder_implements:POGOProtos.Data.Telemetry.Distribution.Range)
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.RangeOrBuilder {
        public static final com.google.protobuf.Descriptors.Descriptor
            getDescriptor() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_Range_descriptor;
        }

        @java.lang.Override
        protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
            internalGetFieldAccessorTable() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_Range_fieldAccessorTable
              .ensureFieldAccessorsInitialized(
                  POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.Builder.class);
        }

        // Construct using POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.newBuilder()
        private Builder() {
          maybeForceBuilderInitialization();
        }

        private Builder(
            com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
          super(parent);
          maybeForceBuilderInitialization();
        }
        private void maybeForceBuilderInitialization() {
          if (com.google.protobuf.GeneratedMessageV3
                  .alwaysUseFieldBuilders) {
          }
        }
        @java.lang.Override
        public Builder clear() {
          super.clear();
          min_ = 0L;

          max_ = 0L;

          return this;
        }

        @java.lang.Override
        public com.google.protobuf.Descriptors.Descriptor
            getDescriptorForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_Range_descriptor;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range getDefaultInstanceForType() {
          return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.getDefaultInstance();
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range build() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range result = buildPartial();
          if (!result.isInitialized()) {
            throw newUninitializedMessageException(result);
          }
          return result;
        }

        @java.lang.Override
        public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range buildPartial() {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range result = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range(this);
          result.min_ = min_;
          result.max_ = max_;
          onBuilt();
          return result;
        }

        @java.lang.Override
        public Builder clone() {
          return (Builder) super.clone();
        }
        @java.lang.Override
        public Builder setField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.setField(field, value);
        }
        @java.lang.Override
        public Builder clearField(
            com.google.protobuf.Descriptors.FieldDescriptor field) {
          return (Builder) super.clearField(field);
        }
        @java.lang.Override
        public Builder clearOneof(
            com.google.protobuf.Descriptors.OneofDescriptor oneof) {
          return (Builder) super.clearOneof(oneof);
        }
        @java.lang.Override
        public Builder setRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            int index, java.lang.Object value) {
          return (Builder) super.setRepeatedField(field, index, value);
        }
        @java.lang.Override
        public Builder addRepeatedField(
            com.google.protobuf.Descriptors.FieldDescriptor field,
            java.lang.Object value) {
          return (Builder) super.addRepeatedField(field, value);
        }
        @java.lang.Override
        public Builder mergeFrom(com.google.protobuf.Message other) {
          if (other instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range) {
            return mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range)other);
          } else {
            super.mergeFrom(other);
            return this;
          }
        }

        public Builder mergeFrom(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range other) {
          if (other == POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.getDefaultInstance()) return this;
          if (other.getMin() != 0L) {
            setMin(other.getMin());
          }
          if (other.getMax() != 0L) {
            setMax(other.getMax());
          }
          this.mergeUnknownFields(other.unknownFields);
          onChanged();
          return this;
        }

        @java.lang.Override
        public final boolean isInitialized() {
          return true;
        }

        @java.lang.Override
        public Builder mergeFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws java.io.IOException {
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range parsedMessage = null;
          try {
            parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
          } catch (com.google.protobuf.InvalidProtocolBufferException e) {
            parsedMessage = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range) e.getUnfinishedMessage();
            throw e.unwrapIOException();
          } finally {
            if (parsedMessage != null) {
              mergeFrom(parsedMessage);
            }
          }
          return this;
        }

        private long min_ ;
        /**
         * int64 min = 1;
         */
        public long getMin() {
          return min_;
        }
        /**
         * int64 min = 1;
         */
        public Builder setMin(long value) {
          
          min_ = value;
          onChanged();
          return this;
        }
        /**
         * int64 min = 1;
         */
        public Builder clearMin() {
          
          min_ = 0L;
          onChanged();
          return this;
        }

        private long max_ ;
        /**
         * int64 max = 2;
         */
        public long getMax() {
          return max_;
        }
        /**
         * int64 max = 2;
         */
        public Builder setMax(long value) {
          
          max_ = value;
          onChanged();
          return this;
        }
        /**
         * int64 max = 2;
         */
        public Builder clearMax() {
          
          max_ = 0L;
          onChanged();
          return this;
        }
        @java.lang.Override
        public final Builder setUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.setUnknownFieldsProto3(unknownFields);
        }

        @java.lang.Override
        public final Builder mergeUnknownFields(
            final com.google.protobuf.UnknownFieldSet unknownFields) {
          return super.mergeUnknownFields(unknownFields);
        }


        // @@protoc_insertion_point(builder_scope:POGOProtos.Data.Telemetry.Distribution.Range)
      }

      // @@protoc_insertion_point(class_scope:POGOProtos.Data.Telemetry.Distribution.Range)
      private static final POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range DEFAULT_INSTANCE;
      static {
        DEFAULT_INSTANCE = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range();
      }

      public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range getDefaultInstance() {
        return DEFAULT_INSTANCE;
      }

      private static final com.google.protobuf.Parser
          PARSER = new com.google.protobuf.AbstractParser() {
        @java.lang.Override
        public Range parsePartialFrom(
            com.google.protobuf.CodedInputStream input,
            com.google.protobuf.ExtensionRegistryLite extensionRegistry)
            throws com.google.protobuf.InvalidProtocolBufferException {
          return new Range(input, extensionRegistry);
        }
      };

      public static com.google.protobuf.Parser parser() {
        return PARSER;
      }

      @java.lang.Override
      public com.google.protobuf.Parser getParserForType() {
        return PARSER;
      }

      @java.lang.Override
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range getDefaultInstanceForType() {
        return DEFAULT_INSTANCE;
      }

    }

    private int bitField0_;
    public static final int COUNT_FIELD_NUMBER = 1;
    private long count_;
    /**
     * int64 count = 1;
     */
    public long getCount() {
      return count_;
    }

    public static final int MEAN_FIELD_NUMBER = 2;
    private float mean_;
    /**
     * float mean = 2;
     */
    public float getMean() {
      return mean_;
    }

    public static final int SUM_OF_SQUARED_DEVIATION_FIELD_NUMBER = 3;
    private double sumOfSquaredDeviation_;
    /**
     * double sum_of_squared_deviation = 3;
     */
    public double getSumOfSquaredDeviation() {
      return sumOfSquaredDeviation_;
    }

    public static final int RANGE_FIELD_NUMBER = 4;
    private POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range range_;
    /**
     * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
     */
    public boolean hasRange() {
      return range_ != null;
    }
    /**
     * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
     */
    public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range getRange() {
      return range_ == null ? POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.getDefaultInstance() : range_;
    }
    /**
     * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
     */
    public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.RangeOrBuilder getRangeOrBuilder() {
      return getRange();
    }

    public static final int BUCKET_OPTIONS_FIELD_NUMBER = 5;
    private POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions bucketOptions_;
    /**
     * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
     */
    public boolean hasBucketOptions() {
      return bucketOptions_ != null;
    }
    /**
     * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
     */
    public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions getBucketOptions() {
      return bucketOptions_ == null ? POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.getDefaultInstance() : bucketOptions_;
    }
    /**
     * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
     */
    public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptionsOrBuilder getBucketOptionsOrBuilder() {
      return getBucketOptions();
    }

    public static final int BUCKET_COUNTS_FIELD_NUMBER = 6;
    private java.util.List bucketCounts_;
    /**
     * repeated int64 bucket_counts = 6;
     */
    public java.util.List
        getBucketCountsList() {
      return bucketCounts_;
    }
    /**
     * repeated int64 bucket_counts = 6;
     */
    public int getBucketCountsCount() {
      return bucketCounts_.size();
    }
    /**
     * repeated int64 bucket_counts = 6;
     */
    public long getBucketCounts(int index) {
      return bucketCounts_.get(index);
    }
    private int bucketCountsMemoizedSerializedSize = -1;

    private byte memoizedIsInitialized = -1;
    @java.lang.Override
    public final boolean isInitialized() {
      byte isInitialized = memoizedIsInitialized;
      if (isInitialized == 1) return true;
      if (isInitialized == 0) return false;

      memoizedIsInitialized = 1;
      return true;
    }

    @java.lang.Override
    public void writeTo(com.google.protobuf.CodedOutputStream output)
                        throws java.io.IOException {
      getSerializedSize();
      if (count_ != 0L) {
        output.writeInt64(1, count_);
      }
      if (mean_ != 0F) {
        output.writeFloat(2, mean_);
      }
      if (sumOfSquaredDeviation_ != 0D) {
        output.writeDouble(3, sumOfSquaredDeviation_);
      }
      if (range_ != null) {
        output.writeMessage(4, getRange());
      }
      if (bucketOptions_ != null) {
        output.writeMessage(5, getBucketOptions());
      }
      if (getBucketCountsList().size() > 0) {
        output.writeUInt32NoTag(50);
        output.writeUInt32NoTag(bucketCountsMemoizedSerializedSize);
      }
      for (int i = 0; i < bucketCounts_.size(); i++) {
        output.writeInt64NoTag(bucketCounts_.get(i));
      }
      unknownFields.writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (count_ != 0L) {
        size += com.google.protobuf.CodedOutputStream
          .computeInt64Size(1, count_);
      }
      if (mean_ != 0F) {
        size += com.google.protobuf.CodedOutputStream
          .computeFloatSize(2, mean_);
      }
      if (sumOfSquaredDeviation_ != 0D) {
        size += com.google.protobuf.CodedOutputStream
          .computeDoubleSize(3, sumOfSquaredDeviation_);
      }
      if (range_ != null) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(4, getRange());
      }
      if (bucketOptions_ != null) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(5, getBucketOptions());
      }
      {
        int dataSize = 0;
        for (int i = 0; i < bucketCounts_.size(); i++) {
          dataSize += com.google.protobuf.CodedOutputStream
            .computeInt64SizeNoTag(bucketCounts_.get(i));
        }
        size += dataSize;
        if (!getBucketCountsList().isEmpty()) {
          size += 1;
          size += com.google.protobuf.CodedOutputStream
              .computeInt32SizeNoTag(dataSize);
        }
        bucketCountsMemoizedSerializedSize = dataSize;
      }
      size += unknownFields.getSerializedSize();
      memoizedSize = size;
      return size;
    }

    @java.lang.Override
    public boolean equals(final java.lang.Object obj) {
      if (obj == this) {
       return true;
      }
      if (!(obj instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution)) {
        return super.equals(obj);
      }
      POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution other = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution) obj;

      boolean result = true;
      result = result && (getCount()
          == other.getCount());
      result = result && (
          java.lang.Float.floatToIntBits(getMean())
          == java.lang.Float.floatToIntBits(
              other.getMean()));
      result = result && (
          java.lang.Double.doubleToLongBits(getSumOfSquaredDeviation())
          == java.lang.Double.doubleToLongBits(
              other.getSumOfSquaredDeviation()));
      result = result && (hasRange() == other.hasRange());
      if (hasRange()) {
        result = result && getRange()
            .equals(other.getRange());
      }
      result = result && (hasBucketOptions() == other.hasBucketOptions());
      if (hasBucketOptions()) {
        result = result && getBucketOptions()
            .equals(other.getBucketOptions());
      }
      result = result && getBucketCountsList()
          .equals(other.getBucketCountsList());
      result = result && unknownFields.equals(other.unknownFields);
      return result;
    }

    @java.lang.Override
    public int hashCode() {
      if (memoizedHashCode != 0) {
        return memoizedHashCode;
      }
      int hash = 41;
      hash = (19 * hash) + getDescriptor().hashCode();
      hash = (37 * hash) + COUNT_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
          getCount());
      hash = (37 * hash) + MEAN_FIELD_NUMBER;
      hash = (53 * hash) + java.lang.Float.floatToIntBits(
          getMean());
      hash = (37 * hash) + SUM_OF_SQUARED_DEVIATION_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
          java.lang.Double.doubleToLongBits(getSumOfSquaredDeviation()));
      if (hasRange()) {
        hash = (37 * hash) + RANGE_FIELD_NUMBER;
        hash = (53 * hash) + getRange().hashCode();
      }
      if (hasBucketOptions()) {
        hash = (37 * hash) + BUCKET_OPTIONS_FIELD_NUMBER;
        hash = (53 * hash) + getBucketOptions().hashCode();
      }
      if (getBucketCountsCount() > 0) {
        hash = (37 * hash) + BUCKET_COUNTS_FIELD_NUMBER;
        hash = (53 * hash) + getBucketCountsList().hashCode();
      }
      hash = (29 * hash) + unknownFields.hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(
        java.io.InputStream input,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input, extensionRegistry);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseDelimitedFrom(
        java.io.InputStream input,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input, extensionRegistry);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parseFrom(
        com.google.protobuf.CodedInputStream input,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input, extensionRegistry);
    }

    @java.lang.Override
    public Builder newBuilderForType() { return newBuilder(); }
    public static Builder newBuilder() {
      return DEFAULT_INSTANCE.toBuilder();
    }
    public static Builder newBuilder(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution prototype) {
      return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype);
    }
    @java.lang.Override
    public Builder toBuilder() {
      return this == DEFAULT_INSTANCE
          ? new Builder() : new Builder().mergeFrom(this);
    }

    @java.lang.Override
    protected Builder newBuilderForType(
        com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
      Builder builder = new Builder(parent);
      return builder;
    }
    /**
     * Protobuf type {@code POGOProtos.Data.Telemetry.Distribution}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder implements
        // @@protoc_insertion_point(builder_implements:POGOProtos.Data.Telemetry.Distribution)
        POGOProtos.Data.Telemetry.DistributionOuterClass.DistributionOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.class, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Builder.class);
      }

      // Construct using POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.newBuilder()
      private Builder() {
        maybeForceBuilderInitialization();
      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);
        maybeForceBuilderInitialization();
      }
      private void maybeForceBuilderInitialization() {
        if (com.google.protobuf.GeneratedMessageV3
                .alwaysUseFieldBuilders) {
        }
      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        count_ = 0L;

        mean_ = 0F;

        sumOfSquaredDeviation_ = 0D;

        if (rangeBuilder_ == null) {
          range_ = null;
        } else {
          range_ = null;
          rangeBuilder_ = null;
        }
        if (bucketOptionsBuilder_ == null) {
          bucketOptions_ = null;
        } else {
          bucketOptions_ = null;
          bucketOptionsBuilder_ = null;
        }
        bucketCounts_ = java.util.Collections.emptyList();
        bitField0_ = (bitField0_ & ~0x00000020);
        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor;
      }

      @java.lang.Override
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution getDefaultInstanceForType() {
        return POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.getDefaultInstance();
      }

      @java.lang.Override
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution build() {
        POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution buildPartial() {
        POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution result = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution(this);
        int from_bitField0_ = bitField0_;
        int to_bitField0_ = 0;
        result.count_ = count_;
        result.mean_ = mean_;
        result.sumOfSquaredDeviation_ = sumOfSquaredDeviation_;
        if (rangeBuilder_ == null) {
          result.range_ = range_;
        } else {
          result.range_ = rangeBuilder_.build();
        }
        if (bucketOptionsBuilder_ == null) {
          result.bucketOptions_ = bucketOptions_;
        } else {
          result.bucketOptions_ = bucketOptionsBuilder_.build();
        }
        if (((bitField0_ & 0x00000020) == 0x00000020)) {
          bucketCounts_ = java.util.Collections.unmodifiableList(bucketCounts_);
          bitField0_ = (bitField0_ & ~0x00000020);
        }
        result.bucketCounts_ = bucketCounts_;
        result.bitField0_ = to_bitField0_;
        onBuilt();
        return result;
      }

      @java.lang.Override
      public Builder clone() {
        return (Builder) super.clone();
      }
      @java.lang.Override
      public Builder setField(
          com.google.protobuf.Descriptors.FieldDescriptor field,
          java.lang.Object value) {
        return (Builder) super.setField(field, value);
      }
      @java.lang.Override
      public Builder clearField(
          com.google.protobuf.Descriptors.FieldDescriptor field) {
        return (Builder) super.clearField(field);
      }
      @java.lang.Override
      public Builder clearOneof(
          com.google.protobuf.Descriptors.OneofDescriptor oneof) {
        return (Builder) super.clearOneof(oneof);
      }
      @java.lang.Override
      public Builder setRepeatedField(
          com.google.protobuf.Descriptors.FieldDescriptor field,
          int index, java.lang.Object value) {
        return (Builder) super.setRepeatedField(field, index, value);
      }
      @java.lang.Override
      public Builder addRepeatedField(
          com.google.protobuf.Descriptors.FieldDescriptor field,
          java.lang.Object value) {
        return (Builder) super.addRepeatedField(field, value);
      }
      @java.lang.Override
      public Builder mergeFrom(com.google.protobuf.Message other) {
        if (other instanceof POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution) {
          return mergeFrom((POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution other) {
        if (other == POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.getDefaultInstance()) return this;
        if (other.getCount() != 0L) {
          setCount(other.getCount());
        }
        if (other.getMean() != 0F) {
          setMean(other.getMean());
        }
        if (other.getSumOfSquaredDeviation() != 0D) {
          setSumOfSquaredDeviation(other.getSumOfSquaredDeviation());
        }
        if (other.hasRange()) {
          mergeRange(other.getRange());
        }
        if (other.hasBucketOptions()) {
          mergeBucketOptions(other.getBucketOptions());
        }
        if (!other.bucketCounts_.isEmpty()) {
          if (bucketCounts_.isEmpty()) {
            bucketCounts_ = other.bucketCounts_;
            bitField0_ = (bitField0_ & ~0x00000020);
          } else {
            ensureBucketCountsIsMutable();
            bucketCounts_.addAll(other.bucketCounts_);
          }
          onChanged();
        }
        this.mergeUnknownFields(other.unknownFields);
        onChanged();
        return this;
      }

      @java.lang.Override
      public final boolean isInitialized() {
        return true;
      }

      @java.lang.Override
      public Builder mergeFrom(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws java.io.IOException {
        POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution parsedMessage = null;
        try {
          parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
        } catch (com.google.protobuf.InvalidProtocolBufferException e) {
          parsedMessage = (POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution) e.getUnfinishedMessage();
          throw e.unwrapIOException();
        } finally {
          if (parsedMessage != null) {
            mergeFrom(parsedMessage);
          }
        }
        return this;
      }
      private int bitField0_;

      private long count_ ;
      /**
       * int64 count = 1;
       */
      public long getCount() {
        return count_;
      }
      /**
       * int64 count = 1;
       */
      public Builder setCount(long value) {
        
        count_ = value;
        onChanged();
        return this;
      }
      /**
       * int64 count = 1;
       */
      public Builder clearCount() {
        
        count_ = 0L;
        onChanged();
        return this;
      }

      private float mean_ ;
      /**
       * float mean = 2;
       */
      public float getMean() {
        return mean_;
      }
      /**
       * float mean = 2;
       */
      public Builder setMean(float value) {
        
        mean_ = value;
        onChanged();
        return this;
      }
      /**
       * float mean = 2;
       */
      public Builder clearMean() {
        
        mean_ = 0F;
        onChanged();
        return this;
      }

      private double sumOfSquaredDeviation_ ;
      /**
       * double sum_of_squared_deviation = 3;
       */
      public double getSumOfSquaredDeviation() {
        return sumOfSquaredDeviation_;
      }
      /**
       * double sum_of_squared_deviation = 3;
       */
      public Builder setSumOfSquaredDeviation(double value) {
        
        sumOfSquaredDeviation_ = value;
        onChanged();
        return this;
      }
      /**
       * double sum_of_squared_deviation = 3;
       */
      public Builder clearSumOfSquaredDeviation() {
        
        sumOfSquaredDeviation_ = 0D;
        onChanged();
        return this;
      }

      private POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range range_ = null;
      private com.google.protobuf.SingleFieldBuilderV3<
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.RangeOrBuilder> rangeBuilder_;
      /**
       * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
       */
      public boolean hasRange() {
        return rangeBuilder_ != null || range_ != null;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range getRange() {
        if (rangeBuilder_ == null) {
          return range_ == null ? POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.getDefaultInstance() : range_;
        } else {
          return rangeBuilder_.getMessage();
        }
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
       */
      public Builder setRange(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range value) {
        if (rangeBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          range_ = value;
          onChanged();
        } else {
          rangeBuilder_.setMessage(value);
        }

        return this;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
       */
      public Builder setRange(
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.Builder builderForValue) {
        if (rangeBuilder_ == null) {
          range_ = builderForValue.build();
          onChanged();
        } else {
          rangeBuilder_.setMessage(builderForValue.build());
        }

        return this;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
       */
      public Builder mergeRange(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range value) {
        if (rangeBuilder_ == null) {
          if (range_ != null) {
            range_ =
              POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.newBuilder(range_).mergeFrom(value).buildPartial();
          } else {
            range_ = value;
          }
          onChanged();
        } else {
          rangeBuilder_.mergeFrom(value);
        }

        return this;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
       */
      public Builder clearRange() {
        if (rangeBuilder_ == null) {
          range_ = null;
          onChanged();
        } else {
          range_ = null;
          rangeBuilder_ = null;
        }

        return this;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.Builder getRangeBuilder() {
        
        onChanged();
        return getRangeFieldBuilder().getBuilder();
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.RangeOrBuilder getRangeOrBuilder() {
        if (rangeBuilder_ != null) {
          return rangeBuilder_.getMessageOrBuilder();
        } else {
          return range_ == null ?
              POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.getDefaultInstance() : range_;
        }
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.Range range = 4;
       */
      private com.google.protobuf.SingleFieldBuilderV3<
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.RangeOrBuilder> 
          getRangeFieldBuilder() {
        if (rangeBuilder_ == null) {
          rangeBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
              POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.Range.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.RangeOrBuilder>(
                  getRange(),
                  getParentForChildren(),
                  isClean());
          range_ = null;
        }
        return rangeBuilder_;
      }

      private POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions bucketOptions_ = null;
      private com.google.protobuf.SingleFieldBuilderV3<
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptionsOrBuilder> bucketOptionsBuilder_;
      /**
       * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
       */
      public boolean hasBucketOptions() {
        return bucketOptionsBuilder_ != null || bucketOptions_ != null;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions getBucketOptions() {
        if (bucketOptionsBuilder_ == null) {
          return bucketOptions_ == null ? POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.getDefaultInstance() : bucketOptions_;
        } else {
          return bucketOptionsBuilder_.getMessage();
        }
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
       */
      public Builder setBucketOptions(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions value) {
        if (bucketOptionsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          bucketOptions_ = value;
          onChanged();
        } else {
          bucketOptionsBuilder_.setMessage(value);
        }

        return this;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
       */
      public Builder setBucketOptions(
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.Builder builderForValue) {
        if (bucketOptionsBuilder_ == null) {
          bucketOptions_ = builderForValue.build();
          onChanged();
        } else {
          bucketOptionsBuilder_.setMessage(builderForValue.build());
        }

        return this;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
       */
      public Builder mergeBucketOptions(POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions value) {
        if (bucketOptionsBuilder_ == null) {
          if (bucketOptions_ != null) {
            bucketOptions_ =
              POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.newBuilder(bucketOptions_).mergeFrom(value).buildPartial();
          } else {
            bucketOptions_ = value;
          }
          onChanged();
        } else {
          bucketOptionsBuilder_.mergeFrom(value);
        }

        return this;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
       */
      public Builder clearBucketOptions() {
        if (bucketOptionsBuilder_ == null) {
          bucketOptions_ = null;
          onChanged();
        } else {
          bucketOptions_ = null;
          bucketOptionsBuilder_ = null;
        }

        return this;
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.Builder getBucketOptionsBuilder() {
        
        onChanged();
        return getBucketOptionsFieldBuilder().getBuilder();
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
       */
      public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptionsOrBuilder getBucketOptionsOrBuilder() {
        if (bucketOptionsBuilder_ != null) {
          return bucketOptionsBuilder_.getMessageOrBuilder();
        } else {
          return bucketOptions_ == null ?
              POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.getDefaultInstance() : bucketOptions_;
        }
      }
      /**
       * .POGOProtos.Data.Telemetry.Distribution.BucketOptions bucket_options = 5;
       */
      private com.google.protobuf.SingleFieldBuilderV3<
          POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptionsOrBuilder> 
          getBucketOptionsFieldBuilder() {
        if (bucketOptionsBuilder_ == null) {
          bucketOptionsBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
              POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptions.Builder, POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution.BucketOptionsOrBuilder>(
                  getBucketOptions(),
                  getParentForChildren(),
                  isClean());
          bucketOptions_ = null;
        }
        return bucketOptionsBuilder_;
      }

      private java.util.List bucketCounts_ = java.util.Collections.emptyList();
      private void ensureBucketCountsIsMutable() {
        if (!((bitField0_ & 0x00000020) == 0x00000020)) {
          bucketCounts_ = new java.util.ArrayList(bucketCounts_);
          bitField0_ |= 0x00000020;
         }
      }
      /**
       * repeated int64 bucket_counts = 6;
       */
      public java.util.List
          getBucketCountsList() {
        return java.util.Collections.unmodifiableList(bucketCounts_);
      }
      /**
       * repeated int64 bucket_counts = 6;
       */
      public int getBucketCountsCount() {
        return bucketCounts_.size();
      }
      /**
       * repeated int64 bucket_counts = 6;
       */
      public long getBucketCounts(int index) {
        return bucketCounts_.get(index);
      }
      /**
       * repeated int64 bucket_counts = 6;
       */
      public Builder setBucketCounts(
          int index, long value) {
        ensureBucketCountsIsMutable();
        bucketCounts_.set(index, value);
        onChanged();
        return this;
      }
      /**
       * repeated int64 bucket_counts = 6;
       */
      public Builder addBucketCounts(long value) {
        ensureBucketCountsIsMutable();
        bucketCounts_.add(value);
        onChanged();
        return this;
      }
      /**
       * repeated int64 bucket_counts = 6;
       */
      public Builder addAllBucketCounts(
          java.lang.Iterable values) {
        ensureBucketCountsIsMutable();
        com.google.protobuf.AbstractMessageLite.Builder.addAll(
            values, bucketCounts_);
        onChanged();
        return this;
      }
      /**
       * repeated int64 bucket_counts = 6;
       */
      public Builder clearBucketCounts() {
        bucketCounts_ = java.util.Collections.emptyList();
        bitField0_ = (bitField0_ & ~0x00000020);
        onChanged();
        return this;
      }
      @java.lang.Override
      public final Builder setUnknownFields(
          final com.google.protobuf.UnknownFieldSet unknownFields) {
        return super.setUnknownFieldsProto3(unknownFields);
      }

      @java.lang.Override
      public final Builder mergeUnknownFields(
          final com.google.protobuf.UnknownFieldSet unknownFields) {
        return super.mergeUnknownFields(unknownFields);
      }


      // @@protoc_insertion_point(builder_scope:POGOProtos.Data.Telemetry.Distribution)
    }

    // @@protoc_insertion_point(class_scope:POGOProtos.Data.Telemetry.Distribution)
    private static final POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution();
    }

    public static POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser
        PARSER = new com.google.protobuf.AbstractParser() {
      @java.lang.Override
      public Distribution parsePartialFrom(
          com.google.protobuf.CodedInputStream input,
          com.google.protobuf.ExtensionRegistryLite extensionRegistry)
          throws com.google.protobuf.InvalidProtocolBufferException {
        return new Distribution(input, extensionRegistry);
      }
    };

    public static com.google.protobuf.Parser parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public POGOProtos.Data.Telemetry.DistributionOuterClass.Distribution getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_POGOProtos_Data_Telemetry_Distribution_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_POGOProtos_Data_Telemetry_Distribution_Range_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_POGOProtos_Data_Telemetry_Distribution_Range_fieldAccessorTable;

  public static com.google.protobuf.Descriptors.FileDescriptor
      getDescriptor() {
    return descriptor;
  }
  private static  com.google.protobuf.Descriptors.FileDescriptor
      descriptor;
  static {
    java.lang.String[] descriptorData = {
      "\n,POGOProtos/Data/Telemetry/Distribution" +
      ".proto\022\031POGOProtos.Data.Telemetry\"\303\007\n\014Di" +
      "stribution\022\r\n\005count\030\001 \001(\003\022\014\n\004mean\030\002 \001(\002\022" +
      " \n\030sum_of_squared_deviation\030\003 \001(\001\022<\n\005ran" +
      "ge\030\004 \001(\0132-.POGOProtos.Data.Telemetry.Dis" +
      "tribution.Range\022M\n\016bucket_options\030\005 \001(\0132" +
      "5.POGOProtos.Data.Telemetry.Distribution" +
      ".BucketOptions\022\025\n\rbucket_counts\030\006 \003(\003\032\345\003" +
      "\n\rBucketOptions\022O\n\016linear_buckets\030\001 \001(\0132" +
      "5.POGOProtos.Data.Telemetry.Distribution" +
      ".LinearBucketsH\000\022Y\n\023exponential_buckets\030" +
      "\002 \001(\0132:.POGOProtos.Data.Telemetry.Distri" +
      "bution.ExponentialBucketsH\000\022S\n\020explicit_" +
      "buckets\030\003 \001(\01327.POGOProtos.Data.Telemetr" +
      "y.Distribution.ExplicitBucketsH\000\032!\n\017Expl" +
      "icitBuckets\022\016\n\006bounds\030\001 \003(\003\032V\n\022Exponenti" +
      "alBuckets\022\032\n\022num_finite_buckets\030\001 \001(\003\022\025\n" +
      "\rgrowth_factor\030\002 \001(\002\022\r\n\005scale\030\003 \001(\002\032J\n\rL" +
      "inearBuckets\022\032\n\022num_finite_buckets\030\001 \001(\003" +
      "\022\r\n\005width\030\002 \001(\003\022\016\n\006offset\030\003 \001(\003B\014\n\nBucke" +
      "tType\032!\n\017ExplicitBuckets\022\016\n\006bounds\030\001 \003(\003" +
      "\032V\n\022ExponentialBuckets\022\032\n\022num_finite_buc" +
      "kets\030\001 \001(\003\022\025\n\rgrowth_factor\030\002 \001(\002\022\r\n\005sca" +
      "le\030\003 \001(\002\032J\n\rLinearBuckets\022\032\n\022num_finite_" +
      "buckets\030\001 \001(\003\022\r\n\005width\030\002 \001(\003\022\016\n\006offset\030\003" +
      " \001(\003\032!\n\005Range\022\013\n\003min\030\001 \001(\003\022\013\n\003max\030\002 \001(\003b" +
      "\006proto3"
    };
    com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner =
        new com.google.protobuf.Descriptors.FileDescriptor.    InternalDescriptorAssigner() {
          public com.google.protobuf.ExtensionRegistry assignDescriptors(
              com.google.protobuf.Descriptors.FileDescriptor root) {
            descriptor = root;
            return null;
          }
        };
    com.google.protobuf.Descriptors.FileDescriptor
      .internalBuildGeneratedFileFrom(descriptorData,
        new com.google.protobuf.Descriptors.FileDescriptor[] {
        }, assigner);
    internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor =
      getDescriptor().getMessageTypes().get(0);
    internal_static_POGOProtos_Data_Telemetry_Distribution_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor,
        new java.lang.String[] { "Count", "Mean", "SumOfSquaredDeviation", "Range", "BucketOptions", "BucketCounts", });
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_descriptor =
      internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor.getNestedTypes().get(0);
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_descriptor,
        new java.lang.String[] { "LinearBuckets", "ExponentialBuckets", "ExplicitBuckets", "BucketType", });
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_descriptor =
      internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_descriptor.getNestedTypes().get(0);
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExplicitBuckets_descriptor,
        new java.lang.String[] { "Bounds", });
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_descriptor =
      internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_descriptor.getNestedTypes().get(1);
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_ExponentialBuckets_descriptor,
        new java.lang.String[] { "NumFiniteBuckets", "GrowthFactor", "Scale", });
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_descriptor =
      internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_descriptor.getNestedTypes().get(2);
    internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_POGOProtos_Data_Telemetry_Distribution_BucketOptions_LinearBuckets_descriptor,
        new java.lang.String[] { "NumFiniteBuckets", "Width", "Offset", });
    internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_descriptor =
      internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor.getNestedTypes().get(1);
    internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_POGOProtos_Data_Telemetry_Distribution_ExplicitBuckets_descriptor,
        new java.lang.String[] { "Bounds", });
    internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_descriptor =
      internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor.getNestedTypes().get(2);
    internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_POGOProtos_Data_Telemetry_Distribution_ExponentialBuckets_descriptor,
        new java.lang.String[] { "NumFiniteBuckets", "GrowthFactor", "Scale", });
    internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_descriptor =
      internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor.getNestedTypes().get(3);
    internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_POGOProtos_Data_Telemetry_Distribution_LinearBuckets_descriptor,
        new java.lang.String[] { "NumFiniteBuckets", "Width", "Offset", });
    internal_static_POGOProtos_Data_Telemetry_Distribution_Range_descriptor =
      internal_static_POGOProtos_Data_Telemetry_Distribution_descriptor.getNestedTypes().get(4);
    internal_static_POGOProtos_Data_Telemetry_Distribution_Range_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_POGOProtos_Data_Telemetry_Distribution_Range_descriptor,
        new java.lang.String[] { "Min", "Max", });
  }

  // @@protoc_insertion_point(outer_class_scope)
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy