diff options
author | Adrian Kummerlaender | 2015-01-25 17:15:59 +0100 |
---|---|---|
committer | Adrian Kummerlaender | 2015-01-25 17:15:59 +0100 |
commit | 4f2aa4218ec63107b4624e576ff391c2019690a1 (patch) | |
tree | 50315075a26d822e6ebfbd1fe23a81a33ebcf47e | |
parent | 8b0d1c5296c22ce28fd0c8f9b251308b7bbf3090 (diff) | |
download | TypeAsValue-4f2aa4218ec63107b4624e576ff391c2019690a1.tar TypeAsValue-4f2aa4218ec63107b4624e576ff391c2019690a1.tar.gz TypeAsValue-4f2aa4218ec63107b4624e576ff391c2019690a1.tar.bz2 TypeAsValue-4f2aa4218ec63107b4624e576ff391c2019690a1.tar.lz TypeAsValue-4f2aa4218ec63107b4624e576ff391c2019690a1.tar.xz TypeAsValue-4f2aa4218ec63107b4624e576ff391c2019690a1.tar.zst TypeAsValue-4f2aa4218ec63107b4624e576ff391c2019690a1.zip |
Implemented `Count` in terms of `Fold` and `Map`
* as its name implies this function counts the amount of elements satisfying a given _function_
* added appropriate test case
-rw-r--r-- | src/list/operation/higher/query.h | 11 | ||||
-rw-r--r-- | test.cc | 24 |
2 files changed, 35 insertions, 0 deletions
diff --git a/src/list/operation/higher/query.h b/src/list/operation/higher/query.h index 29f65dc..c6eabc7 100644 --- a/src/list/operation/higher/query.h +++ b/src/list/operation/higher/query.h @@ -3,6 +3,7 @@ #include "fold.h" #include "misc.h" +#include "operation/math.h" #include "operation/logic.h" namespace tav { @@ -35,6 +36,16 @@ using None = Not< typename Any<Function, List>::type >; +template < + template<typename> class Function, + typename List +> +using Count = Fold< + Add, + tav::Size<0>, + typename Map<Function, List>::type +>; + } #endif // TYPEASVALUE_SRC_LIST_OPERATION_HIGHER_QUERY_H_ @@ -607,3 +607,27 @@ static_assert( >::value, "(list-tabulate 4 square) != (list 0 1 4 9)" ); + +// list count + +static_assert( + std::is_same< + tav::Size<2>, + tav::Count< + tav::Odd, + tav::List<tav::Int<1>, tav::Int<2>, tav::Int<3>>::type + >::type + >::value, + "(count odd? (list 1 2 3)) != 2" +); + +static_assert( + std::is_same< + tav::Size<0>, + tav::Count< + tav::Even, + tav::List<tav::Int<1>, tav::Int<3>, tav::Int<5>>::type + >::type + >::value, + "(count even? (list 1 3 5)) != 0" +); |