-
Notifications
You must be signed in to change notification settings - Fork 13.7k
Open
Labels
C-tracking-issueCategory: An issue tracking the progress of sth. like the implementation of an RFCCategory: An issue tracking the progress of sth. like the implementation of an RFCS-tracking-unimplementedStatus: The feature has not been implemented.Status: The feature has not been implemented.T-libs-apiRelevant to the library API team, which will review and decide on the PR/issue.Relevant to the library API team, which will review and decide on the PR/issue.
Description
Feature gate: #![feature(funnel_shifts)]
This is a tracking issue for implementation of funnel shifts on integers.
Funnel shifts are essentially a generalization of bitwise rotations. a.funnel_shl(b, n)
means concatenate a
and b
(with a
in the most significant half), creating an integer twice as wide, shifting this to the left by n
(taken modulo the bit size of a
and b
), shifting in zeros, and finally extract the most significant half of the wide integer as the result.
a.funnel_shl(a, n)
is meant to be exactly equivalent to a.rotate_left(n)
.
Public API
funnel_shl
andfunnel_shr
on the primitive integer typesu8
,u16
,u32
,u64
andu128
Steps / History
A SIMD version of these intrinsics were added in #142078
- Implementation
- Final comment period (FCP)1
- Stabilization PR
Unresolved Questions
- Should we also provide these functions on signed integer types (akin to
rotate
s`?
Footnotes
Metadata
Metadata
Assignees
Labels
C-tracking-issueCategory: An issue tracking the progress of sth. like the implementation of an RFCCategory: An issue tracking the progress of sth. like the implementation of an RFCS-tracking-unimplementedStatus: The feature has not been implemented.Status: The feature has not been implemented.T-libs-apiRelevant to the library API team, which will review and decide on the PR/issue.Relevant to the library API team, which will review and decide on the PR/issue.