mirror of
https://github.com/ROCm/composable_kernel.git
synced 2026-06-30 11:47:48 +00:00
93 lines
3.0 KiB
C++
93 lines
3.0 KiB
C++
// Copyright (c) Advanced Micro Devices, Inc., or its affiliates.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
#include <gtest/gtest.h>
|
|
#include "ck/utility/sequence_helper.hpp"
|
|
#include "ck/utility/tuple_helper.hpp"
|
|
|
|
using namespace ck;
|
|
|
|
// Tests for sequence_find_value (PR #3600)
|
|
TEST(SequenceFindValue, FindExistingElement)
|
|
{
|
|
constexpr auto result = sequence_find_value<17>(Sequence<5, 11, 17, 23, 29>{});
|
|
EXPECT_EQ(result, 2); // 17 is at index 2
|
|
}
|
|
|
|
TEST(SequenceFindValue, FindFirstElement)
|
|
{
|
|
constexpr auto result = sequence_find_value<7>(Sequence<7, 13, 19, 31>{});
|
|
EXPECT_EQ(result, 0);
|
|
}
|
|
|
|
TEST(SequenceFindValue, FindLastElement)
|
|
{
|
|
constexpr auto result = sequence_find_value<41>(Sequence<3, 11, 23, 41>{});
|
|
EXPECT_EQ(result, 3);
|
|
}
|
|
|
|
TEST(SequenceFindValue, ElementNotFound)
|
|
{
|
|
constexpr auto result = sequence_find_value<50>(Sequence<2, 8, 14, 26>{});
|
|
EXPECT_EQ(result, -1);
|
|
}
|
|
|
|
TEST(SequenceFindValue, EmptySequence)
|
|
{
|
|
constexpr auto result = sequence_find_value<1>(Sequence<>{});
|
|
EXPECT_EQ(result, -1);
|
|
}
|
|
|
|
// Tests for find_in_tuple_of_sequences (PR #3600)
|
|
TEST(FindInTupleOfSequences, FindInFirstSequence)
|
|
{
|
|
constexpr auto tuple_of_seqs =
|
|
make_tuple(Sequence<5, 11>{}, Sequence<17, 23>{}, Sequence<29, 37>{});
|
|
constexpr auto result = find_in_tuple_of_sequences<11>(tuple_of_seqs);
|
|
EXPECT_EQ(result.itran, 0); // Found in first sequence (index 0)
|
|
EXPECT_EQ(result.idim_up, 1); // At position 1 within that sequence
|
|
EXPECT_TRUE(result.found);
|
|
}
|
|
|
|
TEST(FindInTupleOfSequences, FindInMiddleSequence)
|
|
{
|
|
constexpr auto tuple_of_seqs =
|
|
make_tuple(Sequence<2, 4, 6>{}, Sequence<8, 10>{}, Sequence<12>{});
|
|
constexpr auto result = find_in_tuple_of_sequences<10>(tuple_of_seqs);
|
|
EXPECT_EQ(result.itran, 1); // Found in second sequence (index 1)
|
|
EXPECT_EQ(result.idim_up, 1); // At position 1 within that sequence
|
|
EXPECT_TRUE(result.found);
|
|
}
|
|
|
|
TEST(FindInTupleOfSequences, FindInLastSequence)
|
|
{
|
|
constexpr auto tuple_of_seqs = make_tuple(Sequence<3>{}, Sequence<7>{}, Sequence<13, 19, 31>{});
|
|
constexpr auto result = find_in_tuple_of_sequences<31>(tuple_of_seqs);
|
|
EXPECT_EQ(result.itran, 2); // Found in third sequence (index 2)
|
|
EXPECT_EQ(result.idim_up, 2); // At position 2 within that sequence
|
|
EXPECT_TRUE(result.found);
|
|
}
|
|
|
|
TEST(FindInTupleOfSequences, NotFound)
|
|
{
|
|
constexpr auto tuple_of_seqs = make_tuple(Sequence<1, 3>{}, Sequence<5, 7, 9>{});
|
|
constexpr auto result = find_in_tuple_of_sequences<100>(tuple_of_seqs);
|
|
EXPECT_FALSE(result.found);
|
|
}
|
|
|
|
TEST(FindInTupleOfSequences, EmptyTuple)
|
|
{
|
|
constexpr auto tuple_of_seqs = make_tuple();
|
|
constexpr auto result = find_in_tuple_of_sequences<1>(tuple_of_seqs);
|
|
EXPECT_FALSE(result.found);
|
|
}
|
|
|
|
TEST(FindInTupleOfSequences, SingleSequence)
|
|
{
|
|
constexpr auto tuple_of_seqs = make_tuple(Sequence<41, 43, 47, 53>{});
|
|
constexpr auto result = find_in_tuple_of_sequences<47>(tuple_of_seqs);
|
|
EXPECT_EQ(result.itran, 0);
|
|
EXPECT_EQ(result.idim_up, 2);
|
|
EXPECT_TRUE(result.found);
|
|
}
|