25 template<armnn::DataType ArmnnType,
typename T = armnn::ResolveType<ArmnnType>>
32 const std::vector<float>& inputValues,
33 const std::vector<float>& expectedOutputValues,
39 auto inputTensor = MakeTensor<T, 4>(inputTensorInfo,
40 armnnUtils::QuantizedVector<T>(inputValues, qScale, qOffset));
43 result.outputExpected = MakeTensor<T, 4>(outputTensorInfo,
44 armnnUtils::QuantizedVector<T>(expectedOutputValues, qScale, qOffset));
46 std::unique_ptr<armnn::ITensorHandle> inputHandle = tensorHandleFactory.CreateTensorHandle(inputTensorInfo);
47 std::unique_ptr<armnn::ITensorHandle> outputHandle = tensorHandleFactory.CreateTensorHandle(outputTensorInfo);
52 AddInputToWorkload(descriptor, info, inputTensorInfo, inputHandle.get());
53 AddOutputToWorkload(descriptor, info, outputTensorInfo, outputHandle.get());
55 std::unique_ptr<armnn::IWorkload> workload = workloadFactory.CreateInstanceNormalization(descriptor, info);
57 inputHandle->Allocate();
58 outputHandle->Allocate();
69 template<armnn::DataType ArmnnType,
typename T = armnn::ResolveType<ArmnnType>>
86 std::vector<float> inputValues
109 std::vector<float> expectedOutputValues
121 0.99995005f, -0.7337929f,
123 -0.99995005f, 0.52413774f,
126 -0.99995005f, -1.1531031f,
128 0.99995005f, 1.3627582f
143 return InstanceNormTestImpl<ArmnnType>(
150 expectedOutputValues,
154 template<armnn::DataType ArmnnType,
typename T = armnn::ResolveType<ArmnnType>>
171 std::vector<float> inputValues
194 std::vector<float> expectedOutputValues
229 return InstanceNormTestImpl<ArmnnType>(
236 expectedOutputValues,
248 return InstanceNormTest<armnn::DataType::Float32>(workloadFactory, memoryManager, tensorHandleFactory, dataLayout);
257 return InstanceNormTest<armnn::DataType::Float16>(workloadFactory, memoryManager, tensorHandleFactory, dataLayout);
266 return InstanceNormTest2<armnn::DataType::Float32>(workloadFactory, memoryManager, tensorHandleFactory, dataLayout);
275 return InstanceNormTest2<armnn::DataType::Float16>(workloadFactory, memoryManager, tensorHandleFactory, dataLayout);
float m_Gamma
Gamma, the scale scalar value applied for the normalized tensor. Defaults to 1.0. ...
LayerTestResult< float, 4 > InstanceNormFloat32Test2(armnn::IWorkloadFactory &workloadFactory, const armnn::IBackendInternal::IMemoryManagerSharedPtr &memoryManager, const armnn::ITensorHandleFactory &tensorHandleFactory, armnn::DataLayout dataLayout)
void IgnoreUnused(Ts &&...)
LayerTestResult< armnn::Half, 4 > InstanceNormFloat16Test2(armnn::IWorkloadFactory &workloadFactory, const armnn::IBackendInternal::IMemoryManagerSharedPtr &memoryManager, const armnn::ITensorHandleFactory &tensorHandleFactory, armnn::DataLayout dataLayout)
LayerDescriptor m_Parameters
float m_Eps
Epsilon, small scalar value added to variance to avoid dividing by zero. Defaults to 1e-12f...
std::shared_ptr< IMemoryManager > IMemoryManagerSharedPtr
LayerTestResult< armnn::Half, 4 > InstanceNormFloat16Test(armnn::IWorkloadFactory &workloadFactory, const armnn::IBackendInternal::IMemoryManagerSharedPtr &memoryManager, const armnn::ITensorHandleFactory &tensorHandleFactory, armnn::DataLayout dataLayout)
void CopyDataFromITensorHandle(void *memory, const armnn::ITensorHandle *tensorHandle)
DataLayout m_DataLayout
The data layout to be used (NCHW, NHWC).
float m_Beta
Beta, the offset scalar value applied for the normalized tensor. Defaults to 1.0. ...
LayerTestResult< float, 4 > InstanceNormFloat32Test(armnn::IWorkloadFactory &workloadFactory, const armnn::IBackendInternal::IMemoryManagerSharedPtr &memoryManager, const armnn::ITensorHandleFactory &tensorHandleFactory, armnn::DataLayout dataLayout)
Contains information about inputs and outputs to a layer.
void CopyDataToITensorHandle(armnn::ITensorHandle *tensorHandle, const void *memory)
void PermuteTensorNhwcToNchw(armnn::TensorInfo &tensorInfo, std::vector< T > &tensorData)