blob: 132550342cce82a8987f155a3fa156b7a5b51f9a [file] [log] [blame]
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +00006#include <aclCommon/ArmComputeTensorUtils.hpp>
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +00007#include <aclCommon/test/MemCopyTestImpl.hpp>
Aron Virginas-Tar56055192018-11-12 18:10:43 +00008
Matteo Martincighd95e9062019-01-31 15:35:59 +00009#if defined(ARMCOMPUTECL_ENABLED) && defined(ARMCOMPUTENEON_ENABLED)
10#include <cl/ClWorkloadFactory.hpp>
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000011#include <cl/test/ClContextControlFixture.hpp>
Aron Virginas-Tar56055192018-11-12 18:10:43 +000012#include <cl/test/ClWorkloadFactoryHelper.hpp>
13
Matteo Martincighd95e9062019-01-31 15:35:59 +000014#include <neon/NeonWorkloadFactory.hpp>
Aron Virginas-Tar56055192018-11-12 18:10:43 +000015#include <neon/test/NeonWorkloadFactoryHelper.hpp>
David Beck39fedf02018-10-16 12:58:49 +010016#endif
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010017
Sadik Armagan1625efc2021-06-10 18:24:34 +010018#include <doctest/doctest.h>
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010019
Sadik Armagan1625efc2021-06-10 18:24:34 +010020TEST_SUITE("MemCopyCommon")
21{
22TEST_CASE("AclTypeConversions")
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010023{
24 arm_compute::Strides strides(1, 2, 3, 4);
25 armnn::TensorShape convertedStrides = armnn::armcomputetensorutils::GetStrides(strides);
26
Sadik Armagan1625efc2021-06-10 18:24:34 +010027 CHECK(convertedStrides[0] == 4);
28 CHECK(convertedStrides[1] == 3);
29 CHECK(convertedStrides[2] == 2);
30 CHECK(convertedStrides[3] == 1);
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010031
32 arm_compute::TensorShape shape(5, 6, 7, 8);
33 armnn::TensorShape convertedshape = armnn::armcomputetensorutils::GetShape(shape);
34
Sadik Armagan1625efc2021-06-10 18:24:34 +010035 CHECK(convertedshape[0] == 8);
36 CHECK(convertedshape[1] == 7);
37 CHECK(convertedshape[2] == 6);
38 CHECK(convertedshape[3] == 5);
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010039}
40
Sadik Armagan1625efc2021-06-10 18:24:34 +010041}
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +010042
Matteo Martincighd95e9062019-01-31 15:35:59 +000043#if defined(ARMCOMPUTECL_ENABLED) && defined(ARMCOMPUTENEON_ENABLED)
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010044
Sadik Armagan1625efc2021-06-10 18:24:34 +010045TEST_CASE_FIXTURE(ClContextControlFixture, "CopyBetweenNeonAndGpu")
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010046{
Matteo Martincigh49124022019-01-11 13:25:59 +000047 LayerTestResult<float, 4> result =
48 MemCopyTest<armnn::NeonWorkloadFactory, armnn::ClWorkloadFactory, armnn::DataType::Float32>(false);
Sadik Armagan483c8112021-06-01 09:24:52 +010049 auto predResult = CompareTensors(result.m_ActualData, result.m_ExpectedData,
50 result.m_ActualShape, result.m_ExpectedShape);
Sadik Armagan1625efc2021-06-10 18:24:34 +010051 CHECK_MESSAGE(predResult.m_Result, predResult.m_Message.str());
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010052}
53
Sadik Armagan1625efc2021-06-10 18:24:34 +010054TEST_CASE_FIXTURE(ClContextControlFixture, "CopyBetweenGpuAndNeon")
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010055{
Matteo Martincigh49124022019-01-11 13:25:59 +000056 LayerTestResult<float, 4> result =
57 MemCopyTest<armnn::ClWorkloadFactory, armnn::NeonWorkloadFactory, armnn::DataType::Float32>(false);
Sadik Armagan483c8112021-06-01 09:24:52 +010058 auto predResult = CompareTensors(result.m_ActualData, result.m_ExpectedData,
59 result.m_ActualShape, result.m_ExpectedShape);
Sadik Armagan1625efc2021-06-10 18:24:34 +010060 CHECK_MESSAGE(predResult.m_Result, predResult.m_Message.str());
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010061}
62
Sadik Armagan1625efc2021-06-10 18:24:34 +010063TEST_CASE_FIXTURE(ClContextControlFixture, "CopyBetweenNeonAndGpuWithSubtensors")
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010064{
Matteo Martincigh49124022019-01-11 13:25:59 +000065 LayerTestResult<float, 4> result =
66 MemCopyTest<armnn::NeonWorkloadFactory, armnn::ClWorkloadFactory, armnn::DataType::Float32>(true);
Sadik Armagan483c8112021-06-01 09:24:52 +010067 auto predResult = CompareTensors(result.m_ActualData, result.m_ExpectedData,
68 result.m_ActualShape, result.m_ExpectedShape);
Sadik Armagan1625efc2021-06-10 18:24:34 +010069 CHECK_MESSAGE(predResult.m_Result, predResult.m_Message.str());
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010070}
71
Sadik Armagan1625efc2021-06-10 18:24:34 +010072TEST_CASE_FIXTURE(ClContextControlFixture, "CopyBetweenGpuAndNeonWithSubtensors")
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010073{
Matteo Martincigh49124022019-01-11 13:25:59 +000074 LayerTestResult<float, 4> result =
75 MemCopyTest<armnn::ClWorkloadFactory, armnn::NeonWorkloadFactory, armnn::DataType::Float32>(true);
Sadik Armagan483c8112021-06-01 09:24:52 +010076 auto predResult = CompareTensors(result.m_ActualData, result.m_ExpectedData,
77 result.m_ActualShape, result.m_ExpectedShape);
Sadik Armagan1625efc2021-06-10 18:24:34 +010078 CHECK_MESSAGE(predResult.m_Result, predResult.m_Message.str());
Aron Virginas-Tar3b278e92018-10-12 13:00:55 +010079}
80
Matteo Martincighd95e9062019-01-31 15:35:59 +000081#endif