-
Notifications
You must be signed in to change notification settings - Fork 757
reduce_by_key (CUDA) should not assume its output iterator is default constructible #1812
Comments
I wonder if one sneaky but convenient solution to this would be to use a
This would obviate the need to default construct an instance of the output iterators and doesn't require any changes to the dispatch macro as the Then we can extract the value before returning. |
I was thinking of trying a new dispatch macro and use it at first only in this API. If it works, it can be gradually adopted elsewhere... I still hate the "num_items_fixed" hack... |
@senior-zero Perhaps you didn't see this issue when I filed it, but I think this should now be closed along with #1826? Please also look at NVIDIA/cccl#821. |
Hello, @harrism! I've missed this issue indeed. I don't think it should be closed, though. I'd be glad to have an index dispatch version that returns a value. I think this would simplify the code and make future issues less probable. |
closed by #1827 We can open a new issue later as necessary when we update the dispatch mechanism across all algorithms. |
As discussed in #1804,
thrust::reduce_by_key
's CUDA implementation assumes that the output iterator it is passed can be default constructed.thrust/thrust/system/cuda/detail/reduce_by_key.h
Line 1087 in d3e6fa1
This is made necessary by the implementation of the dispatch macro:
thrust/thrust/system/cuda/detail/dispatch.h
Lines 29 to 37 in d3e6fa1
The dispatch mechanism should be modified so that it's return value can be used to initialize a local so that a temporary does not need to be default constructed in order to use it.
The text was updated successfully, but these errors were encountered: