Title: | Hash R Objects to Integers Fast |
---|---|
Description: | Apply an adaptation of the SuperFastHash algorithm to any R object. Hash whole R objects or, for vectors or lists, hash R objects to obtain a set of hash values that is stored in a structure equivalent to the input. See <http://www.azillionmonkeys.com/qed/hash.html> for a description of the hash algorithm. |
Authors: | Mark van der Loo [aut, cre], Paul Hsieh [ctb] |
Maintainer: | Mark van der Loo <[email protected]> |
License: | GPL-3 |
Version: | 0.1.4 |
Built: | 2024-12-10 06:37:31 UTC |
Source: | CRAN |
This package exports Paul Hsies's SuperFastHash
C-code to R.
It can be used to hash either whole R objects or, for vectors or lists,
R objects can be hashed recursively so one obtains a set of hash values
that is stored in a structure equivalent to the input.
Hash R objects to 32bit integers
hash(x, ...) ## Default S3 method: hash(x, ...) ## S3 method for class 'character' hash( x, recursive = TRUE, what = c("string", "pointer"), nthread = getOption("hashr_num_thread"), ... ) ## S3 method for class 'list' hash(x, recursive = TRUE, nthread = getOption("hashr_num_thread"), ...)
hash(x, ...) ## Default S3 method: hash(x, ...) ## S3 method for class 'character' hash( x, recursive = TRUE, what = c("string", "pointer"), nthread = getOption("hashr_num_thread"), ... ) ## S3 method for class 'list' hash(x, recursive = TRUE, nthread = getOption("hashr_num_thread"), ...)
x |
Object to hash |
... |
Arguments to be passed to other methods. In particular, for the default method,
these arguments are passed to |
recursive |
hash each element separately? |
what |
Hash the string or the pointer to the string (faster, but not reproducible over R sessions) |
nthread |
maximum number of threads used. |
The default method serialize
s the input to a single
raw
vector which is then hashed to a single signed
integer. This is also true for character
vectors when
recursive=FALSE
. When recursive=TRUE
each element of a
character
vector is hashed separately, based on the underlying
char
representation in C
.
On systems supporting openMP, this function is able to use multiple cores. By default, a sensible number of cores is chosen. See the entry on OpenMP Support in the writing R extensions manual to check whether your system supports it.
The hash function used is Paul Hsieh's' SuperFastHash
function which is
described on his website.
As the title of the algorithm suggests, this hashing algorithm is not aimed to
be used as a secure hash, and it is probably a bad idea to use it for that purpose.
# hash some complicated R object (not a list). m <- lm(height ~ weight, data=women) hash(m) # hash a character vector element by element: x <- c("Call any vegetable" , "and the chances are good" , "that the vegetable will respond to you") hash(x) # hash a character vector as one object: hash(x, recursive=FALSE) # hash a list recursively L <- strsplit(x," ") hash(L) # recursive really means recursive, so nested lists are recursed over: L <- list( x = 10 , y = list( foo = "bob" , bar = lm(Sepal.Width ~ Sepal.Length, data=iris) ) ) hash(L) hash(L,recursive=FALSE)
# hash some complicated R object (not a list). m <- lm(height ~ weight, data=women) hash(m) # hash a character vector element by element: x <- c("Call any vegetable" , "and the chances are good" , "that the vegetable will respond to you") hash(x) # hash a character vector as one object: hash(x, recursive=FALSE) # hash a list recursively L <- strsplit(x," ") hash(L) # recursive really means recursive, so nested lists are recursed over: L <- list( x = 10 , y = list( foo = "bob" , bar = lm(Sepal.Width ~ Sepal.Length, data=iris) ) ) hash(L) hash(L,recursive=FALSE)