Message 173261 - Python tracker

Message173261

Author mark.dickinson
Recipients alexhsamuel, antocuni, benjamin.peterson, mark.dickinson, meador.inge, nascheme, r.david.murray
Date 2012-10-18.12:18:24
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1350562704.79.0.89580594441.issue9011@psf.upfronthosting.co.za>
In-reply-to
Content
With the string, the minus sign applies only to the imaginary part;  with the expression '-1j', it applies to the whole complex number (both real and imaginary parts).

I don't see any sensible way to 'fix' the string to complex conversion; indeed, I think any change would make it worse than before.  It's a known issue with complex arithmetic that x + 1j*y doesn't give you complex(x, y);  the conversions from string and the complex(x, y) form are there to make it possible to carefully create a complex number with known real and imaginary parts.


> For example, in pypy we use the same code for parsing literals and
> converting strings, so you get -0.0 in both cases.

But -1j isn't a literal.  It's unary minus applied to a the complex number given by the literal '1j'.  Python's code *does* give the same results both for converting strings and parsing literals.
History
Date User Action Args
2012-10-18 12:18:24mark.dickinsonsetrecipients: + mark.dickinson, nascheme, benjamin.peterson, alexhsamuel, r.david.murray, meador.inge, antocuni
2012-10-18 12:18:24mark.dickinsonsetmessageid: <1350562704.79.0.89580594441.issue9011@psf.upfronthosting.co.za>
2012-10-18 12:18:24mark.dickinsonlinkissue9011 messages
2012-10-18 12:18:24mark.dickinsoncreate