package edu.washington.escience.myria.column; import java.util.Arrays; import com.google.common.base.Preconditions; import edu.washington.escience.myria.Schema; import edu.washington.escience.myria.Type; import edu.washington.escience.myria.storage.TupleUtils; /** * A column of Double values. * * */ public final class DoubleColumn extends Column<Double> { /** Required for Java serialization. */ private static final long serialVersionUID = 1L; /** Internal representation of the column data. */ private final double[] data; /** The number of existing rows in this column. */ private final int position; /** * Constructs a new column. * * @param data the data * @param numData number of tuples. * */ public DoubleColumn(final double[] data, final int numData) { Preconditions.checkNotNull(data); Preconditions.checkArgument(numData <= TupleUtils.getBatchSize(Type.DOUBLE_TYPE)); this.data = data; position = numData; } @Override public Double getObject(final int row) { return Double.valueOf(getDouble(row)); } /** * Returns the element at the specified row in this column. * * @param row row of element to return. * @return the element at the specified row in this column. */ @Override public double getDouble(final int row) { Preconditions.checkElementIndex(row, position); return data[row]; } @Override public Type getType() { return Type.DOUBLE_TYPE; } @Override public int size() { return position; } @Override public String toString() { final StringBuilder sb = new StringBuilder(); sb.append(size()).append(" elements: ["); for (int i = 0; i < size(); ++i) { if (i > 0) { sb.append(", "); } sb.append(data[i]); } sb.append(']'); return sb.toString(); } }