gpt4 book ai didi

python - 二进制补码函数输出 -1 的错误结果

转载 作者:太空宇宙 更新时间:2023-11-04 00:13:30 25 4
gpt4 key购买 nike

我正在为 FPGA 程序生成输入以使用梯形积分方法。基本上,这里感兴趣的功能是 invert()twos_comp()功能;其余的只是测试(创建方波信号,然后迭代并将其转换为二进制补码)。

signals = []
bit_signals = []

def invert(bit_val):
new_val = []
for i in bit_val:
new_val.append(str(int(not(int(i)))))
return ''.join(new_val)

def twos_comp(val):
if val < 0:
bin_val = format(val, '08b')[1:]
return format(int(invert(bin_val),2) + int('1', 2), '08b')
else:
bin_val = format(val, '08b')[1:]
return bin_val

x = 0
signal = 1
while x <= 25:
if x % 2 == 0:
signal*=-1
signals.append(signal)
x+=1

print(signals)

for i in signals:
bit_signals.append(twos_comp(i))

print(bit_signals)

这里的问题是,这会将 1 的二进制补码输出为 01111111,而不是 1111111。invert() 的输出似乎是正确的,twos_comp() 的输出对于正数似乎是正确的,信号的生成似乎也是正确的,所以我认为它一定是有线的东西

return format(int(invert(bin_val),2) + int('1', 2), '08b')

但环顾 SO 和谷歌,这是其他人处理二进制添加的方式。

请注意 twos_comp() 的所有输入将是 8 位。关于为什么这不起作用的任何帮助将不胜感激。没有完全错误,只是输出不正确。

您可以运行代码 here .

最佳答案

val-1 时遍历值:

>>> format(-1, '08b')
'-0000001'

您可能已经发现了错误——08b 表示 8 个字符宽,而不是 8 个数字。对于负数,- 占用 1 个字符,因此您只能得到 8 位数字。但如果问题的原因不明显,让我们继续:

>>> format(val, '08b')[1:]
'0000001'
>>> invert('0000001')
'1111110'
>>> int(invert('0000001'), 2)
126
>>> int('1', 2) # BTW, why do you need this instead of just 1, exactly?
1
>>> 126 + 1
127
>>> format(127, '08b')
01111111

如果您想要一个 hacky 解决方案(我怀疑您这样做,因为您已经到处在字符串和数字之间来回切换),只需这样做:

bin_val = format(val, '09b')[-8:]

这对正数和负数都适用。

关于python - 二进制补码函数输出 -1 的错误结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51717210/

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