Generate Prime Factorization for Numbers in a Range
primeFactorizeSieve.RdGenerates the prime factorization of all numbers between bound1 and bound2 (if supplied) or all numbers up to bound1.
Details
This function is useful when many prime factorizations are needed. Instead of generating the prime factorization on the fly, one can reference the indices/names of the generated list.
This algorithm benefits greatly from the fast integer division library 'libdivide'. The following is from https://libdivide.com/:
“libdivide allows you to replace expensive integer divides with comparatively cheap multiplication and bitshifts. Compilers usually do this, but only when the divisor is known at compile time. libdivide allows you to take advantage of it at runtime. The result is that integer division can become faster - a lot faster.”
Value
Returns a named/unnamed list of integer vectors if max(bound1, bound2) \(< 2^{31}\), or a list of numeric vectors otherwise.
Examples
## Generate some random data
set.seed(28)
mySamp <- sample(10^5, 5*10^4)
## Generate prime factorizations up
## to 10^5 (max element from mySamp)
system.time(allPFacs <- primeFactorizeSieve(10^5))
#> user system elapsed
#> 0.016 0.004 0.021
## Use generated prime factorization for further
## analysis by accessing the index of allPFacs
for (s in mySamp) {
pFac <- allPFacs[[s]]
## Continue algorithm
}
## Generating prime factorizations over
## a range is efficient as well
system.time(primeFactorizeSieve(10^12, 10^12 + 10^5))
#> user system elapsed
#> 0.021 0.004 0.024
## Set 'namedList' to TRUE to return a named list
primeFactorizeSieve(27, 30, namedList = TRUE)
#> $`27`
#> [1] 3 3 3
#>
#> $`28`
#> [1] 2 2 7
#>
#> $`29`
#> [1] 29
#>
#> $`30`
#> [1] 2 3 5
#>
## Using nThreads
system.time(primeFactorizeSieve(1e4, 5e4, nThreads = 2))
#> user system elapsed
#> 0.006 0.002 0.007