/*
* Copyright 2013 Proofpoint Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.kairosdb.client.builder.aggregator;
import static com.google.common.base.Preconditions.checkArgument;
import org.kairosdb.client.builder.TimeUnit;
public class PercentileAggregator extends SamplingAggregator
{
private double percentile;
public PercentileAggregator(double percentile, int value, TimeUnit unit)
{
super("percentile", value, unit);
checkArgument(percentile >= 0, "value must be greater than or equal to 0.");
checkArgument(percentile <= 1, "value must be less than or equal to 1.");
this.percentile = percentile;
}
public double getPercentile()
{
return percentile;
}
@Override
public boolean equals(Object o)
{
if (this == o)
return true;
if (o == null || getClass() != o.getClass())
return false;
if (!super.equals(o))
return false;
PercentileAggregator that = (PercentileAggregator) o;
return Double.compare(that.percentile, percentile) == 0;
}
@Override
public int hashCode()
{
int result = super.hashCode();
long temp;
temp = Double.doubleToLongBits(percentile);
result = 31 * result + (int) (temp ^ (temp >>> 32));
return result;
}
}