pow(x, y, z) more efficient than x**y % z and other options
See Python: Tips and Tricks for similar articles.The Python documentation on pow()
states that pow(x,y,z)
is computed more efficiently than pow(x,y) % z
, and our tests show that to be the case.
Note that this is mostly academic as all the methods we tested for raising one number to the power of another and then doing a modulus operation are lightning fast.
You should probably use whichever method suits your coding style the most, but for those who are curious and thrive on speed, here’s how we tested it:
import time
import math
x = 4
y = 2
z = 3
repeat = 1000000
results = {}
# operator
start_time = time.time()
for i in range(repeat):
result = x**y % z
i+=1
results["x**y % z"] = time.time()-start_time
# pow() Function
start_time = time.time()
for i in range(repeat):
result = pow(x, y, z)
i+=1
results["pow(x, y, z)"] = time.time()-start_time
# pow() with % operator Function
start_time = time.time()
for i in range(repeat):
result = pow(x, y) % z
i+=1
results["pow(x, y) % z"] = time.time()-start_time
# math.pow() Function
start_time = time.time()
for i in range(repeat):
result = math.pow(x, y) % z
i+=1
results["math.pow(x, y) % z"] = time.time()-start_time
# output results
results_list = sorted(results.items(), key = lambda t:t[1])
for i in range(0, len(results_list)):
print(results_list[i][0], ':', results_list[i][1])
And here are the results:
math.pow(x, y) % z : 0.2949240207672119
x**y % z : 0.41014599800109863
pow(x, y) % z : 0.4418478012084961
pow(x, y, z) : 0.824713945388794
Related Articles
- Fixing WebVTT Times with Python
- Using Python to Convert Images to WEBP
- Scientific Notation in Python
- Understanding Python’s __main__ variable
- Converting Leading Tabs to Spaces with Python
- pow(x, y, z) more efficient than x**y % z and other options (this article)
- A Python Model for Ping Pong Matches
- Bulk Convert Python files to IPython Notebook Files (py to ipynb conversion)
- Python’s date.strftime() slower than str(), split, unpack, and concatenate?
- Basic Python Programming Exercise: A Penny Doubled Every Day
- Bi-directional Dictionary in Python
- How to find all your Python installations on Windows (and Mac)
- Associate Python Files with IDLE
- Change Default autosave Interval in JupyterLab
- Python: isdigit() vs. isdecimal()
- Python Clocks Explained
- Python Color Constants Module
- Maximum recursion depth exceeded while calling a Python object
- When to use Static Methods in Python? Never
- Finally, a use case for finally – Python Exception Handling
- Creating an Email Decorator with Python and AWS
- Python Coding Challenge: Two People with the Same Birthday
- How to Create a Simple Simulation in Python – Numeric Data
- Collatz Conjecture in Python
- Simple Python Script for Extracting Text from an SRT File
- Python Virtual Environments with venv
- Mapping python to Python 3 on Your Mac
- How to Make IDLE the Default Editor for Python Files on Windows
- How to Do Ternary Operator Assignment in Python
- How to Convert Seconds to Years with Python
- How to Create a Python Package
- How to Read a File with Python
- How to Check the Operating System with Python
- How to Use enumerate() to Print a Numbered List in Python
- How to Repeatedly Append to a String in Python
- Checking your Sitemap for Broken Links with Python
- How to do Simultaneous Assignment in Python
- Visual Studio Code - Opening Files with Python open()
- How to Slice Strings in Python
- How Python Finds Imported Modules
- How to Merge Dictionaries in Python
- How to Index Strings in Python
- How to Create a Tuple in Python