Parsing Large Numbers Question
Hi All, I am writing some simple code to raise a base value to a power
then perform some operations on the output. I have included the code I am
using now, below ( see end of this message ), also see immediately below
what this looks like when I run my script from the console ;
INPUT Value: 431.1
INPUT Power Value; 1.9907
What I need to be able to do ;
1.) Store whole number value to left of the decimal point without decimals to
a variable = x
2.) Grab entire decimal value to the right of the decimal point and store in a variable
Parse (y) according to some simple rules. Here's where it gets trick for me.
What I want to do is examine (y) to see if there are any leading leading and trailing zeros
In the example ; "1739.554505....." IF this value was instead, something like any of the following ;
Then I want to extract the whole number less any continuous leading zeroes
NEXT, I want to cut the number so that when there are four continuous trailing zeros, all zeros
starting from the first one that started off the first four continuous zeros and all following zeroes are
So in our example ;
(y) becomes "55450564142665825784206390380859375"
Next I want to take the mod of above value by %1999
This returns "1407"
Next I want to join this value AS the decimal value to the right as ;
Ok, so now why am I stuck at this point?
I'm still fairly new to learning Python so I don't actually kknow what the best ways are to do this.
I'm thinking I could maybe just do a trim on the value to the right of the decimal, take that, convert the whole thing to a string, then chop up each digit and store each individually to an array then code a rule set for stepping through strings in array cells, but this also seems like it could take more CPU time than I'd like. I'm hoping to perform this sort of operation fast, as fast as possible.
Also, I do not even know how to best approach this even if I had to store this as a string into an array, and if I munderstand correctly string processing tends to takes more CPU time than number calcs.
Any insight, direction, code suggestions greatly appreciated!
This is the code I am currently using ;
import time e0=time.time() c0=time.clock() import sys import math from sympy import mpmath from mpmath import * mpmath.mp.dps = 10000 inputx = float(input('Enter inputx Value: ')) powerx =float(input('Enter Power Value; ')) inputx_squared = float((mpmath.power(inputx, powerx)))%1999 print('\r') print('RESULT ', '%.60f' % inputx_squared) elapsed_time=time.time() -e0 cpu_time=time.clock() -c0 print('\r') print("CPU TIME ;", cpu_time)