我想知道Python(3.3.0)打印复数的方式。我在找一个解释,而不是改变印刷品的方法。
示例:
>>> complex(1,1)-complex(1,1)
0j
为什么不直接打印“0”?我的猜测是:保持类型复杂的输出。
下一个示例:
>>> complex(0,1)*-1
(-0-1j)
好吧,一个简单的“-1j”或“(-1j)”就可以了。为什么是“-0”??这和+0不一样吗?这似乎不是一个取整问题:
>>> (complex(0,1)*-1).real == 0.0
True
当虚部为正时,-0消失:
>>> complex(0,1)
1j
>>> complex(0,1)*-1
(-0-1j)
>>> complex(0,1)*-1*-1
1j
又一个例子:
>>> complex(0,1)*complex(0,1)*-1
(1-0j)
>>> complex(0,1)*complex(0,1)*-1*-1
(-1+0j)
>>> (complex(0,1)*complex(0,1)*-1).imag
-0.0
我是不是丢了什么东西?
它打印
0j
以指示它仍然是一个complex
值。你也可以这样打回去:其余的可能是IEEE 754 floating point representation魔法的结果,它区分了0和-0,即所谓的signed zero。基本上,有一个位表示这个数字是正是负,而不管这个数字恰好是零。这解释了为什么
1j * -1
给出了一个负零实部:正零乘以-1。标准要求-0与+0进行比较,这解释了为什么
(1j * -1).real == 0.0
仍然有效。Python仍然决定打印-0的原因是,在复杂的世界中,这些操作会对分支切割产生影响,例如在the ^{} function :
这是关于想象的部分,不是真实的部分,但是很容易想象真实部分的符号会产生类似的差异的情况。
0j
是一个imaginary literal,它确实表示复数,而不是整数或浮点数。+-0
(“有符号零”)是Python在Python中自^{complex
打印或指定零分数部分。-0
部分是printed以便准确地表示内容as ^{repr()
在操作结果输出到控制台时被隐式调用)。关于为什么
(-0+1j) = 1j
但是(1j*-1) = (-0+1j)
的问题。 注意(-0+0j)
或(-0.0+0j)
不是单个复数,而是添加到complex
的表达式。要计算结果,首先将第一个数字转换为complex
(-0
->;(0.0,0.0)
,因为整数没有有符号零,-0.0
->;(-0.0,0.0)
)。然后将其.real
和.imag
添加到1j
的相应的(+0.0,1.0)
中。结果是(+0.0,1.0)
:^)。若要直接构造复数,请使用complex(-0.0,1)
。答案在于Python源代码本身。
我来举你的一个例子。让
当您完成
a*b
时,您将调用this function:如果在python解释器中这样做,您将得到
从IEEE754,你得到了一个negative zero,从that's not +0,你得到了打印时的parens和真实部分。
我想(但我不确定)这个基本原理来自于用基本复杂函数计算时这个符号的重要性(在维基百科关于符号0的文章中有这样的参考)。
相关问题 更多 >
编程相关推荐