Class TypedCombineFnDelegate<InputT,AccumT,OutputT>
- Type Parameters:
InputT
- the type of inputAccumT
- the type of accumulatorOutputT
- the type of output
- All Implemented Interfaces:
Serializable
,CombineFnBase.GlobalCombineFn<InputT,
,AccumT, OutputT> HasDisplayData
Combine.CombineFn
delegating all relevant calls to given delegate. This is used to
create a type anonymous class for cases where the CombineFn is a generic class. The anonymous
class can then be used in a UDAF as
.registerUdaf("UDAF", new TypedCombineFnDelegateinvalid input: '<'>(genericCombineFn) {})
- See Also:
-
Constructor Summary
ConstructorsModifierConstructorDescriptionprotected
TypedCombineFnDelegate
(Combine.CombineFn<InputT, AccumT, OutputT> delegate) -
Method Summary
Modifier and TypeMethodDescriptionAdds the given input value to the given accumulator, returning the new accumulator value.Applies thisCombineFn
to a collection of input values to produce a combined output value.Returns an accumulator that represents the same logical value as the input accumulator, but may have a more compact representation.Returns a new, mutable accumulator value, representing the accumulation of zero input values.Returns the default value when there are no values added to the accumulator.extractOutput
(AccumT accumulator) Returns the output value that is the result of combining all the input values represented by the given accumulator.TypeVariable
<?> Returns theTypeVariable
ofAccumT
.getAccumulatorCoder
(CoderRegistry registry, Coder<InputT> inputCoder) Returns theCoder
to use for accumulatorAccumT
values, or null if it is not able to be inferred.getDefaultOutputCoder
(CoderRegistry registry, Coder<InputT> inputCoder) Returns theCoder
to use by default for outputOutputT
values, or null if it is not able to be inferred.Returns the error message for not supported default values in Combine.globally().TypeVariable
<?> Returns theTypeVariable
ofInputT
.Returns aTypeDescriptor
capturing what is known statically about the input type of thisCombineFn
instance's most-derived class.TypeVariable
<?> Returns theTypeVariable
ofOutputT
.Returns aTypeDescriptor
capturing what is known statically about the output type of thisCombineFn
instance's most-derived class.mergeAccumulators
(Iterable<AccumT> accumulators) Returns an accumulator representing the accumulation of all the input values accumulated in the merging accumulators.void
populateDisplayData
(DisplayData.Builder builder) Register display data for the given transform or component.
-
Constructor Details
-
TypedCombineFnDelegate
-
-
Method Details
-
getOutputType
Description copied from class:Combine.CombineFn
Returns aTypeDescriptor
capturing what is known statically about the output type of thisCombineFn
instance's most-derived class.In the normal case of a concrete
CombineFn
subclass with no generic type parameters of its own, this will be a complete non-generic type.- Overrides:
getOutputType
in classCombine.CombineFn<InputT,
AccumT, OutputT>
-
getInputType
Description copied from class:Combine.CombineFn
Returns aTypeDescriptor
capturing what is known statically about the input type of thisCombineFn
instance's most-derived class.In the normal case of a concrete
CombineFn
subclass with no generic type parameters of its own, this will be a complete non-generic type.- Overrides:
getInputType
in classCombine.CombineFn<InputT,
AccumT, OutputT>
-
createAccumulator
Description copied from class:Combine.CombineFn
Returns a new, mutable accumulator value, representing the accumulation of zero input values.- Specified by:
createAccumulator
in classCombine.CombineFn<InputT,
AccumT, OutputT>
-
addInput
Description copied from class:Combine.CombineFn
Adds the given input value to the given accumulator, returning the new accumulator value.- Specified by:
addInput
in classCombine.CombineFn<InputT,
AccumT, OutputT> - Parameters:
mutableAccumulator
- may be modified and returned for efficiencyinput
- should not be mutated
-
mergeAccumulators
Description copied from class:Combine.CombineFn
Returns an accumulator representing the accumulation of all the input values accumulated in the merging accumulators.- Specified by:
mergeAccumulators
in classCombine.CombineFn<InputT,
AccumT, OutputT> - 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.
-
extractOutput
Description copied from class:Combine.CombineFn
Returns the output value that is the result of combining all the input values represented by the given accumulator.- Specified by:
extractOutput
in classCombine.CombineFn<InputT,
AccumT, OutputT> - Parameters:
accumulator
- can be modified for efficiency
-
compact
Description copied from class:Combine.CombineFn
Returns an accumulator that represents the same logical value as the input accumulator, but may have a more compact representation.For most CombineFns this would be a no-op, but should be overridden by CombineFns that (for example) buffer up elements and combine them in batches.
For efficiency, the input accumulator may be modified and returned.
By default returns the original accumulator.
- Overrides:
compact
in classCombine.CombineFn<InputT,
AccumT, OutputT>
-
apply
Description copied from class:Combine.CombineFn
Applies thisCombineFn
to a collection of input values to produce a combined output value.Useful when using a
CombineFn
separately from aCombine
transform. Does not invoke theCombine.CombineFn.mergeAccumulators(java.lang.Iterable<AccumT>)
operation.- Overrides:
apply
in classCombine.CombineFn<InputT,
AccumT, OutputT>
-
defaultValue
Description copied from class:Combine.CombineFn
Returns the default value when there are no values added to the accumulator.By default returns the extract output of an empty accumulator.
- Specified by:
defaultValue
in interfaceCombineFnBase.GlobalCombineFn<InputT,
AccumT, OutputT> - Overrides:
defaultValue
in classCombine.CombineFn<InputT,
AccumT, OutputT>
-
getAccumulatorCoder
public Coder<AccumT> getAccumulatorCoder(CoderRegistry registry, Coder<InputT> inputCoder) throws CannotProvideCoderException Description copied from interface:CombineFnBase.GlobalCombineFn
Returns theCoder
to use for accumulatorAccumT
values, or null if it is not able to be inferred.By default, uses the knowledge of the
Coder
being used forInputT
values and the enclosingPipeline
'sCoderRegistry
to try to infer the Coder forAccumT
values.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:
getAccumulatorCoder
in interfaceCombineFnBase.GlobalCombineFn<InputT,
AccumT, OutputT> - Throws:
CannotProvideCoderException
-
getDefaultOutputCoder
public Coder<OutputT> getDefaultOutputCoder(CoderRegistry registry, Coder<InputT> inputCoder) throws CannotProvideCoderException Description copied from interface:CombineFnBase.GlobalCombineFn
Returns theCoder
to use by default for outputOutputT
values, or null if it is not able to be inferred.By default, uses the knowledge of the
Coder
being used for inputInputT
values and the enclosingPipeline
'sCoderRegistry
to try to infer the Coder forOutputT
values.- Specified by:
getDefaultOutputCoder
in interfaceCombineFnBase.GlobalCombineFn<InputT,
AccumT, OutputT> - Throws:
CannotProvideCoderException
-
getIncompatibleGlobalWindowErrorMessage
Description copied from interface:CombineFnBase.GlobalCombineFn
Returns the error message for not supported default values in Combine.globally().- Specified by:
getIncompatibleGlobalWindowErrorMessage
in interfaceCombineFnBase.GlobalCombineFn<InputT,
AccumT, OutputT>
-
getInputTVariable
Returns theTypeVariable
ofInputT
. -
getAccumTVariable
Returns theTypeVariable
ofAccumT
. -
getOutputTVariable
Returns theTypeVariable
ofOutputT
. -
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:
populateDisplayData
in interfaceHasDisplayData
- Parameters:
builder
- The builder to populate with display data.- See Also:
-