io.deephaven.api.updateby.spec.EmsSpec Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of deephaven-table-api Show documentation
Show all versions of deephaven-table-api Show documentation
The Deephaven table operations API
The newest version!
//
// Copyright (c) 2016-2024 Deephaven Data Labs and Patent Pending
//
package io.deephaven.api.updateby.spec;
import io.deephaven.annotations.BuildableStyle;
import io.deephaven.api.updateby.OperationControl;
import org.immutables.value.Value.Immutable;
import java.time.Duration;
import java.util.Optional;
/**
* A {@link UpdateBySpec} for performing an Exponential Moving Sum across the specified columns
*/
@Immutable
@BuildableStyle
public abstract class EmsSpec extends UpdateBySpecBase {
public static EmsSpec of(OperationControl control, WindowScale windowScale) {
return ImmutableEmsSpec.builder().control(control).windowScale(windowScale).build();
}
public static EmsSpec of(WindowScale windowScale) {
return ImmutableEmsSpec.builder().windowScale(windowScale).build();
}
public static EmsSpec ofTime(final OperationControl control,
final String timestampCol,
long timeScaleNanos) {
return of(control, WindowScale.ofTime(timestampCol, timeScaleNanos));
}
public static EmsSpec ofTime(final String timestampCol, long timeScaleNanos) {
return of(WindowScale.ofTime(timestampCol, timeScaleNanos));
}
public static EmsSpec ofTime(final OperationControl control,
final String timestampCol,
Duration emaDuration) {
return of(control, WindowScale.ofTime(timestampCol, emaDuration));
}
public static EmsSpec ofTime(final String timestampCol, Duration emaDuration) {
return of(WindowScale.ofTime(timestampCol, emaDuration));
}
public static EmsSpec ofTicks(OperationControl control, double tickWindow) {
return of(control, WindowScale.ofTicks(tickWindow));
}
public static EmsSpec ofTicks(double tickWindow) {
return of(WindowScale.ofTicks(tickWindow));
}
public abstract Optional control();
public abstract WindowScale windowScale();
public final OperationControl controlOrDefault() {
return control().orElseGet(OperationControl::defaultInstance);
}
@Override
public final boolean applicableTo(Class> inputType) {
// is primitive or boxed numeric?
return applicableToNumeric(inputType)
|| inputType == char.class || inputType == Character.class;
}
@Override
public final T walk(Visitor visitor) {
return visitor.visit(this);
}
}