SVE Instruction List by Dougall Johnson
FCLAMP: Floating-point clamp to minimum/maximum number
FCLAMP Zd.D, Zn.D, Zm.D (SVE2.1 (SME2
128-bit SVE
data:image/s3,"s3://crabby-images/a07f6/a07f69d380374fc1d3363afb9db80b81fc5e907e" alt=""
For each 64-bit float, 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/3b68e/3b68e5c46d250087a8a992116365241963d97a9a" alt=""
For each 64-bit float, 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/bd0c6/bd0c63b4f12dc4f5057441003c082cd0943cc69d" alt=""
For each 64-bit float, 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/8bebb/8bebb37438c533be7adadc859a0bfca937a25920" alt=""
For each 64-bit float, 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/57325/573256420c82b562f5d59ac10328a337621581e3" alt=""
For each 64-bit float, 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.