C是否具有量化功能?

C是否具有量化功能?,第1张

概述我有一个缓冲区,有许多正16位值(存储为双精度数),我想将其量化为8位(0-255个值). 根据Wikipedia,过程将是: >标准化16位值.即找到最大的并与此分开. >使用Q(x)公式,M = 8. 所以我想知道,如果C有一个可以进行量化的函数,或者有人知道我可以使用的C实现吗? 满满的爱, 路易丝 假设值d在区间[0.0,max]中: unsigned char quantize(doub 我有一个缓冲区,有许多正16位值(存储为双精度数),我想将其量化为8位(0-255个值).

根据Wikipedia,过程将是:

>标准化16位值.即找到最大的并与此分开.
>使用Q(x)公式,M = 8.

所以我想知道,如果C有一个可以进行量化的函数,或者有人知道我可以使用的C实现吗?

满满的爱,
路易丝

解决方法 假设值d在区间[0.0,max]中:

unsigned char quantize(double d,double max){    return (unsigned char)((d / max) * 255.0);}

我不确定你的意思是“16位值;”在使用IEEE-754的任何系统上,双精度值均为64位.但是,如果您具有其他数字类型的值,则该过程实际上是相同的.

总结

以上是内存溢出为你收集整理的C是否具有量化功能?全部内容,希望文章能够帮你解决C是否具有量化功能?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1212696.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存