我的电脑默认使用32位分辨率。我正在写一个脚本,它涉及到使用具有N位分辨率的万用表进行测量。如何将值转换为该值?
例如,如果我有一个提供1000个值的RNG
nums = randn(1,1000);
我使用N位万用表读取这些值,如何获得反映这些值的值?
我目前有
meas = round(nums,N-1);
但它给了我N位,而不是N位。最初的随机数是无界的,但万用表的分辨率是限制的;如何实现限制是我正在寻找的。
编辑I:我说的是测量的分辨率,而不是数字的界限。原始值是无界的。测量值的精度应受到分辨率的限制。
编辑II:我修改了问题,以使问题更清晰。
发布于 2019-12-07 16:01:03
randn
不会产生有界数。假设您生成的是32位整数:
mums = randi([0,2^32-1],1,n);
要丢弃底部的32-N
位,只需除以适当的值并四舍五入(或取下底数):
nums = round(nums/(2^(32-N)));
请注意,我们在这里只使用浮点运算,数字是整数值,而不是实际的整数。如果需要,您可以使用实际的整数执行类似的操作。
而且,很明显,N应该小于32。你不能发明新的比特。如果N大于N,则上面的代码将在数字的底部添加零位。
发布于 2019-12-07 15:57:18
使用万用表时,范围可能类似于-M V到M V,分辨率恒定,您可以配置M来选择范围。
这是定点数学。我的答案是不会使用它,因为我没有可用的工具箱,如果你有它,你可以用它来编写更简单的代码。
您可以生成具有预期分辨率的整数值,然后将其重新缩放到预期范围。
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.
https://stackoverflow.com/questions/59222998
复制相似问题