gpt4 book ai didi

c++ - SSE指令中的UnsignedSaturate是什么意思?

转载 作者:可可西里 更新时间:2023-11-01 18:09:18 31 4
gpt4 key购买 nike

我正在将 SIMD 代码转换为等效的 C 代码。我被困在 SSE 指令之一

__m128i _mm_packus_epi16 (__m128i a, __m128i b)

返回

r0 := UnsignedSaturate(a0)
r1 := UnsignedSaturate(a1)

...
r7 := UnsignedSaturate(a7)
r8 := UnsignedSaturate(b0)
r9 := UnsignedSaturate(b1)
...
r15 := UnsignedSaturate(b7)

UnsignedSaturate 是什么意思?

最佳答案

基本上,“饱和度”意味着超过某个“最大”值的值被设置为“最大”,低于“最小”值的值被设置为“最小”。通常,“min”和“max”是适用于某些数据类型的值。

因此,例如,如果您对无符号字节进行算术运算,则“128+128”必须是“256”(十六进制 0x100),这不适合一个字节。正常的整数运算会产生溢出并丢弃不适合的部分,这意味着“128+128 -> 0”。使用饱和算法,“256 > 255”所以结果是 255。

另一个选项是缩放,它基本上将值“压缩”到较小的范围。饱和度只是将它们切断。

您还可以使用它来将较大的类型放入较小的类型,例如将 16 位值放入 8 位值。您的示例很可能正是这样做的,尽管您可能比我更了解您在那里处理的是哪种类型。

“UnsignedSaturation”很可能有一个“0”的最小值和一个“最大值”,无论结果类型的最大值是多少。因此,负输入变为“0”。

关于c++ - SSE指令中的UnsignedSaturate是什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12141075/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com