File indexing completed on 2025-09-17 08:54:11
0001
0002
0003
0004
0005
0006
0007 #pragma once
0008
0009 #include <cstddef>
0010 #include <type_traits>
0011 #include <utility>
0012
0013 namespace covfie::utility {
0014
0015
0016
0017
0018
0019
0020 template <typename, typename>
0021 struct concat_index_sequence {
0022 };
0023
0024
0025
0026
0027
0028
0029 template <std::size_t... L, std::size_t... H>
0030 struct concat_index_sequence<
0031 std::index_sequence<L...>,
0032 std::index_sequence<H...>> {
0033 using type = std::index_sequence<L..., H...>;
0034 };
0035
0036
0037
0038
0039
0040
0041
0042
0043 template <typename, typename>
0044 struct filter_index_sequence_lt {
0045 };
0046
0047
0048
0049
0050
0051 template <std::size_t N>
0052 struct filter_index_sequence_lt<
0053 std::integral_constant<std::size_t, N>,
0054 std::index_sequence<>> {
0055 using type = std::index_sequence<>;
0056 };
0057
0058
0059
0060
0061
0062
0063 template <std::size_t N, std::size_t V, std::size_t... Vs>
0064 struct filter_index_sequence_lt<
0065 std::integral_constant<std::size_t, N>,
0066 std::index_sequence<V, Vs...>> {
0067 using type = typename concat_index_sequence <
0068 std::conditional_t<
0069 V<N, std::index_sequence<V>, std::index_sequence<>>,
0070 typename filter_index_sequence_lt<
0071 std::integral_constant<std::size_t, N>,
0072 std::index_sequence<Vs...>>::type>::type;
0073 };
0074
0075
0076
0077
0078
0079
0080
0081
0082 template <typename, typename>
0083 struct filter_index_sequence_geq {
0084 };
0085
0086
0087
0088
0089
0090 template <std::size_t N>
0091 struct filter_index_sequence_geq<
0092 std::integral_constant<std::size_t, N>,
0093 std::index_sequence<>> {
0094 using type = std::index_sequence<>;
0095 };
0096
0097
0098
0099
0100
0101
0102 template <std::size_t N, std::size_t V, std::size_t... Vs>
0103 struct filter_index_sequence_geq<
0104 std::integral_constant<std::size_t, N>,
0105 std::index_sequence<V, Vs...>> {
0106 using type = typename concat_index_sequence<
0107 std::conditional_t<
0108 V >= N,
0109 std::index_sequence<V>,
0110 std::index_sequence<>>,
0111 typename filter_index_sequence_geq<
0112 std::integral_constant<std::size_t, N>,
0113 std::index_sequence<Vs...>>::type>::type;
0114 };
0115
0116
0117
0118
0119
0120
0121
0122
0123 template <typename>
0124 struct sort_index_sequence {
0125 };
0126
0127
0128
0129
0130
0131 template <>
0132 struct sort_index_sequence<std::index_sequence<>> {
0133 using type = std::index_sequence<>;
0134 };
0135
0136
0137
0138
0139
0140
0141
0142
0143 template <std::size_t N, std::size_t... Ns>
0144 struct sort_index_sequence<std::index_sequence<N, Ns...>> {
0145 using type = typename concat_index_sequence<
0146 typename sort_index_sequence<typename filter_index_sequence_lt<
0147 std::integral_constant<std::size_t, N>,
0148 std::index_sequence<Ns...>>::type>::type,
0149 typename concat_index_sequence<
0150 std::index_sequence<N>,
0151 typename sort_index_sequence<typename filter_index_sequence_geq<
0152 std::integral_constant<std::size_t, N>,
0153 std::index_sequence<Ns...>>::type>::type>::type>::type;
0154 };
0155
0156
0157
0158
0159
0160
0161
0162
0163 template <typename, typename>
0164 struct is_permutation : std::false_type {
0165 };
0166
0167
0168
0169
0170
0171
0172 template <std::size_t... Us, std::size_t... Vs>
0173 struct is_permutation<std::index_sequence<Us...>, std::index_sequence<Vs...>>
0174 : std::is_same<
0175 typename sort_index_sequence<std::index_sequence<Us...>>::type,
0176 typename sort_index_sequence<std::index_sequence<Vs...>>::type> {
0177 };
0178 }