Class TDigestQuantiles.TDigestQuantilesFn
- All Implemented Interfaces:
Serializable,CombineFnBase.GlobalCombineFn<Double,,com.tdunning.math.stats.MergingDigest, com.tdunning.math.stats.MergingDigest> HasDisplayData
- Enclosing class:
TDigestQuantiles
Combine.CombineFn of TDigestQuantiles transforms.- See Also:
-
Method Summary
Modifier and TypeMethodDescriptioncom.tdunning.math.stats.MergingDigestAdds the given input value to the given accumulator, returning the new accumulator value.create(double compression) ReturnsTDigestQuantiles.TDigestQuantilesFncombiner with the given compression factor.com.tdunning.math.stats.MergingDigestReturns a new, mutable accumulator value, representing the accumulation of zero input values.com.tdunning.math.stats.MergingDigestextractOutput(com.tdunning.math.stats.MergingDigest accum) Output the whole structure so it can be queried, reused or stored easily.TypeVariable<?> Returns theTypeVariableofAccumT.Coder<com.tdunning.math.stats.MergingDigest> getAccumulatorCoder(CoderRegistry registry, Coder inputCoder) Returns theCoderto use for accumulatorAccumTvalues, or null if it is not able to be inferred.Coder<com.tdunning.math.stats.MergingDigest> getDefaultOutputCoder(CoderRegistry registry, Coder inputCoder) Returns theCoderto use by default for outputOutputTvalues, or null if it is not able to be inferred.Returns the error message for not supported default values in Combine.globally().TypeVariable<?> Returns theTypeVariableofInputT.TypeVariable<?> Returns theTypeVariableofOutputT.com.tdunning.math.stats.MergingDigestmergeAccumulators(Iterable<com.tdunning.math.stats.MergingDigest> accumulators) Returns an accumulator representing the accumulation of all the input values accumulated in the merging accumulators.voidpopulateDisplayData(DisplayData.Builder builder) Register display data for the given transform or component.Methods inherited from class org.apache.beam.sdk.transforms.Combine.CombineFn
apply, compact, defaultValue, getInputType, getOutputType
-
Method Details
-
create
ReturnsTDigestQuantiles.TDigestQuantilesFncombiner with the given compression factor.Keep in mind that a compression factor
cfof c guarantees a relative error less than 3/c at mid quantiles.
The accuracy will always be significantly less than 1% at extreme quantiles.- Parameters:
compression- the bound value for centroid and digest sizes.
-
createAccumulator
public com.tdunning.math.stats.MergingDigest createAccumulator()Description copied from class:Combine.CombineFnReturns a new, mutable accumulator value, representing the accumulation of zero input values.- Specified by:
createAccumulatorin classCombine.CombineFn<Double,com.tdunning.math.stats.MergingDigest, com.tdunning.math.stats.MergingDigest>
-
addInput
public com.tdunning.math.stats.MergingDigest addInput(com.tdunning.math.stats.MergingDigest accum, Double value) Description copied from class:Combine.CombineFnAdds the given input value to the given accumulator, returning the new accumulator value.- Specified by:
addInputin classCombine.CombineFn<Double,com.tdunning.math.stats.MergingDigest, com.tdunning.math.stats.MergingDigest> - Parameters:
accum- may be modified and returned for efficiencyvalue- should not be mutated
-
extractOutput
public com.tdunning.math.stats.MergingDigest extractOutput(com.tdunning.math.stats.MergingDigest accum) Output the whole structure so it can be queried, reused or stored easily.- Specified by:
extractOutputin classCombine.CombineFn<Double,com.tdunning.math.stats.MergingDigest, com.tdunning.math.stats.MergingDigest> - Parameters:
accum- can be modified for efficiency
-
mergeAccumulators
public com.tdunning.math.stats.MergingDigest mergeAccumulators(Iterable<com.tdunning.math.stats.MergingDigest> accumulators) Description copied from class:Combine.CombineFnReturns an accumulator representing the accumulation of all the input values accumulated in the merging accumulators.- Specified by:
mergeAccumulatorsin classCombine.CombineFn<Double,com.tdunning.math.stats.MergingDigest, com.tdunning.math.stats.MergingDigest> - Parameters:
accumulators- only the first accumulator may be modified and returned for efficiency; the other accumulators should not be mutated, because they may be shared with other code and mutating them could lead to incorrect results or data corruption.
-
getAccumulatorCoder
public Coder<com.tdunning.math.stats.MergingDigest> getAccumulatorCoder(CoderRegistry registry, Coder inputCoder) Description copied from interface:CombineFnBase.GlobalCombineFnReturns theCoderto use for accumulatorAccumTvalues, or null if it is not able to be inferred.By default, uses the knowledge of the
Coderbeing used forInputTvalues and the enclosingPipeline'sCoderRegistryto try to infer the Coder forAccumTvalues.This is the Coder used to send data through a communication-intensive shuffle step, so a compact and efficient representation may have significant performance benefits.
- Specified by:
getAccumulatorCoderin interfaceCombineFnBase.GlobalCombineFn<Double,com.tdunning.math.stats.MergingDigest, com.tdunning.math.stats.MergingDigest>
-
getDefaultOutputCoder
public Coder<com.tdunning.math.stats.MergingDigest> getDefaultOutputCoder(CoderRegistry registry, Coder inputCoder) Description copied from interface:CombineFnBase.GlobalCombineFnReturns theCoderto use by default for outputOutputTvalues, or null if it is not able to be inferred.By default, uses the knowledge of the
Coderbeing used for inputInputTvalues and the enclosingPipeline'sCoderRegistryto try to infer the Coder forOutputTvalues.- Specified by:
getDefaultOutputCoderin interfaceCombineFnBase.GlobalCombineFn<Double,com.tdunning.math.stats.MergingDigest, com.tdunning.math.stats.MergingDigest>
-
populateDisplayData
Register display data for the given transform or component.populateDisplayData(DisplayData.Builder)is invoked by Pipeline runners to collect display data viaDisplayData.from(HasDisplayData). Implementations may callsuper.populateDisplayData(builder)in order to register display data in the current namespace, but should otherwise usesubcomponent.populateDisplayData(builder)to use the namespace of the subcomponent.By default, does not register any display data. Implementors may override this method to provide their own display data.
- Specified by:
populateDisplayDatain interfaceHasDisplayData- Parameters:
builder- The builder to populate with display data.- See Also:
-
getIncompatibleGlobalWindowErrorMessage
Description copied from interface:CombineFnBase.GlobalCombineFnReturns the error message for not supported default values in Combine.globally().- Specified by:
getIncompatibleGlobalWindowErrorMessagein interfaceCombineFnBase.GlobalCombineFn<InputT,AccumT, OutputT>
-
getInputTVariable
Returns theTypeVariableofInputT. -
getAccumTVariable
Returns theTypeVariableofAccumT. -
getOutputTVariable
Returns theTypeVariableofOutputT.
-