Title: | PharmacoVigilance Methods |
---|---|
Description: | A collection of methods used in the field of pharmacovigilance for the dectection of 'interesting' drug-adverse event pairs from spontaneous reporting data. |
Authors: | Louis Dijkstra [aut, cre], Marco Garling [ctb] |
Maintainer: | Louis Dijkstra <[email protected]> |
License: | GPL (>= 3) |
Version: | 1.0 |
Built: | 2025-01-05 06:03:56 UTC |
Source: | https://github.com/bips-hb/pvm |
Applies the BCPNN to a collection of 2 x 2 tables of the form
event | not event | |
drug | a |
c
|
not drug | b |
d
|
There are two versions of the BCPNN:
'original'
- The original version proposed by Bate et al. (1998)
'alternative'
- The BCPNN as proposed by Norén et al. (2006)
BCPNN( a, b, c, d, alpha = NULL, version = "original", mc_estimate = FALSE, mc_runs = 1000 )
BCPNN( a, b, c, d, alpha = NULL, version = "original", mc_estimate = FALSE, mc_runs = 1000 )
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
alpha |
Value between |
version |
Version of the BCPNN used. Can either be |
mc_estimate |
The value is estimated using Monte Carlo runs (Default = |
mc_runs |
The number of Monte Carlo runs used to estimate the credible interval.
(Default: 1000). Only used when |
The implementation of this function is based on the implementation in the
PhViD
package.
The maximum aposteriori estimate of the information component (IC) or the lower endpoint of the approximate credible interval
Bate, A., Lindquist, M., Edwards, I. R., Olsson, S., Orre, R., Lansner, A., & De Freitas, R. M. (1998). A Bayesian neural network method for adverse drug reaction signal generation. European Journal of Clinical Pharmacology, 54(4), 315–321. http://doi.org/10.1007/s002280050466
Norén, G. N., Bate, A., Orre, R., & Edwards, I. R. (2006). Extending the methods used to screen the WHO drug safety database towards analysis of complex associations and improved accuracy for rare events. Statistics in Medicine, 25(21), 3740–3757. http://doi.org/10.1002/sim.2473
# get the tables a <- srdata$tables$a b <- srdata$tables$b c <- srdata$tables$c d <- srdata$tables$d # Applying the original BCPNN: BCPNN(a, b, c, d) # [1] 0.349783103 -0.609077730 -0.168446711 -0.277981964 ... # Getting the lower end point of the 95% confidence intervaL: BCPNN(a, b, c, d, alpha = 0.05) # [1] 0.280077253 -0.994960076 -0.293624528 -0.408661852 ... # Using the alternative version: BCPNN(a, b, c, d, version = 'alternative') # [1] 0.350235800 -0.595807902 -0.166901050 -0.276387348 ... # Getting the lower end points of the 95% confidence interval # using the alternative version. The estimates are based on # 10,000 Monte Carlo samples: BCPNN(a, b, c, d, version = 'alternative', alpha = 0.05, mc_estimate = TRUE, mc_runs = 10^4) # [1] [1] 0.31621489 -0.92490130 -0.25601307 -0.37040303 ...
# get the tables a <- srdata$tables$a b <- srdata$tables$b c <- srdata$tables$c d <- srdata$tables$d # Applying the original BCPNN: BCPNN(a, b, c, d) # [1] 0.349783103 -0.609077730 -0.168446711 -0.277981964 ... # Getting the lower end point of the 95% confidence intervaL: BCPNN(a, b, c, d, alpha = 0.05) # [1] 0.280077253 -0.994960076 -0.293624528 -0.408661852 ... # Using the alternative version: BCPNN(a, b, c, d, version = 'alternative') # [1] 0.350235800 -0.595807902 -0.166901050 -0.276387348 ... # Getting the lower end points of the 95% confidence interval # using the alternative version. The estimates are based on # 10,000 Monte Carlo samples: BCPNN(a, b, c, d, version = 'alternative', alpha = 0.05, mc_estimate = TRUE, mc_runs = 10^4) # [1] [1] 0.31621489 -0.92490130 -0.25601307 -0.37040303 ...
Performs the chi-squared test with or without Yates's continuity correction to a collection of 2 x 2 tables of the form
event | not event | |
drug | a |
c
|
not drug | b |
d
|
chi2Test(a, b, c, d, yates = FALSE)
chi2Test(a, b, c, d, yates = FALSE)
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
yates |
If |
p-value
The standard warnings for when the counts are too low in the 2 x 2 tables are suppressed. Due to the sparse nature of spontaneous reporting data, this happens quite frequently.
Creates a data frame containing all 2 x 2 contingency tables
given a raw spontaneous reporting (SR) data set. An SR data set
is a binary matrix, where each row is a report. The first
columns represent the presence (1
) or absence of a drug
(0
), the other columns represent the presence or absence
of an event.
The tables are organized as follows:
event |
not event |
total | |
drug |
a |
c |
a + c
|
not drug |
b |
d |
b + d
|
total | a + b |
c + d |
n_reports
|
convertRawReports2Tables(reports, n_drugs, n_events)
convertRawReports2Tables(reports, n_drugs, n_events)
reports |
A binary matrix. Each row is a report |
n_drugs |
The number of drugs |
n_events |
The number of events |
The code is a simplified version of the function create2x2Tables
in the SRSim
package.
A data frame where each row represents a 2 x 2 table. The columns represent:
drug_id |
The ID of the drug |
event_id |
The ID of the event |
a |
Number of times the drug and event appeared together in a report |
b |
Number of times the event appeared without the drug in a report |
c |
Number of times the drug appeared without the event in a report |
d |
Number of times the drug and event both did not appear in a report |
Creates a data frame containing all 2 x 2 contingency tables
given a raw spontaneous reporting (SR) data set. An SR data set
is a binary matrix, where each row is a report. The first
columns represent the presence or absence of a drug, the
The other columns represent the presence or absence of an event.
See for more information the wrapper function,
convertRawReports2Tables()
.
convertRawReports2TablesRcpp(reports, n_drugs, n_events)
convertRawReports2TablesRcpp(reports, n_drugs, n_events)
reports |
A binary matrix. Each row is a report |
n_drugs |
The number of drugs |
n_events |
The number of events |
The code is a simplified version of the function create2x2TablesRcpp
in the SRSim
package.
A dataframe. A description of the columns can be found in the commentary
for the function convertRawReports2Tables()
Returns a 2 x 2 contingency table of the form:
event | not event | |
drug | a |
c
|
not drug | b |
d
|
createTable(a, b, c, d)
createTable(a, b, c, d)
a |
Count in the upper left corner of the table |
b |
Count in the lower left corner of the table |
c |
Count in the upper right corner of the table |
d |
Count in the lower right corner of the table |
A 2 x 2 matrix
Returns the values of the density function of a bimodal negative binomial distribution.
dbinbinom(x, size1, prob1, size2, prob2, w)
dbinbinom(x, size1, prob1, size2, prob2, w)
x |
The x-values |
size1 , prob1
|
The size and prob parameters for the first mode |
size2 , prob2
|
The size and prob parameters for the second mode |
w |
The weight of the first mode (must lie in |
The density for the values in x
DuMouchel, W. (1999). Bayesian Data Mining in Large Frequency Tables, with an Application to the FDA Spontaneous Reporting System. The American Statistician, 53(3), 177–190. https://doi.org/10.1080/00031305.1999.10474456
DuMouchel, W., & Pregibon, D. (2001). Empirical bayes screening for multi-item associations. Proceedings of the Seventh ACM SIGKDD International Conference on Knowledge Discovery and Data Mining - KDD ’01, (October), 67–76. http://doi.org/10.1145/502512.502526
logLikelihood2NegativeBinomial()
, fitPriorParametersGPS()
, GPS()
Performs the (one-sided) Fisher's exact test to a collection of 2 x 2 tables of the form:
event | not event | |
drug | a |
c
|
not drug | b |
d
|
fisherExactTest(a, b, c, d, midpvalue = FALSE)
fisherExactTest(a, b, c, d, midpvalue = FALSE)
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
midpvalue |
The mid-p-value correction (suggested by Agresti) is applied |
Wrapper function for the Rcpp
functions fishersTestGreater
and midPFishersTestGreater
.
p-value
Ahmed, I., Dalmasso, C., Haramburu, F., Thiessard, F., Bro\"et, P., & Tubert-Bitter, P. (2010). False Discovery Rate Estimation for Frequentist Pharmacovigilance Signal Detection Methods. Biometrics, 66(1), 301–309. https://doi.org/10.1111/j.1541-0420.2009.01262.x
Fits the prior parameters to the data for the Gamma Poisson shrinker (GPS). The initial guess for the parameter values are set the same as by DuMouchel (1999).
fitPriorParametersGPS( a, b, c, d, E = ((a + b) * (a + c))/(a + b + c + d), alpha1 = 0.2, beta1 = 0.1, alpha2 = 2, beta2 = 4, w = 1/3 )
fitPriorParametersGPS( a, b, c, d, E = ((a + b) * (a + c))/(a + b + c + d), alpha1 = 0.2, beta1 = 0.1, alpha2 = 2, beta2 = 4, w = 1/3 )
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
E |
Passed to |
alpha1 |
Prior parameter |
beta1 |
Prior parameter |
alpha2 |
Prior parameter |
beta2 |
Prior parameter |
w |
Prior parameter |
A list with the prior parameters
DuMouchel, W. (1999). Bayesian Data Mining in Large Frequency Tables, with an Application to the FDA Spontaneous Reporting System. The American Statistician, 53(3), 177–190. https://doi.org/10.1080/00031305.1999.10474456
DuMouchel, W., & Pregibon, D. (2001). Empirical bayes screening for multi-item associations. Proceedings of the Seventh ACM SIGKDD International Conference on Knowledge Discovery and Data Mining - KDD ’01, (October), 67–76. http://doi.org/10.1145/502512.502526
loglikelihood2NegativeBinomial()
a <- srdata$tables$a b <- srdata$tables$b c <- srdata$tables$c d <- srdata$tables$d fitPriorParametersGPS(a, b, c, d) # $alpha1 # [1] 98.28478 # # $beta1 # [1] 16.48081 # # $alpha2 # [1] 16.61439 # # $beta2 # [1] 18.00642 # # $w # [1] 0.06132586
a <- srdata$tables$a b <- srdata$tables$b c <- srdata$tables$c d <- srdata$tables$d fitPriorParametersGPS(a, b, c, d) # $alpha1 # [1] 98.28478 # # $beta1 # [1] 16.48081 # # $alpha2 # [1] 16.61439 # # $beta2 # [1] 18.00642 # # $w # [1] 0.06132586
Applies the Gamma Poisson Shrinker (GPS) introduced by DuMouchel (1999) to a collection of 2 x 2 tables of the form
event | not event | |
drug | a |
c
|
not drug | b |
d
|
GPS( a, b, c, d, E = ((a + b) * (a + c))/(a + b + c + d), prior = fitPriorParametersGPS(a, b, c, d), alpha = NULL )
GPS( a, b, c, d, E = ((a + b) * (a + c))/(a + b + c + d), prior = fitPriorParametersGPS(a, b, c, d), alpha = NULL )
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
E |
Vector with the expected values when there are no associations. By default set to
the values used by DuMouchel (1999), i.e., |
prior |
List that contains the prior parameters. If not specified, automatically fitted to the data,
see |
alpha |
Value between |
a vector with the GPS estimates
DuMouchel, W. (1999). Bayesian Data Mining in Large Frequency Tables, with an Application to the FDA Spontaneous Reporting System. The American Statistician, 53(3), 177–190. https://doi.org/10.1080/00031305.1999.10474456
DuMouchel, W., & Pregibon, D. (2001). Empirical bayes screening for multi-item associations. Proceedings of the Seventh ACM SIGKDD International Conference on Knowledge Discovery and Data Mining - KDD ’01, (October), 67–76. http://doi.org/10.1145/502512.502526
fitPriorParametersGPS()
Applies the LASSO to raw spontaneous report data.
Every event is regressed on all the drugs in the data set.
The function returns a data frame with every drug-event pair
and the estimated regression coefficient.
In case there are not enough observations of an event (the
event must appear at least twice), the regression is not
performed. All the regression estimates for the drugs and that
particular event are set to 0
. The entries in the lambda
column of the data frame are set to NA
.
Shrinkage parameter
One can set the shrinkage parameter with the argument lambda
in a number of ways:
lambda = NULL
(Default). The parameter is set
through cross-validation. The number of folds can be set with
nfolds
(Default = 10). The loss function used can be set
with type.measure
(Default = deviance
). See for
other type.measure
options the function glmnet::cv.glmnet
.
The glmnet::cv.glmnet
function returns two estimates:
lambda.min
and lambda.1se
. To use the former, set
lambda.type
to "min"
(default). For the latter, type
"1se"
.
Set to one value, e.g., lambda = 0.5
. The same shrinkage parameter
is used for all events.
A vector of length n_events
, e.g., lambda = c(0.5, 0.8, 1)
. The
shrinkage parameters are specified for each event individually.
LASSO( reports, n_drugs, n_events, lambda = NULL, nfolds = 10, type.measure = "deviance", lambda.type = "min", alpha = 1, event_ids = 1:n_events, verbose = FALSE )
LASSO( reports, n_drugs, n_events, lambda = NULL, nfolds = 10, type.measure = "deviance", lambda.type = "min", alpha = 1, event_ids = 1:n_events, verbose = FALSE )
reports |
A binary matrix, where each row represents a report |
n_drugs , n_events
|
The number of drugs and events |
lambda |
Shrinkage parameter. Can be a list of length |
nfolds |
Number of folds used for cross-validation |
type.measure |
Loss function used (Default: |
lambda.type |
Type of estimate that is used (either |
alpha |
The elastic net mixing parameter (Default: 1.0 - LASSO) |
event_ids |
IDs of the events evaluated (Default: all) |
verbose |
Verbosity (Default: |
A data frame with the columns
drug_id |
ID for the drug (simply numbered 1,2,3,...etc.) |
event_id |
ID for the event (simply numbered 1,2,3,...etc.) |
lambda |
The shrinkage parameter |
LASSO |
The regression parameter after regressing all drugs to the event in question |
Returns the log-likelihood of the bimodal negative binomial model
used by the Gamma Poisson shrinker (GPS()
), see function
fitPriorParametersGPS()
. The function is written such
that it can be used by the base function nlminb()
.
loglikelihood2NegativeBinomial(p, a, E)
loglikelihood2NegativeBinomial(p, a, E)
p |
A vector with the parameters ( |
a |
A vector with the number of reports for each of the drug-event pairs |
E |
A vector (of the same length as |
The negative log-likelihood (i.e., -1 * log-likelihood)
DuMouchel, W. (1999). Bayesian Data Mining in Large Frequency Tables, with an Application to the FDA Spontaneous Reporting System. The American Statistician, 53(3), 177–190. https://doi.org/10.1080/00031305.1999.10474456
DuMouchel, W., & Pregibon, D. (2001). Empirical bayes screening for multi-item associations. Proceedings of the Seventh ACM SIGKDD International Conference on Knowledge Discovery and Data Mining - KDD ’01, (October), 67–76. http://doi.org/10.1145/502512.502526
GPS()
, fitPriorParametersGPS()
, dbinbinom()
alpha1 <- 0.2 beta1 <- 0.06 alpha2 <- 1.4 beta2 <- 1.8 w <- 0.1 a <- c(5, 1, 56, 3) E <- c(3.4, 0.5, 10, 0.5) p <- c(alpha1, beta1, alpha2, beta2, w) loglikelihood2NegativeBinomial(p, a, E) #[1] 16.80512
alpha1 <- 0.2 beta1 <- 0.06 alpha2 <- 1.4 beta2 <- 1.8 w <- 0.1 a <- c(5, 1, 56, 3) E <- c(3.4, 0.5, 10, 0.5) p <- c(alpha1, beta1, alpha2, beta2, w) loglikelihood2NegativeBinomial(p, a, E) #[1] 16.80512
Performs the log-likelihood ratio test for a collection of 2 x 2 tables of the form
event | not event | |
drug | a |
c
|
not drug | b |
d
|
logLikelihoodRatioBinomial(a, b, c, d)
logLikelihoodRatioBinomial(a, b, c, d)
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
The log-likelihood ratio
Lian Duan, Khoshneshin, M., Street, W. N., & Mei Liu. (2013). Adverse drug effect detection. IEEE Journal of Biomedical and Health Informatics, 17(2), 305–11. https://doi.org/10.1109/TITB.2012.2227272
A safe way to compare two floating point numbers. The function
is based on the near
function in the dplyr
package.
near(x, y, tol = .Machine$double.eps^0.5)
near(x, y, tol = .Machine$double.eps^0.5)
x , y
|
Numeric vectors to compare |
tol |
Tolerance of comparison (Default: sqrt of the machine precision) |
TRUE
when x
and y
are near, otherwise FALSE
Performs the test of the Poisson mean to a collection of 2 x 2 tables of the form
event | not event | |
drug | a |
c
|
not drug | b |
d
|
PoissonTest(a, b, c, d)
PoissonTest(a, b, c, d)
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
p-value
Determines the proportional reporting rate to a collection of 2 x 2 tables of the form
event | not event | |
drug | a |
c
|
not drug | b |
d
|
In case the parameter alpha
is set, it returns
the lower endpoint of the percent confidence interval.
PRR(a, b, c, d, alpha = NULL)
PRR(a, b, c, d, alpha = NULL)
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
alpha |
Value between |
The PRR or the lower endpoint of the confidence interval
Determines the ROR for a collection of 2 x 2 tables of the form:
event | not event | |
drug | a |
c
|
not drug | b |
d
|
In case the parameter alpha
is set, it returns
the lower endpoint of the percent confidence interval.
ROR(a, b, c, d, alpha = NULL)
ROR(a, b, c, d, alpha = NULL)
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
alpha |
Value between |
The ROR or the lower endpoint of the confidence interval of the ROR
Determines the RRR for a collection of 2 x 2 tables of the form
event | not event | |
drug | a |
c
|
not drug | b |
d
|
RRR(a, b, c, d)
RRR(a, b, c, d)
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
The RRR
A simulated spontaneous reporting data set generated with the SRSim simulator. The data set contains 10,000 reports for 10 drugs and 10 adverse events (AEs). Five drug-AE pairs are associated with an odds ratio of 2. All other drug-AE pairs have an odds ratio of 1. Five drugs are innocent bystanders, i.e., they are prescribed together with one other drug, but they do not cause any adverse events.
srdata
srdata
srdata
contains the following elements:
A binary data frame with 10,000 rows and 20 columns. The first
10 columns represent the drugs; the latter represent the events.
Each row is a report. In case of a 1, the drug/event has been reported,
zero otherwise. The column names are
drug1
till drug10
and event1
till event10
.
The directed acycled graph as an igraph
object
A tibble with all the information on each node/variate:
label
The label for each node/variate
in_degree
The number of edges pointing to the node
id
The ID of each node (simple integer)
parent_id
The ID of the parent node - if any. Otherwise equal to -1
margprob
The marginal probability of the node/variate
beta0
The intercept in the logistic regression model for that node
beta1
The regression coefficient in the logistic regression model for the parent
A vector with marginal probabilities of the drugs
A vector with marginal probabilities of the events
A data frame with 100 rows. Each row contains the data on a drug-event pair. The columns represent:
drug_id
The ID of the drug
event_id
The ID of the event
prob_drug
The marginal probability of that drug
prob_event
The marginal probability of that event
or
The odds ratio
associated
TRUE
is there is a non-zero correlation, FALSE
otherwise
a
Number of times the drug and event appeared together in a report
b
Number of times the event appeared without the drug in a report
c
Number of times the drug appeared without the event in a report
d
Number of times the drug and event both did not appear in a report
The marginal probabilities over the drugs and the AEs were drawn
from a Beta distribution with parameters and
.
The conditional probability of an innocent bystander given that
the other drug is prescribed is set to .9 (this is regulated with
the argument bystander_prob
).
The following commands were used for generating the data set:
library(SRSim) srdata <- SRSim::simulateSRS(n_reports = 10000, n_drugs = 10, n_events = 10, n_innocent_bystanders = 5, bystander_prob = 0.9, n_correlated_pairs = 5, theta = 2, seed = 1) # create the 2x2 tables srdata$tables <- SRSim::convert2Tables(srdata) ```
Determines Yule's Q for a collection of 2 x 2 tables of the form
event | not event | |
drug | a |
c
|
not drug | b |
d
|
In case the parameter alpha
is set, it returns
the lower endpoint of the percent confidence interval.
YulesQ(a, b, c, d, alpha = NULL)
YulesQ(a, b, c, d, alpha = NULL)
a |
A vector with the counts of the upper left corner of the tables |
b |
A vector with the counts of the lower left corner of the tables |
c |
A vector with the counts of the upper right corner of the tables |
d |
A vector with the counts of the lower right corner of the tables |
alpha |
Value between |
Yule's Q or the lower endpoint of the confidence interval