Title: | Fast n-Gram 'Tokenization' |
---|---|
Description: | An n-gram is a sequence of n "words" taken, in order, from a body of text. This is a collection of utilities for creating, displaying, summarizing, and "babbling" n-grams. The 'tokenization' and "babbling" are handled by very efficient C code, which can even be built as its own standalone library. The babbler is a simple Markov chain. The package also offers a vignette with complete example 'workflows' and information about the utilities offered in the package. |
Authors: | Drew Schmidt [aut, cre], Christian Heckendorf [aut] |
Maintainer: | Drew Schmidt <[email protected]> |
License: | BSD 2-clause License + file LICENSE |
Version: | 3.2.3 |
Built: | 2025-01-03 05:29:35 UTC |
Source: | https://github.com/wrathematics/ngram |
An n-gram is a sequence of n "words" taken from a body of text. This package offers utilities for creating, displaying, summarizing, and "babbling" n-grams. The tokenization and "babbling" are handled by very efficient C code, which can even be build as its own standalone library. The babbler is a simple Markov chain.
The ngram package is distributed under the permissive 2-clause BSD license. If you find the code here useful, please let us know and/or cite the package, whatever is appropriate.
The package has its own PRNG; we use an implementation of MT1997 for all non-deterministic choices.
The babbler uses its own internal PRNG (i.e., not R's), so seeds cannot be managed as with R's seeds. The generator is an implementation of MT19937.
At this time, we note that the seed may not guarantee the same results across machines. Currently only Solaris produces different values from mainstream platforms (Windows, Mac, Linux, FreeBSD), but potentially others could as well.
babble(ng, genlen = 150, seed = getseed()) ## S4 method for signature 'ngram' babble(ng, genlen = 150, seed = getseed())
babble(ng, genlen = 150, seed = getseed()) ## S4 method for signature 'ngram' babble(ng, genlen = 150, seed = getseed())
ng |
An ngram object. |
genlen |
Generated length, i.e., the number of words to babble. |
seed |
Seed for the random number generator. |
A markov chain babbler.
library(ngram) str = "A B A C A B B" ng = ngram(str) babble(ng, genlen=5, seed=1234)
library(ngram) str = "A B A C A B B" ng = ngram(str) babble(ng, genlen=5, seed=1234)
A quick utility for concatenating strings together. This is handy because if you want to generate the n-grams for several different texts, you must first put them into a single string unless the text is composed of sentences that should not be joined.
concatenate(..., collapse = " ", rm.space = FALSE)
concatenate(..., collapse = " ", rm.space = FALSE)
... |
Input text(s). |
collapse |
A character to separate the input strings if a vector of strings is supplied; otherwise this does nothing. |
rm.space |
logical; determines if spaces should be removed from the final string. |
A string.
library(ngram) words = c("a", "b", "c") wordcount(words) str = concatenate(words) wordcount(str)
library(ngram) words = c("a", "b", "c") wordcount(words) str = concatenate(words) wordcount(str)
Some simple "getters" for ngram
objects. Necessary since the internal
representation is not a native R object.
ng_order(ng, decreasing = FALSE) ## S4 method for signature 'ngram' ng_order(ng, decreasing = FALSE) get.ngrams(ng) ## S4 method for signature 'ngram' get.ngrams(ng) get.string(ng) ## S4 method for signature 'ngram' get.string(ng) get.nextwords(ng) ## S4 method for signature 'ngram' get.nextwords(ng)
ng_order(ng, decreasing = FALSE) ## S4 method for signature 'ngram' ng_order(ng, decreasing = FALSE) get.ngrams(ng) ## S4 method for signature 'ngram' get.ngrams(ng) get.string(ng) ## S4 method for signature 'ngram' get.string(ng) get.nextwords(ng) ## S4 method for signature 'ngram' get.nextwords(ng)
ng |
An ngram object. |
decreasing |
Should the sorted order be in descending order? |
ngram.order
returns an R vector with the original corpus order of the ngrams.
get.ngrams()
returns an R vector of all n-grams.
get.nextwords()
does nothing at the moment; it will be implemented in
future releases.
getnstring()
recovers the input string as an R string.
library(ngram) str = "A B A C A B B" ng = ngram(str) get.ngrams(ng)[ng_order(ng)]
library(ngram) str = "A B A C A B B" ng = ngram(str) get.ngrams(ng)[ng_order(ng)]
Read in a collection of text files.
multiread( path = ".", extension = "txt", recursive = FALSE, ignore.case = FALSE, prune.empty = TRUE, pathnames = TRUE )
multiread( path = ".", extension = "txt", recursive = FALSE, ignore.case = FALSE, prune.empty = TRUE, pathnames = TRUE )
path |
The base file path to search. |
extension |
An extension or the "*" wildcard (for everything). For example,
to read in files ending |
recursive |
Logical; should the search include all subdirectories? |
ignore.case |
Logical; should case be ignored in the extension? For example, if
|
prune.empty |
Logical; should empty files be removed from the returned list? |
pathnames |
Logical; should the full path be included in the names of the returned list. |
The extension
argument is not a general regular
expression pattern, but a simplified pattern. For example,
the pattern *.txt
is really equivalent to
*[.]txt$
as a regular expression. If you need more
complicated patterns, you should directly use the dir()
function.
A named list of strings, where the names are the file names.
## Not run: path = system.file(package="ngram") ### Read all files in the base path multiread(path, extension="*") ### Read all .r/.R files recursively (warning: lots of text) multiread(path, extension="r", recursive=TRUE, ignore.case=TRUE) ## End(Not run)
## Not run: path = system.file(package="ngram") ### Read all files in the base path multiread(path, extension="*") ### Read all .r/.R files recursively (warning: lots of text) multiread(path, extension="r", recursive=TRUE, ignore.case=TRUE) ## End(Not run)
The ngram()
function is the main workhorse of this package. It takes
an input string and converts it into the internal n-gram representation.
ngram(str, n = 2, sep = " ")
ngram(str, n = 2, sep = " ")
str |
The input text. |
n |
The 'n' as in 'n-gram'. |
sep |
A set of separator characters for the "words". See details for
information about how this works; it works a little differently
from |
On evaluation, a copy of the input string is produced and stored as an external pointer. This is necessary because the internal list representation just points to the first char of each word in the input string. So if you (or R's gc) deletes the input string, basically all hell breaks loose.
The sep
parameter splits at any of the characters in
the string. So sep=", "
splits at a comma or a space.
An ngram
class object.
ngram-class
, getters
,
phrasetable
, babble
library(ngram) str = "A B A C A B B" ngram(str, n=2) str = "A,B,A,C A B B" ### Split at a space print(ngram(str), output="full") ### Split at a comma print(ngram(str, sep=","), output="full") ### Split at a space or a comma print(ngram(str, sep=", "), output="full")
library(ngram) str = "A B A C A B B" ngram(str, n=2) str = "A,B,A,C A B B" ### Split at a space print(ngram(str), output="full") ### Split at a comma print(ngram(str, sep=","), output="full") ### Split at a space or a comma print(ngram(str, sep=", "), output="full")
An n-gram is an ordered sequence of n "words" taken from a body of "text". The terms "words" and "text" can easily be interpreted literally, or with a more loose interpretation.
For example, consider the sequence "A B A C A B B". If we examine the 2-grams (or bigrams) of this sequence, they are
A B, B A, A C, C A, A B, B B
or without repetition:
A B, B A, A C, C A, B B
That is, we take the input string and group the "words" 2 at a time (because
n=2
). Notice that the number of n-grams and the number of words are
not obviously related; counting repetition, the number of n-grams is equal
to
nwords - n + 1
Bounds ignoring repetition are highly dependent on the input. A correct but useless bound is
\#ngrams = nwords - (\#repeats - 1) - (n - 1)
An ngram
object is an S4 class container that stores some basic
summary information (e.g., n), and several external pointers. For
information on how to construct an ngram
object, see
ngram
.
str_ptr
A pointer to a copy of the original input string.
strlen
The length of the string.
n
The eponymous 'n' as in 'n-gram'.
ngl_ptr
A pointer to the processed list of n-grams.
ngsize
The length of the ngram list, or in other words, the number of unique n-grams in the input string.
sl_ptr
A pointer to the list of words from the input string.
Print methods.
## S4 method for signature 'ngram' print(x, output = "summary") ## S4 method for signature 'ngram' show(object)
## S4 method for signature 'ngram' print(x, output = "summary") ## S4 method for signature 'ngram' show(object)
x , object
|
An ngram object. |
output |
a character string; determines what exactly is printed. Options are "summary", "truncated", and "full". |
If output=="summary"
, then just a simple representation of the n-gram
object will be printed; for example, "An ngram object with 5 2-grams".
If output=="truncated"
, then the n-grams will be printed up to a
maximum of 5 total.
If output=="full"
then all n-grams will be printed.
Get a table
get.phrasetable(ng)
get.phrasetable(ng)
ng |
An ngram object. |
library(ngram) str = "A B A C A B B" ng = ngram(str) get.phrasetable(ng)
library(ngram) str = "A B A C A B B" ng = ngram(str) get.phrasetable(ng)
A simple text preprocessor for use with the ngram()
function.
preprocess( x, case = "lower", remove.punct = FALSE, remove.numbers = FALSE, fix.spacing = TRUE )
preprocess( x, case = "lower", remove.punct = FALSE, remove.numbers = FALSE, fix.spacing = TRUE )
x |
Input text. |
case |
Option to change the case of the text. Value should be "upper", "lower", or NULL (no change). |
remove.punct |
Logical; should punctuation be removed? |
remove.numbers |
Logical; should numbers be removed? |
fix.spacing |
Logical; should multi/trailing spaces be collapsed/removed. |
The input text x
must already be in the correct form for
ngram()
, i.e., a single string (character vector of length 1).
The case
argument can take 3 possible values: NULL
, in which
case nothing is done, or lower
or upper
, wherein the case of
the input text will be made lower/upper case, repesctively.
concat()
returns
library(ngram) x = "Watch out for snakes! 111" preprocess(x) preprocess(x, remove.punct=TRUE, remove.numbers=TRUE)
library(ngram) x = "Watch out for snakes! 111" preprocess(x) preprocess(x, remove.punct=TRUE, remove.numbers=TRUE)
Generate a corpus of random "words".
rcorpus(nwords = 50, alphabet = letters, minwordlen = 1, maxwordlen = 6)
rcorpus(nwords = 50, alphabet = letters, minwordlen = 1, maxwordlen = 6)
nwords |
Number of words to generate. |
alphabet |
The pool of "letters" that word generation coes from. By default, it is the lowercase roman alphabet. |
minwordlen , maxwordlen
|
The min/max length of words in the generated corpus. |
A string.
rcorpus(10)
rcorpus(10)
A utility function for use with n-gram modeling. This function splits a string based on various options.
splitter( string, split.char = FALSE, split.space = TRUE, spacesep = "_", split.punct = FALSE )
splitter( string, split.char = FALSE, split.space = TRUE, spacesep = "_", split.punct = FALSE )
string |
An input string. |
split.char |
Logical; should a split occur after every character? |
split.space |
Logical; determines if spaces should be preserved as characters in
the n-gram tokenization. The character(s) used for spaces are
determined by the |
spacesep |
The character(s) to represent a space in the case that
|
split.punct |
Logical; determines if splits should occur at punctuation. |
Note that choosing split.char=TRUE
necessarily implies
split.punct=TRUE
as well — but not necessarily that
split.space=TRUE
.
A string.
x = "watch out! a snake!" splitter(x, split.char=TRUE) splitter(x, split.space=TRUE, spacesep="_") splitter(x, split.punct=TRUE)
x = "watch out! a snake!" splitter(x, split.char=TRUE) splitter(x, split.space=TRUE, spacesep="_") splitter(x, split.punct=TRUE)
Text Summary
string.summary(string, wordlen_max = 10, senlen_max = 10, syllen_max = 10)
string.summary(string, wordlen_max = 10, senlen_max = 10, syllen_max = 10)
string |
An input string. |
wordlen_max , senlen_max , syllen_max
|
The maximum lengths of words/sentences/syllables to consider. |
A list of class string_summary
.
x = "a b a c a b b" string.summary(x)
x = "a b a c a b b" string.summary(x)
An n-gram tokenizer with identical output to the NGramTokenizer
function from the RWeka package.
ngram_asweka(str, min = 2, max = 2, sep = " ")
ngram_asweka(str, min = 2, max = 2, sep = " ")
str |
The input text. |
min , max
|
The minimum and maximum 'n' as in 'n-gram'. |
sep |
A set of separator characters for the "words". See details for
information about how this works; it works a little differently
from |
This n-gram tokenizer behaves similarly in both input and return to
the tokenizer in RWeka. Unlike the tokenizer ngram()
, the
return is not a special class of external pointers; it is a vector,
and therefore can be serialized via save()
or saveRDS()
.
A vector of n-grams listed in decreasing blocks of n, in order within a block. The output matches that of RWeka's n-gram tokenizer.
library(ngram) str = "A B A C A B B" ngram_asweka(str, min=2, max=4)
library(ngram) str = "A B A C A B B" ngram_asweka(str, min=2, max=4)
wordcount()
counts words. Currently a "word" is a clustering of
characters separated from another clustering of charactersby at least 1
space. That is the law.
wordcount(x, sep = " ", count_fun = sum) ## S3 method for class 'character' wordcount(x, sep = " ", count_fun = sum) ## S3 method for class 'ngram' wordcount(x, sep = " ", count_fun = sum)
wordcount(x, sep = " ", count_fun = sum) ## S3 method for class 'character' wordcount(x, sep = " ", count_fun = sum) ## S3 method for class 'ngram' wordcount(x, sep = " ", count_fun = sum)
x |
A string or vector of strings, or an ngram object. |
sep |
The characters used to separate words. |
count_fun |
The function to use for aggregation if |
A count.
library(ngram) words = c("a", "b", "c") words wordcount(words) str = concatenate(words, collapse="") str wordcount(str)
library(ngram) words = c("a", "b", "c") words wordcount(words) str = concatenate(words, collapse="") str wordcount(str)