blob: 8bdfa5bcacaac69c15a2706cf4fa0b8a5f097023 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
package main
import (
"aphopkins/radix_info/factors"
"fmt"
"math"
"os"
"slices"
"strconv"
)
func main() {
if len(os.Args) > 1 {
if n, err := strconv.ParseUint(os.Args[1], 0, 0); err == nil {
if n > 1 {
n := uint(n)
fmt.Println(n, "=", factors.PrimeFactorize(n))
n_factors := factors.Factors(n)
slices.Sort(n_factors)
factorScore := factors.Score(n)
fmt.Printf("Factors: %v (Score: %.2f)\n", n_factors, factorScore)
fmt.Printf("Totative Ratio: %03.1f%%\n",
factors.TotativeRatio(n)*100.0)
fmt.Println("2345 Rank:", factors.BasicRank(n))
fmt.Println("Multiplication Table Complexity:", factors.MTC(n))
fmt.Printf("Natural Logarithm: %.2f\n", math.Log(float64(n)))
} else {
fmt.Println("Argument must be an integer above 1.")
}
} else {
fmt.Printf("Argument must be an integer above 1 [%v].\n", err)
}
} else {
fmt.Println("Please provide an argument (radix to study).")
}
}
|