io.deephaven.engine.table.impl.updateby.internal.BaseObjectBinaryOperator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of deephaven-engine-table Show documentation
Show all versions of deephaven-engine-table Show documentation
Engine Table: Implementation and closely-coupled utilities
package io.deephaven.engine.table.impl.updateby.internal;
import io.deephaven.chunk.Chunk;
import io.deephaven.chunk.ObjectChunk;
import io.deephaven.chunk.attributes.Values;
import io.deephaven.engine.table.impl.MatchPair;
import io.deephaven.engine.table.impl.updateby.UpdateByOperator;
import org.jetbrains.annotations.NotNull;
public abstract class BaseObjectBinaryOperator extends BaseObjectUpdateByOperator {
protected class Context extends BaseObjectUpdateByOperator.Context {
public ObjectChunk objectValueChunk;
protected Context(final int chunkSize) {
super(chunkSize);
}
@Override
public void setValueChunks(@NotNull final Chunk extends Values>[] valueChunks) {
objectValueChunk = valueChunks[0].asObjectChunk();
}
@Override
public void push(int pos, int count) {
for (int ii = 0; ii < count; ii++) {
// read the value from the values chunk
final T currentVal = objectValueChunk.get(pos + ii);
if (curVal == null) {
curVal = currentVal;
} else if (currentVal != null) {
curVal = doOperation(curVal, currentVal);
}
}
}
@Override
public void reset() {
curVal = null;
}
}
public BaseObjectBinaryOperator(@NotNull final MatchPair pair,
@NotNull final String[] affectingColumns,
@NotNull final Class type) {
super(pair, affectingColumns, type);
}
protected abstract T doOperation(T bucketCurVal, T chunkCurVal);
@NotNull
@Override
public UpdateByOperator.Context makeUpdateContext(final int affectedChunkSize, final int influencerChunkSize) {
return new Context(affectedChunkSize);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy