On 21 February 2013 22:39, Schizoid Man <schiz_...@21stcentury.com> wrote: > "Dave Angel" <da...@davea.name> wrote in message >> >> On 02/21/2013 02:33 PM, Schizoid Man wrote: >> However, there is an important inaccuracy in math.pow, because it uses >> floats to do the work. If you have very large integers, that means some of >> them won't be correct. The following are some examples for 2.7.3 on Linux: >> >> a b math.pow(a,b) a**b >> 3 34 1.66771816997e+16 16677181699666569 >> 3 35 5.0031545099e+16 50031545098999707 >> ... >> 5 23 1.19209289551e+16 11920928955078125 >> >> The built-in pow, on the other hand, seems to get identical answers for >> all these cases. So use pow() instead of math.pow() > > I see. I thought using the ** was shorthand for math.pow() and didn't think > that one would be integer operations and the other floats.
Then you want operator.pow: >>> import operator >>> operator.pow(3, 2) 9 math.pow is basically the (double)pow(double, double) function from the underlying C library. operator.pow(a, b) is precisely the same as a**b. > I'm performing > some large integer arithmetic operations. I would normally do this my > writing my own multiplication class and storing results as strings, but a > friend suggested that I look at Python. There's no need to use strings if you're working with integers in Python. The results with int (not float) will be exact and will not overflow since Python's ints have unlimited range (unless your machine runs out of memory but that only happens with *really* big integers). If you want to do computations with non-integers and high precision, take a look at the decimal and fractions modules. http://docs.python.org/2/library/decimal.html http://docs.python.org/2/library/fractions.html There is also a good third party library, sympy, for more complicated exact algebra: http://sympy.org/en/index.html Oscar -- http://mail.python.org/mailman/listinfo/python-list