Мой std :: hash для std :: tuples ... Есть улучшения? [закрыто]

Некоторые, возможно, заметили, что std :: hash не поддерживает кортежи. Поэтому я добавил перегрузку, которая кажется «более приятной», чем решение, которое я видел до сих пор. У кого-нибудь есть идеи по дальнейшему сокращению этого кода? Обратите внимание, что это убийца компилятора! Единственным, кто мог скомпилировать его, был «Clang 3.2» ... Компилятор Intel 13.1 не получает специализацию и постоянно говорит: «Стандарт C ++ не поддерживает хэш-блаблы». И нам не нужно говорить об оригинальном компиляторе Microsoft, не так ли?

Кстати, мое решение поддерживает рекурсивные кортежи, такие какstd::tuple<std::tuple<int,int>,int> поэтому я не уверен, относится ли это к существующим решениям, которые я видел сегодня.

namespace std
{
    template<typename... TTypes>
    class hash<std::tuple<TTypes...>>
    {
    private:
        typedef std::tuple<TTypes...> Tuple;

        template<int N>
        size_t operator()(Tuple value) const { return 0; }

        template<int N, typename THead, typename... TTail>
        size_t operator()(Tuple value) const
        {
            constexpr int Index = N - sizeof...(TTail) - 1;
            return hash<THead>()(std::get<Index>(value)) ^ operator()<N, TTail...>(value);
        }

    public:
        size_t operator()(Tuple value) const
        {
            return operator()<sizeof...(TTypes), TTypes...>(value);
        }
    };
}

Ответы на вопрос(1)

Ваш ответ на вопрос