ArmNN
 21.11
MemCopyTests.cpp
Go to the documentation of this file.
1 //
2 // Copyright © 2017 Arm Ltd. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
8 
9 #if defined(ARMCOMPUTECL_ENABLED) && defined(ARMCOMPUTENEON_ENABLED)
10 #include <cl/ClWorkloadFactory.hpp>
13 
16 #endif
17 
18 #include <doctest/doctest.h>
19 
20 TEST_SUITE("MemCopyCommon")
21 {
22 TEST_CASE("AclTypeConversions")
23 {
24  arm_compute::Strides strides(1, 2, 3, 4);
25  armnn::TensorShape convertedStrides = armnn::armcomputetensorutils::GetStrides(strides);
26 
27  CHECK(convertedStrides[0] == 4);
28  CHECK(convertedStrides[1] == 3);
29  CHECK(convertedStrides[2] == 2);
30  CHECK(convertedStrides[3] == 1);
31 
32  arm_compute::TensorShape shape(5, 6, 7, 8);
33  armnn::TensorShape convertedshape = armnn::armcomputetensorutils::GetShape(shape);
34 
35  CHECK(convertedshape[0] == 8);
36  CHECK(convertedshape[1] == 7);
37  CHECK(convertedshape[2] == 6);
38  CHECK(convertedshape[3] == 5);
39 }
40 
41 }
42 
43 #if defined(ARMCOMPUTECL_ENABLED) && defined(ARMCOMPUTENEON_ENABLED)
44 
45 TEST_CASE_FIXTURE(ClContextControlFixture, "CopyBetweenNeonAndGpu")
46 {
48  MemCopyTest<armnn::NeonWorkloadFactory, armnn::ClWorkloadFactory, armnn::DataType::Float32>(false);
49  auto predResult = CompareTensors(result.m_ActualData, result.m_ExpectedData,
50  result.m_ActualShape, result.m_ExpectedShape);
51  CHECK_MESSAGE(predResult.m_Result, predResult.m_Message.str());
52 }
53 
54 TEST_CASE_FIXTURE(ClContextControlFixture, "CopyBetweenGpuAndNeon")
55 {
57  MemCopyTest<armnn::ClWorkloadFactory, armnn::NeonWorkloadFactory, armnn::DataType::Float32>(false);
58  auto predResult = CompareTensors(result.m_ActualData, result.m_ExpectedData,
59  result.m_ActualShape, result.m_ExpectedShape);
60  CHECK_MESSAGE(predResult.m_Result, predResult.m_Message.str());
61 }
62 
63 TEST_CASE_FIXTURE(ClContextControlFixture, "CopyBetweenNeonAndGpuWithSubtensors")
64 {
66  MemCopyTest<armnn::NeonWorkloadFactory, armnn::ClWorkloadFactory, armnn::DataType::Float32>(true);
67  auto predResult = CompareTensors(result.m_ActualData, result.m_ExpectedData,
68  result.m_ActualShape, result.m_ExpectedShape);
69  CHECK_MESSAGE(predResult.m_Result, predResult.m_Message.str());
70 }
71 
72 TEST_CASE_FIXTURE(ClContextControlFixture, "CopyBetweenGpuAndNeonWithSubtensors")
73 {
75  MemCopyTest<armnn::ClWorkloadFactory, armnn::NeonWorkloadFactory, armnn::DataType::Float32>(true);
76  auto predResult = CompareTensors(result.m_ActualData, result.m_ExpectedData,
77  result.m_ActualShape, result.m_ExpectedShape);
78  CHECK_MESSAGE(predResult.m_Result, predResult.m_Message.str());
79 }
80 
81 #endif
armnn::TensorShape m_ExpectedShape
armnn::PredicateResult CompareTensors(const std::vector< T > &actualData, const std::vector< T > &expectedData, const armnn::TensorShape &actualShape, const armnn::TensorShape &expectedShape, bool compareBoolean=false, bool isDynamic=false)
TEST_SUITE("MemCopyCommon")
TEST_CASE_FIXTURE(ClContextControlFixture, "CopyBetweenNeonAndGpu")
std::vector< T > m_ExpectedData
std::vector< T > m_ActualData
armnn::TensorShape m_ActualShape