28 lines
714 B
JavaScript
28 lines
714 B
JavaScript
|
const isPrime = (n) =>
|
||
|
!Array(Math.ceil(Math.sqrt(n)))
|
||
|
.fill(0)
|
||
|
.map((_, i) => i + 2) // first prime is 2
|
||
|
.some((i) => n !== i && n % i === 0);
|
||
|
|
||
|
const primesCache = [2];
|
||
|
const p = (i) => {
|
||
|
if (primesCache.length <= i) {
|
||
|
let x = primesCache.at(-1);
|
||
|
while (primesCache.length <= i) {
|
||
|
if (isPrime(++x)) primesCache.push(x);
|
||
|
}
|
||
|
}
|
||
|
return primesCache.at(i - 1);
|
||
|
};
|
||
|
|
||
|
const computeGodelNumber = (godelSequence) =>
|
||
|
godelSequence.reduce((acc, num, i) => {
|
||
|
const prime = p(i + 1);
|
||
|
return BigInt(acc) * BigInt(prime) ** BigInt(num);
|
||
|
}, 1) - BigInt(1);
|
||
|
|
||
|
self.addEventListener("message", (e) => {
|
||
|
const godelNumber = computeGodelNumber(e.data);
|
||
|
postMessage(godelNumber);
|
||
|
});
|