Morpheus 1.0.0
Dynamic matrix type and algorithms for sparse matrices
Loading...
Searching...
No Matches
DenseVector/Serial/Morpheus_Copy_Impl.hpp
1
24#ifndef MORPHEUS_DENSEVECTOR_SERIAL_COPY_IMPL_HPP
25#define MORPHEUS_DENSEVECTOR_SERIAL_COPY_IMPL_HPP
26
27#include <Morpheus_Macros.hpp>
28#if defined(MORPHEUS_ENABLE_SERIAL)
29
30#include <Morpheus_SpaceTraits.hpp>
31#include <Morpheus_FormatTraits.hpp>
32#include <Morpheus_FormatTags.hpp>
33#include <Morpheus_Spaces.hpp>
34
35namespace Morpheus {
36namespace Impl {
37
38template <typename ExecSpace, typename KeyType, typename SourceType,
39 typename DestinationType>
40void copy_by_key(
41 const KeyType keys, const SourceType& src, DestinationType& dst,
42 typename std::enable_if_t<
43 Morpheus::is_dense_vector_format_container_v<KeyType> &&
44 Morpheus::is_dense_vector_format_container_v<SourceType> &&
45 Morpheus::is_dense_vector_format_container_v<DestinationType> &&
46 Morpheus::has_custom_backend_v<ExecSpace> &&
47 Morpheus::has_serial_execution_space_v<ExecSpace> &&
48 Morpheus::has_access_v<ExecSpace, KeyType, SourceType,
49 DestinationType>>* = nullptr) {
50 using size_type = typename KeyType::size_type;
51 MORPHEUS_ASSERT(keys.size() <= src.size(),
52 "Size of keys must be smaller or equal to src size.");
53 MORPHEUS_ASSERT(keys.size() <= dst.size(),
54 "Size of keys must be smaller or equal to dst size.");
55
56 for (size_type i = 0; i < keys.size(); i++) {
57 dst[i] = src[keys[i]];
58 }
59}
60
61} // namespace Impl
62} // namespace Morpheus
63
64#endif // MORPHEUS_ENABLE_SERIAL
65#endif // MORPHEUS_DENSEVECTOR_SERIAL_COPY_IMPL_HPP
Generic Morpheus interfaces.
Definition: dummy.cpp:24
constexpr bool has_access_v
Short-hand to has_access.
Definition: Morpheus_SpaceTraits.hpp:713