This online calculator computes prime factorization of a positive integer and checks if a number is prime. This web-app was written using React.js library and performs calculations locally using JavaScript language.
The calculator provides a customizable config and advanced features, you can:
-
Switch view (from standard to advanced). Standard view exponentiates common factors, advanced view shows all calculation in detail.
-
Use different algorithms: default value is automatic, meaning the calculator will pick the most optimized and suitable algorithm for your number.
-
Display the number in scientific notation in this form:
a ×10
x
, wherea
is a +float number andx
is a +integer (default is off). -
Use previous results (default is on). The calculator memorizes all calculations performed on your device and stores them in localStorage. By disabling this, the calculator will ignore previous results.
-
Perform a benchmarking test. This will compute a calculation on your device and will measure time performance. Please note that results may vary depending on your browser, for this matter we recommend using Chrome (or any browser using V8 JavaScript engine). The test generally lasts ten seconds, however, might be slower or faster depending on your hardware capabilities.
-
Download your factorization history and your configuration on your device. This will retrive all data in localStorage and save it as a json file.
Despite being exclusively written with JavaScript, which is an interpreted language (thus being slower than compiled languages), the calculator can compute prime factorization very fast. The web app works with BigInt
data type instead of numbers to avoid precision loss beyond 253 - 1 (MAX_SAFE_INTEGER
). To avoid web page to freeze when doing expensive computations, a web worker is used. The web worker sends the results to the main thread. Also, generators are used in order to stream live results. Here is a list of the algorithms used.
This is the simplest algorithm used in factorization. It was firstly described by Fibonacci in 1202. Despite being slow, it works perfectly for small numbers. For more information check here. An improved version is also available which is 2 times more efficient.
The following npm package is used, quadraticsievefactorization
If you want to support this project, please contribute! You can add your factorization algorithms and see how fast they are!