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();
}
}