This documentation is automatically generated by online-judge-tools/verification-helper
#include "Src/DataStructure/SegmentTree/SegmentTreeConcept.hpp"
#pragma once
#include "../../Algebra/Monoid/MonoidConcept.hpp"
namespace zawa {
namespace concepts {
template <class T>
concept MonoidWithAction = requires {
requires Monoid<typename T::ValueMonoid>;
requires Monoid<typename T::OperatorMonoid>;
{ T::mapping(
std::declval<typename T::ValueMonoid::Element>(),
std::declval<typename T::OperatorMonoid::Element>()
) } -> std::same_as<typename T::ValueMonoid::Element>;
};
} // namespace concepts
} // namespace zawa
#line 2 "Src/DataStructure/SegmentTree/SegmentTreeConcept.hpp"
#line 2 "Src/Algebra/Monoid/MonoidConcept.hpp"
#line 2 "Src/Algebra/Semigroup/SemigroupConcept.hpp"
#include <concepts>
namespace zawa {
namespace concepts {
template <class T>
concept Semigroup = requires {
typename T::Element;
{ T::operation(std::declval<typename T::Element>(), std::declval<typename T::Element>()) } -> std::same_as<typename T::Element>;
};
} // namespace concepts
} // namespace zawa
#line 4 "Src/Algebra/Monoid/MonoidConcept.hpp"
#line 6 "Src/Algebra/Monoid/MonoidConcept.hpp"
namespace zawa {
namespace concepts {
template <class T>
concept Identitiable = requires {
typename T::Element;
{ T::identity() } -> std::same_as<typename T::Element>;
};
template <class T>
concept Monoid = Semigroup<T> and Identitiable<T>;
} // namespace
} // namespace zawa
#line 4 "Src/DataStructure/SegmentTree/SegmentTreeConcept.hpp"
namespace zawa {
namespace concepts {
template <class T>
concept MonoidWithAction = requires {
requires Monoid<typename T::ValueMonoid>;
requires Monoid<typename T::OperatorMonoid>;
{ T::mapping(
std::declval<typename T::ValueMonoid::Element>(),
std::declval<typename T::OperatorMonoid::Element>()
) } -> std::same_as<typename T::ValueMonoid::Element>;
};
} // namespace concepts
} // namespace zawa