Created
May 3, 2023 02:06
-
-
Save chadbrewbaker/84f50f7eedeb2413e8a457dbfa06218f to your computer and use it in GitHub Desktop.
AKS Primality Test
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# ChatGPT4 spit it out with some coaxing - looks legit, haven't tested. | |
import math | |
def is_prime(n): | |
def is_power(a, b): | |
if a == 1: | |
return b != 1 | |
power = 1 | |
while power < b: | |
power *= a | |
return power == b | |
def find_r(n): | |
max_r = math.ceil(math.log2(n) ** 2) | |
for r in range(2, max_r + 1): | |
if not is_power(n, r): | |
return r | |
return -1 | |
def check_a(a, n, r): | |
for k in range(1, r + 1): | |
val = (pow(a, k, n) - k) % n | |
if val != 0: | |
return False | |
return True | |
# Check if n is a power of a smaller number | |
for a in range(2, n): | |
if is_power(a, n): | |
return False | |
# Find the smallest r such that ord_r(n) > log^2(n) | |
r = find_r(n) | |
# Check a-values from 1 to r | |
for a in range(1, r + 1): | |
if math.gcd(a, n) > 1: | |
return False | |
if not check_a(a, n, r): | |
return False | |
return True | |
n = 97 # Try with any number | |
print(f"{n} is prime: {is_prime(n)}") |
Bash version it gave
#!/bin/bash
is_power() {
local a="$1"
local b="$2"
if [ "$a" -eq 1 ]; then
[ "$b" -ne 1 ]
return
fi
local power=1
while [ "$power" -lt "$b" ]; do
power=$((power * a))
done
[ "$power" -eq "$b" ]
}
find_r() {
local n="$1"
local max_r=$(echo "l($n)^2" | bc -l | awk '{printf "%d\n", ($1 + 0.5)}')
for ((r = 2; r <= max_r; r++)); do
if ! is_power "$n" "$r"; then
echo "$r"
return
fi
done
echo 0
}
check_a() {
local a="$1"
local n="$2"
local r="$3"
for ((k = 1; k <= r; k++)); do
local val=$(echo "($a^$k) % $n" | bc)
val=$((val - k))
if [ "$val" -ne 0 ]; then
return 1
fi
done
return 0
}
is_prime() {
local n="$1"
for ((a = 2; a < n; a++)); do
if is_power "$a" "$n"; then
return 1
fi
done
local r=$(find_r "$n")
for ((a = 1; a <= r; a++)); do
if ! (echo "$a" "$n" | awk '{print $1 % $2}') > /dev/null; then
return 1
fi
if ! check_a "$a" "$n" "$r"; then
return 1
fi
done
return 0
}
n=97
if is_prime "$n"; then
echo "$n is prime"
else
echo "$n is not prime"
fi
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Rust version it gave