diff options
| author | Adrien Hopkins <adrien.p.hopkins@gmail.com> | 2023-09-04 15:29:22 -0500 |
|---|---|---|
| committer | Adrien Hopkins <adrien.p.hopkins@gmail.com> | 2023-09-04 18:03:36 -0500 |
| commit | 0e58327b195fa4926ba6977f48c7f535ed17d933 (patch) | |
| tree | dcc4b19f985f5acf54713c71a401091712efe7bf /factors/totative.go | |
| parent | c9a0a5fd748778cb068f88c4bd29147e5b8f28e9 (diff) | |
Add totative digit count to non-compact output
This is done for a few reasons:
- Allow the user to easily determine the exact value of the totative
ratio
- This information is important when the digit map isn't accessible (for
radices >36)
- More consistency with factors
I don't show the exact values of totatives like I do with factors
because they're far more common - the superior highly composite (i.e.
one of the numbers with the highest factor count) number 720720 has
240 factors and 138240 totatives, for example.
Diffstat (limited to 'factors/totative.go')
| -rw-r--r-- | factors/totative.go | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/factors/totative.go b/factors/totative.go index 3a1f635..7a4bebe 100644 --- a/factors/totative.go +++ b/factors/totative.go @@ -1,12 +1,22 @@ package factors -// TotativeRatio calculates the fraction of numbers less than n that +// TotativeRatio calculates the fraction of numbers that // are totatives of n (share no factors with n) func TotativeRatio(n uint) float64 { if n == 0 { panic("0 has no totative ratio!") } + return float64(TotativeCount(n)) / float64(n) +} + +// TotativeCount calculates the number of numbers less than n that +// are totatives of n (share no factors with n) +func TotativeCount(n uint) uint { + if n == 0 { + return 0 + } + primeFactorization := PrimeFactorize(n) num, denom := uint(1), uint(1) @@ -14,5 +24,6 @@ func TotativeRatio(n uint) float64 { num *= p - 1 denom *= p } - return float64(num) / float64(denom) + + return num * (n / denom) } |
