SVE Instruction List by Dougall Johnson
UCLAMP: Unsigned clamp to minimum/maximum vector
UCLAMP Zd.S, Zn.S, Zm.S (SVE2.1 (SME
128-bit SVE
data:image/s3,"s3://crabby-images/2911e/2911e1bc362944dde11eb19a62f994102e0f149b" alt=""
For each unsigned 32-bit integer, clamp (1) to be between the lower-bound (2), and the upper-bound (3), and write the result to (4).
(4) = min( max( (2), (1) ), (3) )
256-bit SVE
data:image/s3,"s3://crabby-images/ef928/ef9286c7fc8d44760070a3aa7f9cbead084b9999" alt=""
For each unsigned 32-bit integer, clamp (1) to be between the lower-bound (2), and the upper-bound (3), and write the result to (4).
(4) = min( max( (2), (1) ), (3) )
512-bit SVE
data:image/s3,"s3://crabby-images/0bfeb/0bfebc1b18795921db38383fb4ae73596e83960c" alt=""
For each unsigned 32-bit integer, clamp (1) to be between the lower-bound (2), and the upper-bound (3), and write the result to (4).
(4) = min( max( (2), (1) ), (3) )
Larger sizes
1024-bit SVE
data:image/s3,"s3://crabby-images/fd466/fd466255ca75a0cff242a9b9b5ad476effda616f" alt=""
For each unsigned 32-bit integer, clamp (1) to be between the lower-bound (2), and the upper-bound (3), and write the result to (4).
(4) = min( max( (2), (1) ), (3) )
2048-bit SVE
data:image/s3,"s3://crabby-images/d41a9/d41a9127d77a4bb92b94a8285853c5136349baa5" alt=""
For each unsigned 32-bit integer, clamp (1) to be between the lower-bound (2), and the upper-bound (3), and write the result to (4).
(4) = min( max( (2), (1) ), (3) )
Report mistakes or give feedback
Inspired by and based on the x86/x64 SIMD Instruction List by Daytime.