Title: | R interface for FDA Adverse Event Reporting System |
---|---|
Description: | The FDA Adverse Event Reporting System (FAERS) is a database used for the spontaneous reporting of adverse events and medication errors related to human drugs and therapeutic biological products. faers pacakge serves as the interface between the FAERS database and R. Furthermore, faers pacakge offers a standardized approach for performing pharmacovigilance analysis. |
Authors: | Yun Peng [aut, cre] , YuXuan Song [aut], Caipeng Qin [aut], JiaXing Lin [aut] |
Maintainer: | Yun Peng <[email protected]> |
License: | MIT + file LICENSE |
Version: | 1.3.0 |
Built: | 2024-11-29 06:11:31 UTC |
Source: | https://github.com/bioc/faers |
Read and Parse ATHENA VOCABULARIES data
athena(use = NULL, list = FALSE, force = FALSE, url = NULL)
athena(use = NULL, list = FALSE, force = FALSE, url = NULL)
use |
An atomic character specifying the files to use with values in "concept", "domain", "concept_class", "concept_relationship", "concept_ancestor", "concept_synonym", "drug_strength", "relationship", and "vocabulary". |
list |
A boolean value, should it only list files in the ATHENA VOCABULARIES data? |
force |
A boolean value. If set to |
url |
A string of url for ATHENA VOCABULARIES data. You must provide it to cache the file when you firstly run this function. |
if list = TRUE
, an atomic character.
if list = FALSE
, a data.table if use
is a
string or otherwise a list of data.table.
Download and parse FAERS Quarterly Data files
faers( years, quarters, format = NULL, dir = getwd(), compress_dir = dir, handle_opts = list() )
faers( years, quarters, format = NULL, dir = getwd(), compress_dir = dir, handle_opts = list() )
years |
An atomic integer indicates years for which data are required. |
quarters |
An atomic character, only "q1", "q2", "q3", and "q4" are allowed. |
format |
File format to used, only "ascii" and "xml" are availabe. Default: "ascii". |
dir |
The destination directory for any downloads. Defaults to current working dir. |
compress_dir |
A string specifies the directory to extract files to. It will be created if necessary. |
handle_opts |
Extra handle options passed to each request new_handle. |
A FAERSxml or FAERSascii object.
# you must change `dir`, as the file included in the package is sampled data <- faers(2004, "q1", dir = system.file("extdata", package = "faers"), compress_dir = tempdir() )
# you must change `dir`, as the file included in the package is sampled data <- faers(2004, "q1", dir = system.file("extdata", package = "faers"), compress_dir = tempdir() )
This function check if data for the years and quarters selected are available at FAERS to be downloaded.
faers_available(years, quarters, force = FALSE, internal = FALSE)
faers_available(years, quarters, force = FALSE, internal = FALSE)
years |
An atomic integer indicates years for which data are required. |
quarters |
An atomic character, only "q1", "q2", "q3", and "q4" are allowed. |
force |
A boolean value. If set to |
internal |
A boolean value. It determines whether to use the internal data associated with the package. |
A logical indicates FAERS can have data for the years
and
quarters
required?
faers_available(c(2011, 2023), c("q1", "q2"))
faers_available(c(2011, 2023), c("q1", "q2"))
Test whether years and quarters are before specified period
faers_before_period(years, quarters, y, q, inclusive = TRUE)
faers_before_period(years, quarters, y, q, inclusive = TRUE)
years |
An atomic integer indicates years to test. |
quarters |
An atomic character indicates quarters to test, only "q1", "q2", "q3", and "q4" are allowed. |
y |
An integer, specifying the period year. |
q |
A string, specifying the period quarter. |
inclusive |
A bool, whether to include the period specifid. |
An atomic logical with the same length of the max length of years
and quarters
.
faers_before_period(c(2011, 2012), c("q1", "q3"), 2011, "q2")
faers_before_period(c(2011, 2012), c("q1", "q3"), 2011, "q2")
Remove caches
faers_clearcache(caches = NULL, force = FALSE)
faers_clearcache(caches = NULL, force = FALSE)
caches |
An atomic character, indicates what caches to remove? Only
"metadata", "fdadrugs", and "athena" can be used. If |
force |
logical. Should permissions be changed (if possible) to allow the file or directory to be removed? |
Path of the deleted directory invisiblely
faers_clearcache()
faers_clearcache()
Packed all FAERSascii
or FAERSxml
objects into a single FAERSascii
or
FAERSxml
object. It is important to note that all data passed to these
functions via the ...
argument must belong to the different FAERS
objects, indicating that they have the different period data (as defined by
faers_period).
faers_combine(...)
faers_combine(...)
... |
Multiple |
A FAERSxml or FAERSascii object.
# the files included in the package are sampled data1 <- faers_parse( system.file("extdata", "aers_ascii_2004q1.zip", package = "faers"), compress_dir = tempdir() ) data2 <- faers_parse( system.file("extdata", "faers_ascii_2017q2.zip", package = "faers"), compress_dir = tempdir() ) faers_combine(data1, data2)
# the files included in the package are sampled data1 <- faers_parse( system.file("extdata", "aers_ascii_2004q1.zip", package = "faers"), compress_dir = tempdir() ) data2 <- faers_parse( system.file("extdata", "faers_ascii_2017q2.zip", package = "faers"), compress_dir = tempdir() ) faers_combine(data1, data2)
Counting the number of unique case for each event
faers_counts(.object, ...) ## S4 method for signature 'FAERSascii' faers_counts( .object, .events = "soc_name", .fn = NULL, ..., .field = "reac", .na.rm = FALSE )
faers_counts(.object, ...) ## S4 method for signature 'FAERSascii' faers_counts( .object, .events = "soc_name", .fn = NULL, ..., .field = "reac", .na.rm = FALSE )
.object |
A FAERSascii object. |
... |
Other arguments passed to specific methods, for |
.events |
A character specify the events column(s) in the |
.fn |
A function or formula defined the preprocessing function before
creating contingency table, with the Note: When using the If a function, it is used as is. If a formula, e.g. If a string, the function is looked up in |
.field |
A string indicates the interested FAERS fields to use. Only values "demo", "drug", "indi", "ther", "reac", "rpsr", and "outc" can be used. |
.na.rm |
A bool, whether |
A data.table object.
# you must change `dir`, as the files included in the package are sampled data <- faers(c(2004, 2017), c("q1", "q2"), dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) ## Not run: # you must standardize and deduplication before disproportionality analysis # you should replace `meddra_path` with yours data <- faers_standardize(data, meddra_path) data <- faers_dedup(data) faers_counts(data) ## End(Not run) std_data <- readRDS(system.file("extdata", "standardized_data.rds", package = "faers" )) faers_counts(std_data)
# you must change `dir`, as the files included in the package are sampled data <- faers(c(2004, 2017), c("q1", "q2"), dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) ## Not run: # you must standardize and deduplication before disproportionality analysis # you should replace `meddra_path` with yours data <- faers_standardize(data, meddra_path) data <- faers_dedup(data) faers_counts(data) ## End(Not run) std_data <- readRDS(system.file("extdata", "standardized_data.rds", package = "faers" )) faers_counts(std_data)
Tidy up FAERS Quarterly Data with duplicate records removed
faers_dedup(object, ...) ## S4 method for signature 'FAERSascii' faers_dedup(object, remove_deleted_cases = TRUE) ## S4 method for signature 'FAERSxml' faers_dedup(object) ## S4 method for signature 'ANY' faers_dedup(object)
faers_dedup(object, ...) ## S4 method for signature 'FAERSascii' faers_dedup(object, remove_deleted_cases = TRUE) ## S4 method for signature 'FAERSxml' faers_dedup(object) ## S4 method for signature 'ANY' faers_dedup(object)
object |
A FAERSascii object. |
... |
Other arguments passed to specific methods. |
remove_deleted_cases |
If |
A FAERSascii object.
# you must change `dir`, as the files included in the package are sampled data <- faers(c(2004, 2017), c("q1", "q2"), dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) ## Not run: # we must standardize firstly # you should replace `meddra_path` with yours data <- faers_standardize(data, meddra_path) faers_dedup(data) ## End(Not run)
# you must change `dir`, as the files included in the package are sampled data <- faers(c(2004, 2017), c("q1", "q2"), dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) ## Not run: # we must standardize firstly # you should replace `meddra_path` with yours data <- faers_standardize(data, meddra_path) faers_dedup(data) ## End(Not run)
This function downloads the FAERS data for selected years and quarters.
faers_download(years, quarters, format = NULL, dir = getwd(), ...)
faers_download(years, quarters, format = NULL, dir = getwd(), ...)
years |
An atomic integer indicates years for which data are required. |
quarters |
An atomic character, only "q1", "q2", "q3", and "q4" are allowed. |
format |
File format to used, only "ascii" and "xml" are availabe. Default: "ascii". |
dir |
The destination directory for any downloads. Defaults to current working dir. |
... |
Extra handle options passed to each request multi_download. |
An atomic character for the path of downloaded files.
# you must change `dir`, as the file included in the package is sampled # in this way, the file will downloaded from FAERS faers_download( year = 2004, quarter = "q1", dir = system.file("extdata", package = "faers") )
# you must change `dir`, as the file included in the package is sampled # in this way, the file will downloaded from FAERS faers_download( year = 2004, quarter = "q1", dir = system.file("extdata", package = "faers") )
Utils function for FAERSascii class.
faers_get(object, ...) ## S4 method for signature 'FAERSascii' faers_get(object, field) faers_mget(object, ...) ## S4 method for signature 'FAERSascii' faers_mget(object, fields) faers_primaryid(object, ...) ## S4 method for signature 'FAERSascii' faers_primaryid(object) ## S4 method for signature 'FAERSascii,ANY,ANY,ANY' x[i] ## S4 method for signature 'FAERSascii' x[[i]] ## S4 method for signature 'FAERSascii' x$name faers_keep(object, ...) ## S4 method for signature 'FAERSascii' faers_keep(object, primaryid = NULL, invert = FALSE) faers_filter(.object, ...) ## S4 method for signature 'FAERSascii' faers_filter(.object, .fn, ..., .field = NULL, .invert = FALSE) faers_modify(.object, ...) ## S4 method for signature 'FAERSascii' faers_modify(.object, .field, .fn, ...)
faers_get(object, ...) ## S4 method for signature 'FAERSascii' faers_get(object, field) faers_mget(object, ...) ## S4 method for signature 'FAERSascii' faers_mget(object, fields) faers_primaryid(object, ...) ## S4 method for signature 'FAERSascii' faers_primaryid(object) ## S4 method for signature 'FAERSascii,ANY,ANY,ANY' x[i] ## S4 method for signature 'FAERSascii' x[[i]] ## S4 method for signature 'FAERSascii' x$name faers_keep(object, ...) ## S4 method for signature 'FAERSascii' faers_keep(object, primaryid = NULL, invert = FALSE) faers_filter(.object, ...) ## S4 method for signature 'FAERSascii' faers_filter(.object, .fn, ..., .field = NULL, .invert = FALSE) faers_modify(.object, ...) ## S4 method for signature 'FAERSascii' faers_modify(.object, .field, .fn, ...)
object , .object
|
A FAERSascii object. |
... |
Other arguments passed to specific methods. For |
field |
A string indicates the FAERS fields to use. Only values "demo", "drug", "indi", "reac", "ther", "rpsr", and "outc" can be used. |
fields |
A character vector specifying the fields to use. Only values "demo", "drug", "indi", "ther", "reac", "rpsr", and "outc" can be used. |
x |
A FAERSascii object. |
i , name
|
Indices specifying elements to extract. For |
primaryid |
An atomic character or integer specifies the reports to
keep. If |
invert |
A bool. If |
.fn |
A function or formula, accept the field data as the input and
return an atomic integer or character of If a function, it is used as is. If a formula, e.g. If a string, the function is looked up in |
.field |
A string indicating the FAERS data to be used as input for the
|
.invert |
A bool. If |
faers_get
: Extract a specific field
data.table. For reac
and indi
field, meddra
data will be automatically added if avaliable.
faers_mget
: Extract a list of field
data.table. For reac
and indi
field, meddra
data will be automatically added if avaliable.
[[
, $
, and [
: Extract a specific field
data.table or a list of field
data.table from FAERS object. Note: this just
extract field data from @data
slot directly. For usual usage, just use
faers_get
or faers_mget
.
faers_primaryid
: Extract the primaryid
from demo
field.
faers_keep
: only keep data from specified primaryid
. Note: year
,
quarter
, deletedCases
will be kept as the original. So make sure you
didn't filter a whole period FAERS quarterly data, in this way, it's much
better to run faers.
faers_filter
: apply a function to extract the wanted primaryid
, then
use faers_keep
to keep data from these primaryids.
See details.
# you must change `dir`, as the file included in the package is sampled data <- faers(2004, "q1", dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) faers_get(data, "indi") data[["indi"]] data$indi faers_get(data, "demo") data[["demo"]] data$demo faers_mget(data, c("indi", "drug")) faers_mget(data, c("indi", "demo")) faers_primaryid(data) faers_keep(data, primaryid = sample(faers_primaryid(data), 20L)) faers_filter(data, .fn = function(x) { sample(x$primaryid, 100L) }, .field = "demo")
# you must change `dir`, as the file included in the package is sampled data <- faers(2004, "q1", dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) faers_get(data, "indi") data[["indi"]] data$indi faers_get(data, "demo") data[["demo"]] data$demo faers_mget(data, c("indi", "drug")) faers_mget(data, c("indi", "demo")) faers_primaryid(data) faers_keep(data, primaryid = sample(faers_primaryid(data), 20L)) faers_filter(data, .fn = function(x) { sample(x$primaryid, 100L) }, .field = "demo")
Load data attached in faers package
faers_load(nm)
faers_load(nm)
nm |
A string of the data name. Available name: "irAEs". |
irAEs
: Immune-related adverse events examined in ICI-associated adverse
events
irAEs
: A data.table
Chen Chen, Bin Wu, ChenYu Zhang, Ting Xu, Immune-related adverse events associated with immune checkpoint inhibitors: An updated comprehensive disproportionality analysis of the FDA adverse event reporting system, International Immunopharmacology
faers_load("irAEs")
faers_load("irAEs")
Merge all FAERS field data into one
faers_merge(object, ...) ## S4 method for signature 'FAERSascii' faers_merge(object, fields = NULL, all = TRUE, all.x = all, all.y = all) ## S4 method for signature 'FAERSxml' faers_merge(object) ## S4 method for signature 'ANY' faers_merge(object)
faers_merge(object, ...) ## S4 method for signature 'FAERSascii' faers_merge(object, fields = NULL, all = TRUE, all.x = all, all.y = all) ## S4 method for signature 'FAERSxml' faers_merge(object) ## S4 method for signature 'ANY' faers_merge(object)
object |
A FAERSascii or FAERSxml object. |
... |
Other arguments passed to specific methods. |
fields |
A character vector specifying the fields to use. Only values "demo", "drug", "indi", "ther", "reac", "rpsr", and "outc" can be used. |
all |
logical; |
all.x |
logical; if |
all.y |
logical; analogous to |
Each pair of field data are merged based on "year", "quarter" and
"primaryid". In cases where any pair of data contains information related to
"drug_seq" elements, such as "drug_seq", "indi_drug_seq", or "dsg_drug_seq",
"drug_seq" will be aligned as well. fields
shall be organized in the
subsequent sequence: 'demo', 'drug', 'indi', 'reac', 'ther', 'rpsr', and
'outc' and the merging sequence will correspondingly adhere to this order.
Only the initial instance, of the "caseid" column will be preserved.
A data.table object.
You'd better only merge necessary data, otherwise a lot of memory will be consumed to merge all fields data.
# you must change `dir`, as the file included in the package is sampled data <- faers(2004, "q1", dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) faers_merge(data, "indi") # only one field is just like faers_get() faers_merge(data, c("demo", "indi"))
# you must change `dir`, as the file included in the package is sampled data <- faers(2004, "q1", dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) faers_merge(data, "indi") # only one field is just like faers_get() faers_merge(data, c("demo", "indi"))
The function lists the metadata for the FAERS databases currently available to download.
faers_meta(force = FALSE, internal = !curl::has_internet())
faers_meta(force = FALSE, internal = !curl::has_internet())
force |
A boolean value. If set to |
internal |
A boolean value. It determines whether to use the internal data associated with the package. |
A data.table reporting years, period, quarter, and file urls and file sizes.
https://fis.fda.gov/extensions/FPD-QDE-FAERS/FPD-QDE-FAERS.html
faers_meta()
faers_meta()
Parse FAERS Quarterly Data
faers_parse( path, format = NULL, year = NULL, quarter = NULL, compress_dir = getwd() )
faers_parse( path, format = NULL, year = NULL, quarter = NULL, compress_dir = getwd() )
path |
A string specifies the path of FAERS Quarterly Data. You can pass
the FAERS zip file directly, In this way, all files in the zip file will be
extracted in |
format |
File format to used, only "ascii" and "xml" are availabe. Default: "ascii". |
year |
Year of the FAERS Quarterly Data. Coerced into integer, if
|
quarter |
String specifies quarter of the FAERS data, if |
compress_dir |
A string specifies the directory to extract files to. It will be created if necessary. |
A FAERSxml or FAERSascii object.
For all fields data:
All names have been converted to lowercase.
Rename "isr" into "primaryid" for periods before 2012q3.
Field specific operations:
demo
:
Rename "gndr_cod" into "gender" for periods before 2014q2.
Rename "sex" into "gender" for periods after or equal to 2014q2.
Rename "case" and "i_f_cod" into "caseid" and "i_f_code" for legacy aers, before 2012q3.
"age_in_years" was added, measured in years.
"country_code" was added (encoded according to the iso2c
standards), it
will be convenient to translate it into other code with
countrycode().
"sex" was added, which recoded "F" as "Female", "M" as "Male" and other
values as NA
.
ther
:
Rename "drug_seq" into "dsg_drug_seq" for legacy aers, before 2012q3.
indi
:
Rename "drug_seq" into "indi_drug_seq" for legacy aers, before 2012q3.
outc
:
Rename "outc_code" into "outc_cod" for 2012q4
data
# the files included in the package are sampled data <- faers_parse( system.file("extdata", "aers_ascii_2004q1.zip", package = "faers"), compress_dir = tempdir() )
# the files included in the package are sampled data <- faers_parse( system.file("extdata", "aers_ascii_2004q1.zip", package = "faers"), compress_dir = tempdir() )
Create contingency table and run disproportionality analysis
faers_phv_table(.object, ..., .full, .object2) ## S4 method for signature 'FAERSascii,FAERSascii,missing' faers_phv_table(.object, .events = "soc_name", ..., .full, .object2) ## S4 method for signature 'FAERSascii,missing,FAERSascii' faers_phv_table(.object, .events = "soc_name", ..., .full, .object2) faers_phv_signal(.object, ...) ## S4 method for signature 'FAERSascii' faers_phv_signal( .object, .methods = NULL, ..., .phv_signal_params = list(), BPPARAM = SerialParam() )
faers_phv_table(.object, ..., .full, .object2) ## S4 method for signature 'FAERSascii,FAERSascii,missing' faers_phv_table(.object, .events = "soc_name", ..., .full, .object2) ## S4 method for signature 'FAERSascii,missing,FAERSascii' faers_phv_table(.object, .events = "soc_name", ..., .full, .object2) faers_phv_signal(.object, ...) ## S4 method for signature 'FAERSascii' faers_phv_signal( .object, .methods = NULL, ..., .phv_signal_params = list(), BPPARAM = SerialParam() )
.object |
A FAERSascii object. The unique number of |
... |
Other arguments passed to specific methods.
|
.full |
A FAERSascii object with data from full data. In this way,
|
.object2 |
A FAERSascii object with data from another interested drug,
In this way, |
.events |
A character specify the events column(s) in the |
.methods |
Just an alias of |
.phv_signal_params |
Other arguments passed to phv_signal. |
BPPARAM |
An optional |
faers_phv_table
: build a contingency table for all events in
.events
.
faers_phv_signal
: Pharmacovigilance Analysis used contingency table
constructed with faers_phv_table
. You must pass .full
or .object2
into faers_phv_table
.
A data.table object.
# you must change `dir`, as the files included in the package are sampled data <- faers(c(2004, 2017), c("q1", "q2"), dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) ## Not run: # you must standardize and deduplication before disproportionality analysis # you should replace `meddra_path` with yours data <- faers_standardize(data, meddra_path) data <- faers_dedup(data) # we use faers_filter() to extract data we are interested # here, we just sample 100 reports. You should do it based on your purpose. faers_phv_signal( faers_filter(data, .fn = ~ sample(faers_primaryid(.x), 100L)), .full = data ) ## End(Not run)
# you must change `dir`, as the files included in the package are sampled data <- faers(c(2004, 2017), c("q1", "q2"), dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) ## Not run: # you must standardize and deduplication before disproportionality analysis # you should replace `meddra_path` with yours data <- faers_standardize(data, meddra_path) data <- faers_dedup(data) # we use faers_filter() to extract data we are interested # here, we just sample 100 reports. You should do it based on your purpose. faers_phv_signal( faers_filter(data, .fn = ~ sample(faers_primaryid(.x), 100L)), .full = data ) ## End(Not run)
Standardize FAERS Quarterly Data for Preferred Term and drug names
faers_standardize(object, ...) ## S4 method for signature 'FAERSascii' faers_standardize(object, meddra_path, add_smq = FALSE)
faers_standardize(object, ...) ## S4 method for signature 'FAERSascii' faers_standardize(object, meddra_path, add_smq = FALSE)
object |
A FAERSascii object. |
... |
Other arguments passed to specific methods. |
meddra_path |
A string, define the path of MedDRA directory. |
add_smq |
A bool, indicates whether Standardised MedDRA Queries (SMQ)
should be added. If |
A FAERSascii object.
#' # you must change `dir`, as the files included in the package are sampled data <- faers(c(2004, 2017), c("q1", "q2"), dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) ## Not run: # you should replace `meddra_path` with yours data <- faers_standardize(data, meddra_path) ## End(Not run)
#' # you must change `dir`, as the files included in the package are sampled data <- faers(c(2004, 2017), c("q1", "q2"), dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) ## Not run: # you should replace `meddra_path` with yours data <- faers_standardize(data, meddra_path) ## End(Not run)
Provide a container for FAERS Quarterly Data file
## S4 method for signature 'FAERS' show(object) ## S4 method for signature 'FAERSascii' show(object) faers_data(object, ...) ## S4 method for signature 'FAERS' faers_data(object) faers_year(object) ## S4 method for signature 'FAERS' faers_year(object) faers_quarter(object) ## S4 method for signature 'FAERS' faers_quarter(object) faers_period(object) ## S4 method for signature 'FAERS' faers_period(object) faers_meddra(object, ...) ## S4 method for signature 'FAERS' faers_meddra(object, use = NULL) faers_deleted_cases(object, ...) ## S4 method for signature 'FAERSascii' faers_deleted_cases(object) faers_header(object) ## S4 method for signature 'FAERSxml' faers_header(object)
## S4 method for signature 'FAERS' show(object) ## S4 method for signature 'FAERSascii' show(object) faers_data(object, ...) ## S4 method for signature 'FAERS' faers_data(object) faers_year(object) ## S4 method for signature 'FAERS' faers_year(object) faers_quarter(object) ## S4 method for signature 'FAERS' faers_quarter(object) faers_period(object) ## S4 method for signature 'FAERS' faers_period(object) faers_meddra(object, ...) ## S4 method for signature 'FAERS' faers_meddra(object, use = NULL) faers_deleted_cases(object, ...) ## S4 method for signature 'FAERSascii' faers_deleted_cases(object) faers_header(object) ## S4 method for signature 'FAERSxml' faers_header(object)
object |
A |
... |
Other arguments passed to specific methods. |
use |
A string, what meddra data to use, "hierarchy" or "smq". If
|
faers_data
: Extract the data
slot.
faers_year
: Extract the year
slot.
faers_quarter
: Extract the quarter
slot.
faers_period
: A data.table combine the year
and quarter
slot.
faers_meddra
: Extract the meddra
slot. If object
have never been
standardized, always return NULL
.
faers_deleted_cases
: Extract the deletedCases
slot.
See details.
year
An integer specifies the year information.
quarter
A string specifies the quarter information.
data
For FAERSxml
, a data.table. For
FAERSascii
, a list of data.table.
meddra
A MedDRA or NULL
representing the meddra data used for
standardization.
format
A string of "ascii" or "xml" indicates the file format used.
deletedCases
An atomic character, as of 2019 Quarter one there are new files that lists deleted cases. faers_dedup will remove cases in this slot.
standardization
A bool, indicates whether standardization has been performed.
deduplication
A bool, indicates whether deduplication has been performed.
# ususaly we use faers() function to create a `FAERS` object # you must change `dir`, as the file included in the package is sampled data <- faers(2004, "q1", dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) faers_data(data) faers_year(data) faers_quarter(data) faers_period(data) faers_meddra(data) faers_deleted_cases(data)
# ususaly we use faers() function to create a `FAERS` object # you must change `dir`, as the file included in the package is sampled data <- faers(2004, "q1", dir = system.file("extdata", package = "faers"), compress_dir = tempdir() ) faers_data(data) faers_year(data) faers_quarter(data) faers_period(data) faers_meddra(data) faers_deleted_cases(data)
Read and Parse Drugs@FDA data
fda_drugs(pattern = "Products", url = NULL, list = FALSE, force = FALSE)
fda_drugs(pattern = "Products", url = NULL, list = FALSE, force = FALSE)
pattern |
File pattern to use. Must define a file exactly, you can set
|
url |
A string of the url for |
list |
A boolean value, should it only list files in the |
force |
A boolean value. If set to |
if list = TRUE
, an atomic character.
if list = FALSE
, a data.table.
fda_drugs(list = TRUE) fda_drugs()
fda_drugs(list = TRUE) fda_drugs()
Provide a container for MedDRA Data file
meddra(path, add_smq = FALSE, primary_soc = FALSE) ## S4 method for signature 'MedDRA' show(object) meddra_hierarchy(object, ...) ## S4 method for signature 'MedDRA' meddra_hierarchy(object) meddra_smq(object, ...) ## S4 method for signature 'MedDRA' meddra_smq(object) meddra_version(object, ...) ## S4 method for signature 'MedDRA' meddra_version(object)
meddra(path, add_smq = FALSE, primary_soc = FALSE) ## S4 method for signature 'MedDRA' show(object) meddra_hierarchy(object, ...) ## S4 method for signature 'MedDRA' meddra_hierarchy(object) meddra_smq(object, ...) ## S4 method for signature 'MedDRA' meddra_smq(object) meddra_version(object, ...) ## S4 method for signature 'MedDRA' meddra_version(object)
path |
A string, define the path of MedDRA directory. |
add_smq |
A bool, indicates whether Standardised MedDRA Queries (SMQ)
should be added. If |
primary_soc |
A bool, indicates whether keep primary soc only. |
object |
A |
... |
Other arguments passed to specific methods. |
meddra
: A MedDRA
object.
meddra_hierarchy
: Extract the hierarchy
slot.
meddra_smq
: Extract the smq
slot.
meddra_version
: Extract the version
slot.
hierarchy
A data.table or NULL
representing
the meddra hierarchy data. There are five levels to the MedDRA hierarchy,
arranged from very specific to very general.
smq
A data.table or NULL
representing the
meddra smq data. Standardised MedDRA Queries (SMQs) are used to support
signal detection and monitoring. SMQs are validated, standard sets of MedDRA
terms. These sets of terms have undergone extensive review, testing, analysis
and expert discussion. SMQs represent a variety of safety topics of
regulatory interest (e.g., SMQ Severe cutaneous adverse reactions, SMQ
Anaphylactic reaction).
version
A string, the version of MedDRA.
Pharmacovigilance, also known as drug safety. In the context of pharmacovigilance studies, disproportionality analysis primarily served as a tool to evaluate possible association between a specific adverse event and a particular drug which can then be investigated through clinical assessment of individual case reports.
phv_signal( a, b, c, d, methods = NULL, alpha = 0.05, correct = TRUE, n_mcmc = 100000L, alpha1 = 0.5, alpha2 = 0.5, theta_init = NULL, squashing = TRUE, BPPARAM = SerialParam() ) phv_ror(a, b, c, d, alpha = 0.05) phv_prr(a, b, c, d, alpha = 0.05) phv_chisq(a, b, c, d, correct = TRUE, BPPARAM = SerialParam()) phv_fisher(a, b, c, d, alpha = 0.05, BPPARAM = SerialParam()) phv_bcpnn_norm(a, b, c, d, alpha = 0.05) phv_bcpnn_mcmc( a, b, c, d, alpha = 0.05, n_mcmc = 100000L, BPPARAM = SerialParam() ) phv_obsexp_shrink( a, b, c, d, alpha = 0.05, alpha1 = 0.5, alpha2 = 0.5, n_mcmc = 100000L, BPPARAM = SerialParam() ) phv_ebgm(a, b, c, d, alpha = 0.05, theta_init = NULL, squashing = TRUE)
phv_signal( a, b, c, d, methods = NULL, alpha = 0.05, correct = TRUE, n_mcmc = 100000L, alpha1 = 0.5, alpha2 = 0.5, theta_init = NULL, squashing = TRUE, BPPARAM = SerialParam() ) phv_ror(a, b, c, d, alpha = 0.05) phv_prr(a, b, c, d, alpha = 0.05) phv_chisq(a, b, c, d, correct = TRUE, BPPARAM = SerialParam()) phv_fisher(a, b, c, d, alpha = 0.05, BPPARAM = SerialParam()) phv_bcpnn_norm(a, b, c, d, alpha = 0.05) phv_bcpnn_mcmc( a, b, c, d, alpha = 0.05, n_mcmc = 100000L, BPPARAM = SerialParam() ) phv_obsexp_shrink( a, b, c, d, alpha = 0.05, alpha1 = 0.5, alpha2 = 0.5, n_mcmc = 100000L, BPPARAM = SerialParam() ) phv_ebgm(a, b, c, d, alpha = 0.05, theta_init = NULL, squashing = TRUE)
a |
also referred to as |
b |
also referred to as |
c |
also referred to as |
d |
also referred to as |
methods |
An atomic character, specifies the method used to signal
mining. Currently, only "ror", "prr", "chisq", "bcpnn_norm", "bcpnn_mcmc",
"obsexp_shrink", "fisher", and "ebgm" are supported. If |
alpha |
Level of significance, for construction of the confidence intervals. |
correct |
A bool indicating whether to apply Yates's continuity correction when computing the chi-squared statistic. |
n_mcmc |
Number of MCMC simulations per |
alpha1 |
Numerator shrinkage parameter |
alpha2 |
Denominator shrinkage parameter |
theta_init |
A data frame of initial hyperparameter guesses with columns
ordered as: |
squashing |
A bool, whether do automated data squashing. If any zeros
found in |
BPPARAM |
An optional |
Note that the a
, b
, c
, d
inputs can be an atomic vectors of equal
length, for which the function will perform the calculations for each
individual (a,b,c,d)
-tuple moving across the vectors.
It is assumed that the contingency table under consideration has drugs/exposures in the rows and outcomes/events in the columns. See contingency table section.
We use the distinct
patient count method to obtain the frequency counts of
patients exposed to each interested drug, those reporting interested event.
As illustrated in the Contingency table, n
equals the total number of
patients in the database, n11
is the number of patients with exposure to
the interested drug during the model period and reporting interested events,
n10
is the number of patients that have used the interested drug but did
not experience interested event during any of the model periods associated
with the drug, n01
is the number of patients that did not use the
interested drug but experienced interested event, and n00
is the number of
patients that were not exposed to the interested drug and did not report
interested condition.
A data.table with columns of estimated
value and it's confidence interval (ci_low
and ci_high
). Estimated column
are as follows:
phv_ror
: reporting odds ratio (ror
).
phv_prr
: proportional reporting ratio (prr
). Signal defined as a prr
of at least 2, chi-squared with Yates's correction of at least 4 and a >= 3
. An equivalent alternative to chi-squared is to calculate a confidence
interval around the prr
.
phv_bcpnn_norm
: information component (ic
).
phv_bcpnn_mcmc
: information component (ic
).
phv_obsexp_shrink
: observed to expected ratio (oe_ratio
).
phv_ebgm
: Empirical Bayes Geometric Mean (ebgm
).
ADR of interest | Other ADRs | Total | |
Drug of interest | a=n11 | b=n10 | a+b=n1. |
Other drugs | c=n01 | d=n00 | c+d=n0. |
Total | a+c=n.1 | b+d=n.0 | a+b+c+d=n |
The observed to expected (OE) ratio with approximate confidence intervals are constructed on the log2 scale as outlined in Norén et al. (2013).
Expected value was estimated by (a + b) / (a + b + c + d) * (a + c)
.
The OE ratio with shrinkage estimates is calculated as (O + alpha1) / (E + alpha2)
.
If (O + alpha1) < 1
, then the exact uncertainty limits should be used. That
is the confidence intervals as implemented in phv_bcpnn_mcmc
(Norén et al.,
2013).
log2(OE)
approximates the Bayesian confidence propagation neural
network information component (IC) with reasonable accuracy when alpha1 = alpha2 = 0.5
(Norén et al., 2013).
An implementation of the Gamma-Poisson Shrinker (GPS) model for identifying unexpected counts in large contingency tables using an empirical Bayes approach. The Empirical Bayes Geometric Mean (EBGM) and quantile scores are obtained from the GPS model estimates. The GPS was proposed by DuMouchel as a signal detection tool for large frequency tables with both observed (O) and expected (E) counts for each drug-outcome pair. It assumes the observed count of any drug-outcome pair follows the Poisson distribution.
For each drug-outcome pair, the primary parameter of interest was the risk ratio. Rather than using the observed over expected (O/E), GPS uses the empirical Bayesian geometric mean (EBGM) posterior distribution of the risk ratio and the surrounding confidence interval for each drug-outcome pair to identify statistical signals of excess risk. To prevent spurious false positives due to implausibly high risk ratios, GPS implements a Bayesian framework that “shrinks” O/E estimates towards a value which is close to the average O/E values for all drug-event pairs at each level of granularity.
David Olaleye, SAS Institute Inc. (2019), Real-World Evidence and Population Health Analytics: Intersection and Application, https://support.sas.com/resources/papers/proceedings19/3361-2019.pdf
Evans, S.J.W., Waller, P.C. and Davis, S. (2001), Use of proportional reporting ratios (PRRs) for signal generation from spontaneous adverse drug reaction reports. Pharmacoepidem. Drug Safe., 10: 483-486. https://doi.org/10.1002/pds.677
Norén GN, Hopstadius J, Bate A. Shrinkage observed-to-expected ratios for robust and transparent large-scale pattern discovery. Statistical methods in medical research. 2013 Feb;22(1):57-69.
phv_signal(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "ror") phv_ror(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "prr") phv_prr(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "chisq") phv_chisq(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "bcpnn_norm") phv_bcpnn_norm(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "bcpnn_mcmc") phv_bcpnn_mcmc(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "obsexp_shrink") phv_obsexp_shrink(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "fisher") phv_fisher(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "ebgm") phv_ebgm(122, 1320, 381, 31341)
phv_signal(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "ror") phv_ror(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "prr") phv_prr(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "chisq") phv_chisq(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "bcpnn_norm") phv_bcpnn_norm(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "bcpnn_mcmc") phv_bcpnn_mcmc(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "obsexp_shrink") phv_obsexp_shrink(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "fisher") phv_fisher(122, 1320, 381, 31341) phv_signal(122, 1320, 381, 31341, "ebgm") phv_ebgm(122, 1320, 381, 31341)