Title: | An Alternative 'Rcpp' Wrapper of 'MeCab' |
---|---|
Description: | A plain 'Rcpp' wrapper of 'MeCab' that can segment Chinese, Japanese, and Korean text into tokens. The main goal of this package is to provide an alternative to 'tidytext' using morphological analysis. |
Authors: | Akiru Kato [aut, cre], Shogo Ichinose [aut], Taku Kudo [aut], Jorge Nocedal [ctb], Nippon Telegraph and Telephone Corporation [cph] |
Maintainer: | Akiru Kato <[email protected]> |
License: | GPL (>= 3) |
Version: | 1.1.1.9003 |
Built: | 2025-01-17 17:18:11 UTC |
Source: | https://github.com/paithiov909/gibasa |
Create a list of tokens
as_tokens( tbl, token_field = "token", pos_field = get_dict_features()[1], nm = NULL )
as_tokens( tbl, token_field = "token", pos_field = get_dict_features()[1], nm = NULL )
tbl |
A tibble of tokens out of |
token_field |
< |
pos_field |
Column containing features
that will be kept as the names of tokens.
If you don't need them, give a |
nm |
Names of returned list.
If left with |
A named list of tokens.
## Not run: tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) |> prettify(col_select = "POS1") |> as_tokens() ## End(Not run)
## Not run: tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) |> prettify(col_select = "POS1") |> as_tokens() ## End(Not run)
Calculates and binds the importance of bigrams and their synergistic average.
bind_lr(tbl, term = "token", lr_mode = c("n", "dn"), avg_rate = 1)
bind_lr(tbl, term = "token", lr_mode = c("n", "dn"), avg_rate = 1)
tbl |
A tidy text dataset. |
term |
< |
lr_mode |
Method for computing 'FL' and 'FR' values.
|
avg_rate |
Weight of the 'LR' value. |
The 'LR' value is the synergistic average of bigram importance that based on the words and their positions (left or right side).
A data.frame.
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) bind_lr(df) |> head() ## End(Not run)
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) bind_lr(df) |> head() ## End(Not run)
Calculates and binds the term frequency, inverse document frequency, and TF-IDF of the dataset. This function experimentally supports 4 types of term frequencies and 5 types of inverse document frequencies.
bind_tf_idf2( tbl, term = "token", document = "doc_id", n = "n", tf = c("tf", "tf2", "tf3", "itf"), idf = c("idf", "idf2", "idf3", "idf4", "df"), norm = FALSE, rmecab_compat = TRUE )
bind_tf_idf2( tbl, term = "token", document = "doc_id", n = "n", tf = c("tf", "tf2", "tf3", "itf"), idf = c("idf", "idf2", "idf3", "idf4", "df"), norm = FALSE, rmecab_compat = TRUE )
tbl |
A tidy text dataset. |
term |
< |
document |
< |
n |
< |
tf |
Method for computing term frequency. |
idf |
Method for computing inverse document frequency. |
norm |
Logical; If passed as |
rmecab_compat |
Logical; If passed as |
Types of term frequency can be switched with tf
argument:
tf
is term frequency (not raw count of terms).
tf2
is logarithmic term frequency of which base is exp(1)
.
tf3
is binary-weighted term frequency.
itf
is inverse term frequency. Use with idf="df"
.
Types of inverse document frequencies can be switched with idf
argument:
idf
is inverse document frequency of which base is 2, with smoothed.
'smoothed' here means just adding 1 to raw values after logarithmizing.
idf2
is global frequency IDF.
idf3
is probabilistic IDF of which base is 2.
idf4
is global entropy, not IDF in actual.
df
is document frequency. Use with tf="itf"
.
A data.frame.
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) |> dplyr::group_by(doc_id) |> dplyr::count(token) |> dplyr::ungroup() bind_tf_idf2(df) |> head() ## End(Not run)
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) |> dplyr::group_by(doc_id) |> dplyr::count(token) |> dplyr::ungroup() bind_tf_idf2(df) |> head() ## End(Not run)
Builds a UTF-8 system dictionary from source dictionary files.
build_sys_dic(dic_dir, out_dir, encoding)
build_sys_dic(dic_dir, out_dir, encoding)
dic_dir |
Directory where the source dictionaries are located. This argument is passed as '-d' option argument. |
out_dir |
Directory where the binary dictionary will be written. This argument is passed as '-o' option argument. |
encoding |
Encoding of input csv files. This argument is passed as '-f' option argument. |
This function is a wrapper around dictionary compiler of 'MeCab'.
Running this function will create 4 files:
'char.bin', 'matrix.bin', 'sys.dic', and 'unk.dic' in out_dir
.
To use these compiled dictionary,
you also need create a dicrc
file in out_dir
.
A dicrc
file is included in source dictionaries,
so you can just copy it to out_dir
.
A TRUE
is invisibly returned if dictionary is successfully built.
if (requireNamespace("withr")) { # create a sample dictionary in temporary directory build_sys_dic( dic_dir = system.file("latin", package = "gibasa"), out_dir = tempdir(), encoding = "utf8" ) # copy the 'dicrc' file file.copy( system.file("latin/dicrc", package = "gibasa"), tempdir() ) # mocking a 'mecabrc' file to temporarily use the dictionary withr::with_envvar( c( "MECABRC" = if (.Platform$OS.type == "windows") { "nul" } else { "/dev/null" }, "RCPP_PARALLEL_BACKEND" = "tinythread" ), { tokenize("katta-wokattauresikatta", sys_dic = tempdir()) } ) }
if (requireNamespace("withr")) { # create a sample dictionary in temporary directory build_sys_dic( dic_dir = system.file("latin", package = "gibasa"), out_dir = tempdir(), encoding = "utf8" ) # copy the 'dicrc' file file.copy( system.file("latin/dicrc", package = "gibasa"), tempdir() ) # mocking a 'mecabrc' file to temporarily use the dictionary withr::with_envvar( c( "MECABRC" = if (.Platform$OS.type == "windows") { "nul" } else { "/dev/null" }, "RCPP_PARALLEL_BACKEND" = "tinythread" ), { tokenize("katta-wokattauresikatta", sys_dic = tempdir()) } ) }
Builds a UTF-8 user dictionary from a csv file.
build_user_dic(dic_dir, file, csv_file, encoding)
build_user_dic(dic_dir, file, csv_file, encoding)
dic_dir |
Directory where the source dictionaries are located. This argument is passed as '-d' option argument. |
file |
Path to write the user dictionary. This argument is passed as '-u' option argument. |
csv_file |
Path to an input csv file. |
encoding |
Encoding of input csv files. This argument is passed as '-f' option argument. |
This function is a wrapper around dictionary compiler of 'MeCab'.
Note that this function does not support auto assignment of word cost field.
So, you can't leave any word costs as empty in your input csv file.
To estimate word costs, use posDebugRcpp()
function.
A TRUE
is invisibly returned if dictionary is successfully built.
if (requireNamespace("withr")) { # create a sample dictionary in temporary directory build_sys_dic( dic_dir = system.file("latin", package = "gibasa"), out_dir = tempdir(), encoding = "utf8" ) # copy the 'dicrc' file file.copy( system.file("latin/dicrc", package = "gibasa"), tempdir() ) # write a csv file and compile it into a user dictionary csv_file <- tempfile(fileext = ".csv") writeLines( c( "qa, 0, 0, 5, \u304f\u3041", "qi, 0, 0, 5, \u304f\u3043", "qu, 0, 0, 5, \u304f", "qe, 0, 0, 5, \u304f\u3047", "qo, 0, 0, 5, \u304f\u3049" ), csv_file ) build_user_dic( dic_dir = tempdir(), file = (user_dic <- tempfile(fileext = ".dic")), csv_file = csv_file, encoding = "utf8" ) # mocking a 'mecabrc' file to temporarily use the dictionary withr::with_envvar( c( "MECABRC" = if (.Platform$OS.type == "windows") { "nul" } else { "/dev/null" }, "RCPP_PARALLEL_BACKEND" = "tinythread" ), { tokenize("quensan", sys_dic = tempdir(), user_dic = user_dic) } ) }
if (requireNamespace("withr")) { # create a sample dictionary in temporary directory build_sys_dic( dic_dir = system.file("latin", package = "gibasa"), out_dir = tempdir(), encoding = "utf8" ) # copy the 'dicrc' file file.copy( system.file("latin/dicrc", package = "gibasa"), tempdir() ) # write a csv file and compile it into a user dictionary csv_file <- tempfile(fileext = ".csv") writeLines( c( "qa, 0, 0, 5, \u304f\u3041", "qi, 0, 0, 5, \u304f\u3043", "qu, 0, 0, 5, \u304f", "qe, 0, 0, 5, \u304f\u3047", "qo, 0, 0, 5, \u304f\u3049" ), csv_file ) build_user_dic( dic_dir = tempdir(), file = (user_dic <- tempfile(fileext = ".dic")), csv_file = csv_file, encoding = "utf8" ) # mocking a 'mecabrc' file to temporarily use the dictionary withr::with_envvar( c( "MECABRC" = if (.Platform$OS.type == "windows") { "nul" } else { "/dev/null" }, "RCPP_PARALLEL_BACKEND" = "tinythread" ), { tokenize("quensan", sys_dic = tempdir(), user_dic = user_dic) } ) }
Concatenates sequences of tokens in the tidy text dataset, while grouping them by an expression.
collapse_tokens(tbl, condition, .collapse = "")
collapse_tokens(tbl, condition, .collapse = "")
tbl |
A tidy text dataset. |
condition |
< |
.collapse |
String with which tokens are concatenated. |
Note that this function drops all columns except but 'token' and columns for grouping sequences. So, the returned data.frame has only 'doc_id', 'sentence_id', 'token_id', and 'token' columns.
A data.frame.
## Not run: df <- tokenize( data.frame( doc_id = "odakyu-sen", text = "\u5c0f\u7530\u6025\u7dda" ) ) |> prettify(col_select = "POS1") collapse_tokens( df, POS1 == "\u540d\u8a5e" & stringr::str_detect(token, "^[\\p{Han}]+$") ) |> head() ## End(Not run)
## Not run: df <- tokenize( data.frame( doc_id = "odakyu-sen", text = "\u5c0f\u7530\u6025\u7dda" ) ) |> prettify(col_select = "POS1") collapse_tokens( df, POS1 == "\u540d\u8a5e" & stringr::str_detect(token, "^[\\p{Han}]+$") ) |> head() ## End(Not run)
Get dictionary information
sys_dic |
String scalar. |
user_dic |
String scalar. |
data.frame.
Tokenize sentences using 'MeCab'
gbs_tokenize( x, sys_dic = "", user_dic = "", split = FALSE, partial = FALSE, mode = c("parse", "wakati") )
gbs_tokenize( x, sys_dic = "", user_dic = "", split = FALSE, partial = FALSE, mode = c("parse", "wakati") )
x |
A data.frame like object or a character vector to be tokenized. |
sys_dic |
Character scalar; path to the system dictionary for 'MeCab'. Note that the system dictionary is expected to be compiled with UTF-8, not Shift-JIS or other encodings. |
user_dic |
Character scalar; path to the user dictionary for 'MeCab'. |
split |
Logical. When passed as |
partial |
Logical. When passed as |
mode |
Character scalar to switch output format. |
A tibble or a named list of tokens.
Returns names of dictionary features. Currently supports "unidic17" (2.1.2 src schema), "unidic26" (2.1.2 bin schema), "unidic29" (schema used in 2.2.0, 2.3.0), "cc-cedict", "ko-dic" (mecab-ko-dic), "naist11", "sudachi", and "ipa".
get_dict_features( dict = c("ipa", "unidic17", "unidic26", "unidic29", "cc-cedict", "ko-dic", "naist11", "sudachi") )
get_dict_features( dict = c("ipa", "unidic17", "unidic26", "unidic29", "cc-cedict", "ko-dic", "naist11", "sudachi") )
dict |
Character scalar; one of "ipa", "unidic17", "unidic26", "unidic29", "cc-cedict", "ko-dic", "naist11", or "sudachi". |
A character vector.
See also 'CC-CEDICT-MeCab' and 'mecab-ko-dic'.
get_dict_features("ipa")
get_dict_features("ipa")
Whole text of 'Ginga Tetsudo no Yoru' written by Miyazawa Kenji from Aozora Bunko
ginga
ginga
An object of class character
of length 553.
A dataset containing the text of Miyazawa Kenji's novel "Ginga Tetsudo no Yoru" (English title: "Night on the Galactic Railroad") which was published in 1934, the year after Kenji's death. Copyright of this work has expired since more than 70 years have passed after the author's death.
The UTF-8 plain text is sourced from https://www.aozora.gr.jp/cards/000081/card43737.html and is cleaned of meta data.
https://www.aozora.gr.jp/cards/000081/files/43737_ruby_19028.zip
head(ginga)
head(ginga)
Check if scalars are blank
is_blank(x, trim = TRUE, ...)
is_blank(x, trim = TRUE, ...)
x |
Object to check its emptiness. |
trim |
Logical. |
... |
Additional arguments for |
Logicals.
is_blank(list(c(a = "", b = NA_character_), NULL))
is_blank(list(c(a = "", b = NA_character_), NULL))
The lexical density is the proportion of content words (lexical items) in documents. This function is a simple helper for calculating the lexical density of given datasets.
lex_density(vec, contents_words, targets = NULL, negate = c(FALSE, FALSE))
lex_density(vec, contents_words, targets = NULL, negate = c(FALSE, FALSE))
vec |
A character vector. |
contents_words |
A character vector containing values to be counted as contents words. |
targets |
A character vector with which the denominator of lexical density is filtered before computing values. |
negate |
A logical vector of which length is 2.
If passed as |
A numeric vector.
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) df |> prettify(col_select = "POS1") |> dplyr::group_by(doc_id) |> dplyr::summarise( noun_ratio = lex_density(POS1, "\u540d\u8a5e", c("\u52a9\u8a5e", "\u52a9\u52d5\u8a5e"), negate = c(FALSE, TRUE) ), mvr = lex_density( POS1, c("\u5f62\u5bb9\u8a5e", "\u526f\u8a5e", "\u9023\u4f53\u8a5e"), "\u52d5\u8a5e" ), vnr = lex_density(POS1, "\u52d5\u8a5e", "\u540d\u8a5e") ) ## End(Not run)
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) df |> prettify(col_select = "POS1") |> dplyr::group_by(doc_id) |> dplyr::summarise( noun_ratio = lex_density(POS1, "\u540d\u8a5e", c("\u52a9\u8a5e", "\u52a9\u52d5\u8a5e"), negate = c(FALSE, TRUE) ), mvr = lex_density( POS1, c("\u5f62\u5bb9\u8a5e", "\u526f\u8a5e", "\u9023\u4f53\u8a5e"), "\u52d5\u8a5e" ), vnr = lex_density(POS1, "\u52d5\u8a5e", "\u540d\u8a5e") ) ## End(Not run)
Replaces tokens in the tidy text dataset with a string scalar only if they are matched to an expression.
mute_tokens(tbl, condition, .as = NA_character_)
mute_tokens(tbl, condition, .as = NA_character_)
tbl |
A tidy text dataset. |
condition |
< |
.as |
String with which tokens are replaced
when they are matched to condition.
The default value is |
A data.frame.
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) |> prettify(col_select = "POS1") mute_tokens(df, POS1 %in% c("\u52a9\u8a5e", "\u52a9\u52d5\u8a5e")) |> head() ## End(Not run)
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) |> prettify(col_select = "POS1") mute_tokens(df, POS1 %in% c("\u52a9\u8a5e", "\u52a9\u52d5\u8a5e")) |> head() ## End(Not run)
Makes an ngram tokenizer function.
ngram_tokenizer(n = 1L)
ngram_tokenizer(n = 1L)
n |
Integer. |
ngram tokenizer function
bigram <- ngram_tokenizer(2) bigram(letters, sep = "-")
bigram <- ngram_tokenizer(2) bigram(letters, sep = "-")
Packs a data.frame of tokens into a new data.frame of corpus, which is compatible with the Text Interchange Formats.
pack(tbl, pull = "token", n = 1L, sep = "-", .collapse = " ")
pack(tbl, pull = "token", n = 1L, sep = "-", .collapse = " ")
tbl |
A data.frame of tokens. |
pull |
< |
n |
Integer internally passed to ngrams tokenizer function
created of |
sep |
Character scalar internally used as the concatenator of ngrams. |
.collapse |
This argument is passed to |
A tibble.
The Text Interchange Formats (TIF) is a set of standards that allows R text analysis packages to target defined inputs and outputs for corpora, tokens, and document-term matrices.
The data.frame of tokens here is a data.frame object compatible with the TIF.
A TIF valid data.frame of tokens is expected to have
one unique key column (named doc_id
)
of each text and several feature columns of each tokens.
The feature columns must contain at least token
itself.
https://github.com/ropenscilabs/tif
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) pack(df) ## End(Not run)
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) pack(df) ## End(Not run)
Turns a single character column into features while separating with delimiter.
prettify( tbl, col = "feature", into = get_dict_features("ipa"), col_select = seq_along(into), delim = "," )
prettify( tbl, col = "feature", into = get_dict_features("ipa"), col_select = seq_along(into), delim = "," )
tbl |
A data.frame that has feature column to be prettified. |
col |
< |
into |
Character vector that is used as column names of features. |
col_select |
Character or integer vector that will be kept in prettified features. |
delim |
Character scalar used to separate fields within a feature. |
A data.frame.
prettify( data.frame(x = c("x,y", "y,z", "z,x")), col = "x", into = c("a", "b"), col_select = "b" ) ## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) prettify(df, col_select = 1:3) prettify(df, col_select = c(1, 3, 6)) prettify(df, col_select = c("POS1", "Original")) ## End(Not run)
prettify( data.frame(x = c("x,y", "y,z", "z,x")), col = "x", into = c("a", "b"), col_select = "b" ) ## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) prettify(df, col_select = 1:3) prettify(df, col_select = c(1, 3, 6)) prettify(df, col_select = c("POS1", "Original")) ## End(Not run)
Tokenize sentences using 'MeCab'
tokenize( x, text_field = "text", docid_field = "doc_id", sys_dic = "", user_dic = "", split = FALSE, partial = FALSE, grain_size = 1L, mode = c("parse", "wakati") )
tokenize( x, text_field = "text", docid_field = "doc_id", sys_dic = "", user_dic = "", split = FALSE, partial = FALSE, grain_size = 1L, mode = c("parse", "wakati") )
x |
A data.frame like object or a character vector to be tokenized. |
text_field |
< |
docid_field |
< |
sys_dic |
Character scalar; path to the system dictionary for 'MeCab'. Note that the system dictionary is expected to be compiled with UTF-8, not Shift-JIS or other encodings. |
user_dic |
Character scalar; path to the user dictionary for 'MeCab'. |
split |
Logical. When passed as |
partial |
Logical. When passed as |
grain_size |
Integer value larger than 1.
This argument is internally passed to |
mode |
Character scalar to switch output format. |
A tibble or a named list of tokens.
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) head(df) ## End(Not run)
## Not run: df <- tokenize( data.frame( doc_id = seq_along(5:8), text = ginga[5:8] ) ) head(df) ## End(Not run)