6
6
that is used in breaking the RSA cryptography protocol, by finding the
7
7
prime numbers that are used to create the public key value, n
8
8
9
- In this implementation, I have used a very simple construct without
9
+ In this implementation, I have used a very simple construct without
10
10
the use of qiskit or cirq to help understand how Shor algorithm's
11
11
idea actually works.
12
12
13
13
Website referred for shor algorithm:
14
14
https://www.geeksforgeeks.org/shors-factorization-algorithm/
15
15
"""
16
+
17
+
16
18
class Shor :
17
19
def period_find (self , num : int , number : int ) -> int :
18
20
"""
@@ -24,7 +26,7 @@ def period_find(self, num: int, number: int) -> int:
24
26
>>> shor.period_find(3, 7)
25
27
6
26
28
"""
27
- start :int = 1
29
+ start : int = 1
28
30
while pow (num , start , number ) != 1 :
29
31
start += 1
30
32
return start
@@ -40,28 +42,24 @@ def shor_algorithm(self, number:int) -> tuple[int, int]:
40
42
>>> factors
41
43
(3, 5)
42
44
"""
43
- if number % 2 == 0 :
44
- return 2 , number // 2
45
+ if number % 2 == 0 :
46
+ return 2 , number // 2
45
47
while True :
46
48
random .seed (0 )
47
- num :int = random .randint (2 , number - 1 )
48
- gcd_number_num :int = math .gcd (number , num )
49
+ num : int = random .randint (2 , number - 1 )
50
+ gcd_number_num : int = math .gcd (number , num )
49
51
if gcd_number_num > 1 :
50
- return gcd_number_num , number // gcd_number_num
51
-
52
- result :int = self .period_find (num , number )
53
- if not result % 2 :
54
- start :int = pow (num , result // 2 , number )
55
- if start != number - 1 :
56
- p_value :int = math .gcd (start - 1 , number )
57
- q_value :int = math .gcd (start + 1 , number )
52
+ return gcd_number_num , number // gcd_number_num
53
+
54
+ result : int = self .period_find (num , number )
55
+ if not result % 2 :
56
+ start : int = pow (num , result // 2 , number )
57
+ if start != number - 1 :
58
+ p_value : int = math .gcd (start - 1 , number )
59
+ q_value : int = math .gcd (start + 1 , number )
58
60
if p_value > 1 and q_value > 1 :
59
61
return p_value , q_value
60
-
62
+
61
63
62
64
shor = Shor ()
63
65
print (shor .shor_algorithm (15 ))
64
-
65
-
66
-
67
-
0 commit comments