Handled type hinds

This commit is contained in:
Joelkurien 2024-10-29 21:36:23 +11:00
commit ebf66fb78c
2 changed files with 18 additions and 19 deletions

View File

@ -1192,6 +1192,7 @@
## Quantum ## Quantum
* [Q Fourier Transform](quantum/q_fourier_transform.py) * [Q Fourier Transform](quantum/q_fourier_transform.py)
* [Shor Algorithm](quantum/shor_algorithm.py)
## Scheduling ## Scheduling
* [First Come First Served](scheduling/first_come_first_served.py) * [First Come First Served](scheduling/first_come_first_served.py)

View File

@ -6,13 +6,15 @@ Shor Algorithm is one of the basic quantum computing algorithm
that is used in breaking the RSA cryptography protocol, by finding the that is used in breaking the RSA cryptography protocol, by finding the
prime numbers that are used to create the public key value, n prime numbers that are used to create the public key value, n
In this implementation, I have used a very simple construct without In this implementation, I have used a very simple construct without
the use of qiskit or cirq to help understand how Shor algorithm's the use of qiskit or cirq to help understand how Shor algorithm's
idea actually works. idea actually works.
Website referred for shor algorithm: Website referred for shor algorithm:
https://www.geeksforgeeks.org/shors-factorization-algorithm/ https://www.geeksforgeeks.org/shors-factorization-algorithm/
""" """
class Shor: class Shor:
def period_find(self, num: int, number: int) -> int: def period_find(self, num: int, number: int) -> int:
""" """
@ -24,7 +26,7 @@ class Shor:
>>> shor.period_find(3, 7) >>> shor.period_find(3, 7)
6 6
""" """
start:int = 1 start: int = 1
while pow(num, start, number) != 1: while pow(num, start, number) != 1:
start += 1 start += 1
return start return start
@ -40,28 +42,24 @@ class Shor:
>>> factors >>> factors
(3, 5) (3, 5)
""" """
if number%2 == 0: if number % 2 == 0:
return 2, number//2 return 2, number // 2
while True: while True:
random.seed(0) random.seed(0)
num:int = random.randint(2, number-1) num: int = random.randint(2, number - 1)
gcd_number_num:int = math.gcd(number, num) gcd_number_num: int = math.gcd(number, num)
if gcd_number_num > 1: if gcd_number_num > 1:
return gcd_number_num, number//gcd_number_num return gcd_number_num, number // gcd_number_num
result:int = self.period_find(num, number) result: int = self.period_find(num, number)
if not result%2: if not result % 2:
start:int = pow(num, result//2, number) start: int = pow(num, result // 2, number)
if start != number-1: if start != number - 1:
p_value:int = math.gcd(start-1, number) p_value: int = math.gcd(start - 1, number)
q_value:int = math.gcd(start+1, number) q_value: int = math.gcd(start + 1, number)
if p_value > 1 and q_value > 1: if p_value > 1 and q_value > 1:
return p_value, q_value return p_value, q_value
shor = Shor() shor = Shor()
print(shor.shor_algorithm(15)) print(shor.shor_algorithm(15))