10#ifndef XTENSOR_XSET_OPERATION_HPP
11#define XTENSOR_XSET_OPERATION_HPP
16#include <xtl/xsequence.hpp>
18#include "../containers/xscalar.hpp"
19#include "../core/xfunction.hpp"
20#include "../core/xmath.hpp"
21#include "../core/xstrides.hpp"
22#include "../utils/xutils.hpp"
23#include "../views/xstrided_view.hpp"
36 template <
bool lvalue>
40 static auto make(E&& e)
42 return [&e](
const auto& t)
44 return std::find(e.begin(), e.end(), t) != e.end();
50 struct lambda_isin<false>
53 static auto make(E&& e)
55 return [e](
const auto& t)
57 return std::find(e.begin(), e.end(), t) != e.end();
74 template <
class E,
class T>
75 inline auto isin(E&& element, std::initializer_list<T> test_elements)
noexcept
77 auto lambda = [test_elements](
const auto& t)
79 return std::find(test_elements.begin(), test_elements.end(), t) != test_elements.end();
94 template <
class E,
class F>
95 inline auto isin(E&& element, F&& test_elements)
noexcept
98 auto lambda = detail::lambda_isin<std::is_lvalue_reference<F>::value>::make(std::forward<F>(test_elements
114 template <
class E, iterator_concept I>
115 inline auto isin(E&& element, I&& test_elements_begin, I&& test_elements_end)
noexcept
117 auto lambda = [&test_elements_begin, &test_elements_end](
const auto& t)
119 return std::find(test_elements_begin, test_elements_end, t) != test_elements_end;
134 template <
class E,
class T>
135 inline auto in1d(E&& element, std::initializer_list<T> test_elements)
noexcept
137 XTENSOR_ASSERT(element.dimension() == 1ul);
138 return isin(std::forward<E>(element), std::forward<std::initializer_list<T>>(test_elements));
151 template <
class E,
class F>
152 inline auto in1d(E&& element, F&& test_elements)
noexcept
155 XTENSOR_ASSERT(element.dimension() == 1ul);
156 XTENSOR_ASSERT(test_elements.dimension() == 1ul);
157 return isin(std::forward<E>(element), std::forward<F>(test_elements));
171 template <
class E, iterator_concept I>
172 inline auto in1d(E&& element, I&& test_elements_begin, I&& test_elements_end)
noexcept
174 XTENSOR_ASSERT(element.dimension() == 1ul);
176 std::forward<E>(element),
177 std::forward<I>(test_elements_begin),
178 std::forward<I>(test_elements_end)
191 template <
class E1,
class E2>
194 XTENSOR_ASSERT(std::is_sorted(a.cbegin(), a.cend()));
200 for (
size_t i = 0; i < v.size(); ++i)
202 out(i) =
static_cast<std::size_t
>(std::lower_bound(a.cbegin(), a.cend(), v(i)) - a.cbegin());
207 for (
size_t i = 0; i < v.size(); ++i)
209 out(i) =
static_cast<std::size_t
>(std::upper_bound(a.cbegin(), a.cend(), v(i)) - a.cbegin());
auto in1d(E &&element, std::initializer_list< T > test_elements) noexcept
in1d
auto isin(E &&element, std::initializer_list< T > test_elements) noexcept
isin
auto searchsorted(E1 &&a, E2 &&v, bool right=true)
Find indices where elements should be inserted to maintain order.
standard mathematical functions for xexpressions
auto make_lambda_xfunction(F &&lambda, E &&... args)
Create a xfunction from a lambda.
xarray< T, L > empty(const S &shape)
Create a xcontainer (xarray, xtensor or xtensor_fixed) with uninitialized values of with value_type T...