diff options
Diffstat (limited to 'src/backends/reference/workloads/ElementwiseFunction.cpp')
-rw-r--r-- | src/backends/reference/workloads/ElementwiseFunction.cpp | 34 |
1 files changed, 17 insertions, 17 deletions
diff --git a/src/backends/reference/workloads/ElementwiseFunction.cpp b/src/backends/reference/workloads/ElementwiseFunction.cpp index c8c25ef9e9..934a86217a 100644 --- a/src/backends/reference/workloads/ElementwiseFunction.cpp +++ b/src/backends/reference/workloads/ElementwiseFunction.cpp @@ -13,26 +13,26 @@ namespace armnn { -template <typename Functor, typename dataTypeInput, typename dataTypeOutput> -ElementwiseFunction<Functor, dataTypeInput, dataTypeOutput>::ElementwiseFunction(const TensorShape& inShape0, - const TensorShape& inShape1, - const TensorShape& outShape, - const dataTypeInput* inData0, - const dataTypeInput* inData1, - dataTypeOutput* outData) +template <typename Functor, typename DecoderOp, typename EncoderOp> +ElementwiseFunction<Functor, DecoderOp, EncoderOp>::ElementwiseFunction(const TensorShape& inShape0, + const TensorShape& inShape1, + const TensorShape& outShape, + DecoderOp& inData0, + DecoderOp& inData1, + EncoderOp& outData) { BroadcastLoop(inShape0, inShape1, outShape).Unroll(Functor(), 0, inData0, inData1, outData); } } //namespace armnn -template struct armnn::ElementwiseFunction<std::plus<float>, float, float>; -template struct armnn::ElementwiseFunction<std::minus<float>, float, float>; -template struct armnn::ElementwiseFunction<std::multiplies<float>, float, float>; -template struct armnn::ElementwiseFunction<std::divides<float>, float, float>; -template struct armnn::ElementwiseFunction<armnn::maximum<float>, float, float>; -template struct armnn::ElementwiseFunction<armnn::minimum<float>, float, float>; -template struct armnn::ElementwiseFunction<std::equal_to<float>, float ,uint8_t>; -template struct armnn::ElementwiseFunction<std::equal_to<uint8_t>, uint8_t, uint8_t>; -template struct armnn::ElementwiseFunction<std::greater<float>, float, uint8_t>; -template struct armnn::ElementwiseFunction<std::greater<uint8_t>, uint8_t, uint8_t>; +template struct armnn::ElementwiseFunction<std::plus<float>, armnn::Decoder, armnn::Encoder>; +template struct armnn::ElementwiseFunction<std::minus<float>, armnn::Decoder, armnn::Encoder>; +template struct armnn::ElementwiseFunction<std::multiplies<float>, armnn::Decoder, armnn::Encoder>; +template struct armnn::ElementwiseFunction<std::divides<float>, armnn::Decoder, armnn::Encoder>; +template struct armnn::ElementwiseFunction<armnn::maximum<float>, armnn::Decoder, armnn::Encoder>; +template struct armnn::ElementwiseFunction<armnn::minimum<float>, armnn::Decoder, armnn::Encoder>; + +template struct armnn::ElementwiseFunction<std::equal_to<float>, armnn::Decoder, armnn::ComparisonEncoder>; +template struct armnn::ElementwiseFunction<std::greater<float>, armnn::Decoder, armnn::ComparisonEncoder>; + |