Transdiagnostic Treatment for Depression & Anxiety
Meta-Analytic Database of Randomized Controlled Trials /
© The Metapsy Collaboration
Additional Information
This online meta-analysis tool allows to explore a simplified version of the “Transdiagnostic Psychotherapy Trials for Depression and Anxiety” dataset. It is part of the meta-analytic research domain (MARD) on psychotherapy for depression. The code used to simplify the data for this application can be downloaded here.
Outcome Selection
In the tab "Select outcome" you can decide which of our two outcome variables you are interested in: depression or anxiety.
Not all studies in our database report on both of these outcome variables. Once you have selected in which outcome you are interested, only the studies that report on this outcome will be shown in the table on this page. All the filters that you select in this sidebar will also only affect those studies. You can always go back to "Select Outcome" to select the other outcome.
Meta-Analysis Results
By default, the web application automatically makes a few decisions concerning the analysis settings. These analysis settings can be seen below under "Analysis Settings". By default, the application uses a Random-Effects Pooling Model for your meta-analysis. This is nearly always the correct choice when one is analyzing data in mental health research. In addition, the Restricted Maximum-Likelihood estimator is used by default to calculate the between-study heterogeneity of your meta-analysis. However, when clicking on the dropdown menu "Pooling Model", you can see that there are various estimators available when assuming a Random-Effects (RE) model. Sometimes, the choice of the between-study heterogeneity estimator can have an impact on the pooled results, and not every estimator is optimal under all circumstances. If you want to learn more about this, you can consult Harrer, Cuijpers, Furukawa & Ebert, 2020. It is also possible to calculate effects using a Fixed-Effect Model; but this model should only be used if you have good reasons for applying it.
Under "Analyzed Moderators", the moderating variables which are currently inspected in meta-regression/subgroup analyses in the "Moderator Analysis" tab are shown. By default, the publication year is used for a meta-regression on your selected data, and the country/region of a study is used as a subgroup analysis. You can easily add more moderator analyses by clicking on the white box. A dropdown will then appear, showing you more variables which are available. You can then add those variables by clicking on them. It is also possible to remove variables. To do that, again click on the white box and use the backspace ← key.
By default, the application also uses Knapp-Hartung adjustments to calculate the confidence interval for your meta-analysis result. It is possible to disable this method by unchecking the "Use Knapp-Hartung Adjustments" checkbox. You can learn more about this method in Harrer, Cuijpers, Furukawa & Ebert, 2020.
Finally, after you have completed the reconfiguration of your meta-analysis settings, simply click the "Re-run Meta-Analysis" button. This will reculate the results of your meta-analysis, using the new settings you have provided. Please note that the reanalysis may take some time before it is finished.
Analysis Settings
Main Results
Heterogeneity:
Removed as outliers:
As a sensitivity analysis, it can be helpful to identify potentially outlying studies and how they might affect the pooled result. This is particularly helpful when the heterogeneity of a meta-analysis is high. In this tab, the pooled effect without outlying studies is presented. Especially if the pooled effect without outliers has a lower heterogeneity than the original one, it can be helpful to also take this estimate into account for further decision making. If no outliers are detected, the results in this tab will be identical to the ones in the main analysis.
Subgroup Analysis
About the Metapsy Database Web App
This application was developed by researchers at the Vrije Universiteit Amsterdam, The Netherlands, the Friedrich-Alexander-Universität Erlangen-Nürnberg, Germany, and the Technical University Munich, Germany. The data are based on a meta-analytic database that was developed by researchers at the Vrije Universiteit Amsterdam in the past 14 years.
This project, led by Prof. Pim Cuijpers and Dr. Eirini Karyotaki, has resulted in a long series of published studies in peer-reviewed journals. Researchers from the Friedrich-Alexander-Universität in Germany, led by Mathias Harrer and Dr. David Ebert (Technical University Munich), have developed the web application and the automated analyses that are conducted online.
About the Metapsy Web Application
This web application serves as an interface to the Metapsy meta-analytic database. The application uses a Shiny server instance to access the database, enable data downloads, and handle computations using state-of-the-art meta-analytic techniques.
The meta
(Balduzzi, Rücker & Schwarzer, 2019) and dmetar
(Harrer, Cuijpers, Furukawa & Ebert, 2020) R packages are used to perform the meta-analyses.
The metagen
function is used internally to perform the meta-analytic pooling. By default, the Restricted Maximum-Likelihood estimator (Viechtbauer, 2005) is used to estimate the between-study heterogeneity/variance τ2 in a random-effects model; REML is also used for meta-regressions. To calculate the Number Needed to Treat (NNT), the method by Furukawa and Leucht (Furukawa & Leucht, 2011) is used, assuming Control Event Rate (CER) of 0.19, which is derived from Cuijpers et al., 2014. For subgroup analyses, the subgroup.analysis.mixed.effects
function is used, implementing a mixed-effect model for which results within subgroups are pooled using a random-effects model (inheriting the τ2-estimator specified for the overall analysis), and results between subgroups are compared assuming a fixed-effects model.
To generate forest plots, the forest
function in meta
is used.
Outlier selection is conducted using the find.outliers
function in dmetar
. The function implements a simple outlier removal algorithm where all results for which the 95% confidence interval is outside the 95% confidence interval of the pooled effect are removed as outliers. Due to high computational costs, sensitivity analyses based on the “Leave-One-Out” paradigm are not conducted for large meta-analyses (k>50). For smaller meta-analyses, a Baujat plot (Baujat et al., 2002) is created using the baujat
function in meta
.
Publication bias analyses are conducted using the eggers.test
function in dmetar
(which is a wrapper for the metabias
function in meta
). A P-curve is created using the pcurve
function in dmetar
. Please note that several prerequisites should be considered before P-curves can be interpreted (Simonsohn et al., 2014).
For the risk of bias overview, the rob.summary
function in dmetar
is used.
The metapsyData Package
The metapsyData
package allows you to access the meta-analytic psychotherapy databases in R. To install the package, use the following code:
if (!require("devtools"))
install.packages("devtools")
devtools::install_github("metapsy-project/metapsyData")
The metapsyData
package allows to access the Metapsy meta-analytic psychotherapy databases direct in your R
environment. Once installed, simply run the getData()
function to save the data locally. The documentation of the package is also hosted here.
Here is an example:
library(metapsyData)
library(dplyr)
d <- getData("depression-anxiety-transdiagnostic")
glimpse(d$data)
#> Rows: 122
#> Columns: 70
#> $ study <chr> "Ali, 2003", "Bathgate, 2021", "Bathgate, 2021", "Cal…
#> $ .g <dbl> 0.61, 0.72, 0.92, 0.22, 0.01, 0.40, 0.69, 1.32, 0.83,…
#> $ .g_se <dbl> 0.16, 0.38, 0.39, 0.63, 0.63, 0.20, 0.20, 0.23, 0.21,…
#> $ condition_arm1 <chr> "other psy", "cbt", "cbt", "cbt", "cbt", "3rd", "3rd"…
#> $ condition_arm2 <chr> "cau", "cau", "cau", "cau", "cau", "cau", "cau", "cau…
#> $ multi_arm1 <chr> NA, NA, NA, NA, NA, "ftf MBCT", "internet MBCT", NA, …
#> $ multi_arm2 <chr> NA, NA, NA, NA, NA, "cau", "cau", NA, NA, NA, NA, NA,…
#> $ outcome_type <chr> "msd", "msd", "msd", "msd", "msd", "msd", "msd", "msd…
#> $ sample <chr> "co", "itt", "itt", "co", "co", "itt", "itt", "itt", …
#> $ instrument <chr> "AKUADS", "phq9", "gad-7", "hamd", "hama", "hads", "h…
#> $ rating <chr> "self-report", "self-report", "self-report", "clinici…
#> $ time <chr> "post", "post", "post", "post", "post", "post", "post…
#> $ depanx <chr> "mix", "dep", "anx", "dep", "anx", "mix", "mix", "anx…
#> $ mean_arm1 <dbl> 1844, 407, 421, 1214, 1843, 1369, 1188, 366, 159, 233…
#> $ sd_arm1 <dbl> 7.88, 2.95, 3.51, 7.84, 11.50, 6.84, 6.55, 10.90, 5.1…
#> $ n_arm1 <dbl> 70, 14, 14, 7, 7, 77, 90, 48, 48, 70, 70, 70, 70, 70,…
#> $ mean_arm2 <dbl> 234, 713, 767, 1375, 185, 1648, 1648, 49, 234, 272, 2…
#> $ sd_arm2 <dbl> 8.29, 4.97, 3.75, 3.10, 5.69, 6.89, 6.89, 7.40, 11.60…
#> $ n_arm2 <dbl> 91, 15, 15, 4, 4, 39, 39, 48, 48, 71, 71, 71, 69, 69,…
#> $ precalc_g <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ precalc_g_se <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ dich <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ dich_type <chr> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ event_arm1 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ event_arm2 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ totaln_arm1 <dbl> 124, 15, 15, 10, 10, 77, 90, 50, 50, 75, 75, 75, 75, …
#> $ totaln_arm2 <dbl> 150, 16, 16, 6, 6, 39, 39, 50, 50, 76, 76, 76, 76, 76…
#> $ mean_change_arm1 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ sd_change_arm1 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ n_change_arm1 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ mean_change_arm2 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ sd_change_arm2 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ n_change_arm2 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ baseline_m_arm1 <dbl> 2801, 96, 933, 1729, 2514, 1881, 1724, 558, 23, 291, …
#> $ baseline_sd_arm1 <dbl> 7.88, 5.30, 3.87, 8.30, 10.42, 6.70, 7.07, 11.80, 6.6…
#> $ baseline_n_arm1 <dbl> 70, 15, 15, 7, 7, 77, 90, 50, 50, 75, 75, 75, 74, 74,…
#> $ baseline_m_arm2 <dbl> 2862, 906, 1006, 115, 165, 1704, 1704, 554, 224, 324,…
#> $ baseline_sd_arm2 <dbl> 8.97, 5.37, 3.84, 5.69, 7.05, 5.79, 5.79, 11.20, 6.20…
#> $ baseline_n_arm2 <dbl> 91, 16, 16, 4, 4, 39, 39, 50, 50, 76, 76, 76, 76, 76,…
#> $ other_statistic <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ time_weeks <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ year <dbl> 2003, 2021, 2021, 2015, 2015, 2018, 2018, 2011, 2011,…
#> $ comorbid_mental <chr> "n", "n", "n", "n", "n", "n", "n", "n", "n", "n", "n"…
#> $ format <chr> "ind", "tel", "tel", "oth", "oth", "grp", "gsh", "ind…
#> $ format_details <chr> NA, NA, NA, "ind or tel, patient preference", "ind or…
#> $ n_sessions_arm1 <dbl> 8, 6, 6, 8, 8, 8, 8, 4, 4, 10, 10, 10, 10, 10, 12, 12…
#> $ country <chr> "oth", "us", "us", "us", "us", "eu", "eu", "us", "us"…
#> $ age_group <chr> "adul", "adul", "adul", "adul", "adul", "adul", "adul…
#> $ mean_age <dbl> NA, 32, 32, 63, 63, 52, 52, 64, 64, 41, 41, 41, 41, 4…
#> $ percent_women <dbl> 1.00, 0.81, 0.81, 0.12, 0.12, 0.86, 0.86, 0.22, 0.22,…
#> $ recruitment <chr> "oth", "oth", "oth", "oth", "oth", "com", "com", "oth…
#> $ diagnosis <chr> "cut", "cut", "cut", "mdd", "mdd", "cut", "cut", "cut…
#> $ target_group <chr> "oth", "med", "med", "med", "med", "med", "med", "med…
#> $ sg <dbl> 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,…
#> $ ac <dbl> 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1,…
#> $ ba <chr> "sr", "sr", "sr", "1", "1", "1", "1", "sr", "sr", "sr…
#> $ itt <dbl> 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,…
#> $ rob <dbl> 2, 2, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,…
#> $ no.arms <dbl> 2, 2, 2, 2, 2, 3, 3, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3,…
#> $ is.multiarm <dbl> 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1,…
#> $ primary <dbl> 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0,…
#> $ notes <chr> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ full_ref <chr> "Ali BS, Rahbar MH, Naeem S, Gul A, Mubeen S, Iqbal A…
#> $ .id <chr> "Ali_2003_otherpsy_cau_NA_NA_msd_AKUADS_self-report_p…
#> $ .log_rr <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ .log_rr_se <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ .event_arm1 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ .event_arm2 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ .totaln_arm1 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
#> $ .totaln_arm2 <dbl> NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, N…
The raw data files can be accessed in the associated GitHub repository under data
. To search for available databases in metapsyData
, run the listData()
function.
Citation
You can run citation("metapsyData")
to retrieve the preferred citation.