-
Notifications
You must be signed in to change notification settings - Fork 70
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Canonical way of handling read-only data in interfaces taking mdspans #331
Comments
After further consideration my |
This is what I came up with: template <class Accessor>
class ConstAccessorAdaptor {
public:
using element_type = std::add_const_t<typename Accessor::element_type>;
using reference = std::add_const_t<typename Accessor::reference>;
using data_handle_type = typename Accessor::data_handle_type;
using offset_policy = ConstAccessorAdaptor;
ConstAccessorAdaptor(Accessor const& to_be_wrapped) : wrapped_{to_be_wrapped} {}
constexpr reference access(data_handle_type p, std::size_t i) const {
return wrapped_.access(p, i);
}
constexpr data_handle_type offset(data_handle_type p,
std::size_t i) const {
return wrapped_.offset(p, i);
}
private:
Accessor wrapped_{};
};
template <typename ElementT, class Extents, class Layout, class Accessor>
constexpr auto read_only_cast(cuda::std::mdspan<ElementT, Extents, Layout, Accessor> other) {
using CElementT = std::add_const_t<ElementT>;
return cuda::std::mdspan<CElementT, Extents, Layout, ConstAccessorAdaptor<Accessor>>{other};
} |
Hi! We've discussed this before, but just haven't had a chance to document it in a nice way. The issue is that accessors in general don't promise that a "const version of the accessor" even exists. This doesn't necessarily even make sense for some custom accessors. Your solution If I were implementing this, I would do something like this. template<class Accessor>
as_const(const Accessor& acc) {
return const_accessor_adapter<Accessor>(acc);
}
// Specialize for default_accessor
template<class ElementType>
as_const(const default_accessor<ElementType>& acc) {
return default_accessor<std::add_const_t<ElementType>>{};
}
template<class ElementType, class Extents, class Layout, class Accessor>
constexpr auto as_const(mdspan<ElementType, Extents, Layout, Accessor> x) {
auto const_acc = as_const(x.accessor());
using const_data_handle_type = typename decltype(const_acc)::data_handle_type;
return mdspan{const_data_handle_type{x.data_handle()}, x.mapping(), const_acc}; // use CTAD
} |
Yeah, I somewhat assumed that reference wrappers would support reference semantics (including contents not being modifiable when the wrapper is |
@pauleonix We've been asked the question "How do I make a view-of-const mdspan from a general mdspan?" enough times that we really should write a C++ Standard Library proposal to do it. Would you be interested in contributing? |
@mhoemmen I would lie if I said that I wasn't interested, but I certainly don't have the headspace right now to work myself into the proposal process from zero. But if someone would write a draft I would be happy to (proof-) read, discuss and give feedback or however else I can contribute on refining it while hopefully learning more about the process (and mdspan) for future opportunities. |
Well this issue just popped up in Kokkos, I made a rather kludgy fix: https://github.com/kokkos/kokkos/pull/7053/files#diff-fdbb0c6e835c8457ab0f560f668ba721fb72de7f4f68fc9ec565c3b729608040 . Just thought I might add to more uses cases. I'd be up for helping with a paper on this. I'm busy with personal matters this month but I could work on one for Wroclaw |
@nmm0 Thanks for posting! Accessors in general don't promise to have any template parameters. Even if they have a template parameter, they don't promise that it is the element type. Even if they do have a template parameter that is the element type, then they don't promise that For example, |
Yeah this was a bit of a hack since we are only expected some specific accessors in our tests. I think specialization might be the best thing here because it can also give meaningful errors for accessors that may not work with const types. |
I have not found any information on this topic. The
dot_product
example just doesn't take care ofconst
-correctness at all. Withspan
one can just havespan<T const>
and an implicit cast happens when passing aspan<T>
. Withmdspan
things are less straightforward when one wants to stay generic with respect to theAccessorPolicy
, i.e.doesn't compile as the compiler can't both deduce
L
andA
and cast from an element type offloat
to an element type offloat const
. The best solution I could come up with is some kind of explicit cast likewhich then allows
This naive implementation is probably flawed in its assumption that every
Accessor
has a single template argument (can be fixed by adding a variadic overload ofread_only_cast
) and generally I would not expect that the implementation of this kind of facility is left to the user. Is there a simpler way that avoids the need to explicitly specify any template parameters tobar()
? I thinkmdspan/examples/dot_product/dot_product.cpp
Lines 48 to 56 in a9c54cc
mdspan
s.The text was updated successfully, but these errors were encountered: