hydra.langs.parquet.format.ColumnIndex Maven / Gradle / Ivy
package hydra.langs.parquet.format;
import java.io.Serializable;
/**
* Description for ColumnIndex. Each <array-field>[i] refers to the page at OffsetIndex.page_locations[i]
*/
public class ColumnIndex implements Serializable {
public static final hydra.core.Name NAME = new hydra.core.Name("hydra/langs/parquet/format.ColumnIndex");
/**
* A list of Boolean values to determine the validity of the corresponding min and max values. If true, a page contains only null values, and writers have to set the corresponding entries in min_values and max_values to byte[0], so that all lists have the same length. If false, the corresponding entries in min_values and max_values must be valid.
*/
public final java.util.List nullPages;
public final java.util.List minValues;
public final java.util.List maxValues;
/**
* Stores whether both min_values and max_values are orderd and if so, in which direction. This allows readers to perform binary searches in both lists. Readers cannot assume that max_values[i] <= min_values[i+1], even if the lists are ordered.
*/
public final hydra.langs.parquet.format.BoundaryOrder boundaryOrder;
/**
* A list containing the number of null values for each page
*/
public final java.util.Optional> nullCounts;
public ColumnIndex (java.util.List nullPages, java.util.List minValues, java.util.List maxValues, hydra.langs.parquet.format.BoundaryOrder boundaryOrder, java.util.Optional> nullCounts) {
this.nullPages = nullPages;
this.minValues = minValues;
this.maxValues = maxValues;
this.boundaryOrder = boundaryOrder;
this.nullCounts = nullCounts;
}
@Override
public boolean equals(Object other) {
if (!(other instanceof ColumnIndex)) {
return false;
}
ColumnIndex o = (ColumnIndex) (other);
return nullPages.equals(o.nullPages) && minValues.equals(o.minValues) && maxValues.equals(o.maxValues) && boundaryOrder.equals(o.boundaryOrder) && nullCounts.equals(o.nullCounts);
}
@Override
public int hashCode() {
return 2 * nullPages.hashCode() + 3 * minValues.hashCode() + 5 * maxValues.hashCode() + 7 * boundaryOrder.hashCode() + 11 * nullCounts.hashCode();
}
public ColumnIndex withNullPages(java.util.List nullPages) {
return new ColumnIndex(nullPages, minValues, maxValues, boundaryOrder, nullCounts);
}
public ColumnIndex withMinValues(java.util.List minValues) {
return new ColumnIndex(nullPages, minValues, maxValues, boundaryOrder, nullCounts);
}
public ColumnIndex withMaxValues(java.util.List maxValues) {
return new ColumnIndex(nullPages, minValues, maxValues, boundaryOrder, nullCounts);
}
public ColumnIndex withBoundaryOrder(hydra.langs.parquet.format.BoundaryOrder boundaryOrder) {
return new ColumnIndex(nullPages, minValues, maxValues, boundaryOrder, nullCounts);
}
public ColumnIndex withNullCounts(java.util.Optional> nullCounts) {
return new ColumnIndex(nullPages, minValues, maxValues, boundaryOrder, nullCounts);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy