首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在MATLAB中将数值转换为N位分辨率?

如何在MATLAB中将数值转换为N位分辨率?
EN

Stack Overflow用户
提问于 2019-12-07 12:29:32
回答 2查看 86关注 0票数 0

我的电脑默认使用32位分辨率。我正在写一个脚本,它涉及到使用具有N位分辨率的万用表进行测量。如何将值转换为该值?

例如,如果我有一个提供1000个值的RNG

代码语言:javascript
运行
复制
nums = randn(1,1000);

我使用N位万用表读取这些值,如何获得反映这些值的值?

我目前有

代码语言:javascript
运行
复制
meas = round(nums,N-1);

但它给了我N位,而不是N位。最初的随机数是无界的,但万用表的分辨率是限制的;如何实现限制是我正在寻找的。

编辑I:我说的是测量的分辨率,而不是数字的界限。原始值是无界的。测量值的精度应受到分辨率的限制。

编辑II:我修改了问题,以使问题更清晰。

EN

回答 2

Stack Overflow用户

发布于 2019-12-07 16:01:03

randn不会产生有界数。假设您生成的是32位整数:

代码语言:javascript
运行
复制
mums = randi([0,2^32-1],1,n);

要丢弃底部的32-N位,只需除以适当的值并四舍五入(或取下底数):

代码语言:javascript
运行
复制
nums = round(nums/(2^(32-N)));

请注意,我们在这里只使用浮点运算,数字是整数值,而不是实际的整数。如果需要,您可以使用实际的整数执行类似的操作。

而且,很明显,N应该小于32。你不能发明新的比特。如果N大于N,则上面的代码将在数字的底部添加零位。

票数 1
EN

Stack Overflow用户

发布于 2019-12-07 15:57:18

使用万用表时,范围可能类似于-M V到M V,分辨率恒定,您可以配置M来选择范围。

这是定点数学。我的答案是不会使用它,因为我没有可用的工具箱,如果你有它,你可以用它来编写更简单的代码。

您可以生成具有预期分辨率的整数值,然后将其重新缩放到预期范围。

代码语言:javascript
运行
复制
F=2^N-1 %Maximum integer value
X=randi([0,F],100,1)
X*2*M/F-M %Rescale, divide by the integer range, multiply by the intended range. Then offset by intended minimum.
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59222998

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档