Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://inbo.github.io/effectclass/
Interpret effects and visualise uncertainty
https://inbo.github.io/effectclass/
effect-size fan-chart r r-package r-stats
Last synced: 3 months ago
JSON representation
Interpret effects and visualise uncertainty
- Host: GitHub
- URL: https://inbo.github.io/effectclass/
- Owner: inbo
- License: gpl-3.0
- Created: 2019-05-22T08:44:06.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-02-28T15:06:10.000Z (12 months ago)
- Last Synced: 2024-05-01T12:39:51.233Z (10 months ago)
- Topics: effect-size, fan-chart, r, r-package, r-stats
- Language: R
- Homepage: https://effectclass.netlify.com
- Size: 5.21 MB
- Stars: 3
- Watchers: 7
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Citation: CITATION.cff
Awesome Lists containing this project
- awesome-ggplot2 - effectclass
README
# effectclass
[data:image/s3,"s3://crabby-images/50e01/50e01ab16b24ac988524a7b9a87465ea9a5415fc" alt="Project Status: Active – The project has reached a stable, usable state and is being actively developed."](https://www.repostatus.org/#active)
[data:image/s3,"s3://crabby-images/9460a/9460ae64cb1599ed0094f86a4ee22a80c809511e" alt="Lifecycle: stable"](https://lifecycle.r-lib.org/articles/stages.html#stable)
data:image/s3,"s3://crabby-images/7bf7f/7bf7f7868f67c9d312807b30578242738e88e6fd" alt="GitHub"
[data:image/s3,"s3://crabby-images/1b568/1b568e9f138cba7a9c2a1e5599fcb0fd2f43b3af" alt="License"](https://www.gnu.org/licenses/gpl-3.0.html)
[data:image/s3,"s3://crabby-images/ae29f/ae29f73c51744a26d6eddfc058631e4776fdfe36" alt="Release"](https://github.com/inbo/effectclass/releases)
[data:image/s3,"s3://crabby-images/bdc63/bdc63680a9cfefe4d0085950f316bcf038ffe939" alt="R build status"](https://github.com/inbo/effectclass/actions)
data:image/s3,"s3://crabby-images/efeba/efeba36973d377f508bf63b048ed19805ef8b40c" alt="r-universe name"
data:image/s3,"s3://crabby-images/d1398/d139843d72c1a76bb7fcffa3ff5ca03f93d25593" alt="r-universe package"
[data:image/s3,"s3://crabby-images/a0dc7/a0dc7c55fd8e5de4d34b3851dcec88e2aca33937" alt="Codecov test coverage"](https://app.codecov.io/gh/inbo/effectclass?branch=main)
data:image/s3,"s3://crabby-images/64378/64378cb9e5e5a809532f62805f8dc545a2c898dd" alt="GitHub code size in bytes"
data:image/s3,"s3://crabby-images/8ea32/8ea32ff017273bb628bd4d9fdd97d91fc2923300" alt="GitHub repo size"The `effectclass` package helps interpreting effects and visualising uncertainty.
It classifies the effects by comparing a coverage interval with a reference, lower and upper threshold. The result is a 10 scale classification of the effect. You can reduced it to a 4 scale classification. `effectclass` provides `stat_effect()` and `scale_effect()` to visualise the effects as points with different shapes.
The Bank of England visualises uncertainty by using a fan plot^[Britton, E.; Fisher, P. & J. Whitley (1998). [The Inflation Report Projections: Understanding the Fan Chart](https://www.bankofengland.co.uk/-/media/boe/files/quarterly-bulletin/1998/the-inflation-report-projections-understanding-the-fan-chart). Bank of England Quarterly Bulletin. Retrieved 2019-05-22.]. Instead of displaying a single coverage interval, they recommend to display a bunch of coverage intervals with different levels of transparency.
## Installation
You can install the released version of `effectclass` from [GitHub](https://github.com/inbo/effectclass) with:
``` r
# installation requires the "remotes" package
# install.package("remotes")remotes::install_github("inbo/effectclass")
```## Example
Classifying effect for usage in a table
``` r
library(effectclass)
z <- data.frame(
effect = c("unknown\neffect", "potential\npositive\neffect",
"potential\nnegative\neffect", "no effect", "positive\neffect",
"negative\neffect", "moderate\npositive\neffect",
"moderate\nnegative\neffect", "strong\npositive\neffect",
"strong\nnegative\neffect"),
estimate = c( 0, 0, 0, 0, 1, -1, 0.5, -0.5, 1.5, -1.5),
lcl = c(-2, -0.9, -2, -0.9, 0.1, -2, 0.1, -0.9, 1.1, -2),
ucl = c( 2, 2, 0.9, 0.9, 2, -0.1, 0.9, -0.1, 2, -1.1)
)
classification(z$lcl, z$ucl, threshold = c(-1, 1), reference = 0)
```Adding a classification to a plot
``` r
library(ggplot2)
ggplot(z, aes(x = effect, y = estimate, ymin = lcl, ymax = ucl)) +
stat_effect(threshold = c(-1, 1), reference = 0, size = 3)
```Creating a fan plot
``` r
z <- data.frame(year = 1990:2019, dx = rnorm(30), s = rnorm(30, 1, 0.05))
z$index <- cumsum(z$dx)
library(ggplot2)
ggplot(z, aes(x = year, y = index, link_sd = s)) + stat_fan() + geom_line()
```