# ggbump **Repository Path**: youmigo/ggbump ## Basic Information - **Project Name**: ggbump - **Description**: 备份,不用。 地铁图,地铁连线图。小水流图 - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 1 - **Forks**: 0 - **Created**: 2020-11-02 - **Last Updated**: 2024-06-01 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # ggbump [![Lifecycle: experimental](https://img.shields.io/badge/lifecycle-maturing-blue.svg)](https://www.tidyverse.org/lifecycle/#maturing) [![CRAN status](https://www.r-pkg.org/badges/version/ggbump)](https://CRAN.R-project.org/package=ggbump) [![R build status](https://github.com/HaydenMacDonald/ggbump/workflows/R-CMD-check/badge.svg)](https://github.com/HaydenMacDonald/ggbump/actions) \[![CRAN Downloads](https://cranlogs.r-pkg.org/badges/ggbump) The R package `ggbump` creates elegant bump charts in ggplot. Bump charts are good to use to plot ranking over time, or other examples when the path between two nodes have no statistical significance. Also includes functions to create custom smooth lines called sigmoid curves. ## Installation You can install ggbump from CRAN with: ``` r install.packages("ggbump") ``` Or the latest development version from [github](https://github.com/davidsjoberg/ggbump) with: ``` r devtools::install_github("davidsjoberg/ggbump") ``` ## Bump chart examples Basic example: A more advanced example: ![Example2](https://user-images.githubusercontent.com/44140737/75692519-fb146b00-5ca5-11ea-85f5-9fc33e760a7d.png) [Click here for code to the plot above](https://github.com/davidsjoberg/ggbump/wiki/My-year-on-Spotify) Flags could be used instead of names: ![Example3](https://user-images.githubusercontent.com/44140737/76630573-8f04f300-6540-11ea-802a-653e3b509dfa.png) [Click here for code to the plot above](https://github.com/davidsjoberg/ggbump/wiki/geom_bump-with-flags) ## Sigmoid curves examples With `geom_sigmoid` you can make custom sigmoid curves: ![Example4](https://user-images.githubusercontent.com/44140737/79050627-9268c880-7c2b-11ea-9afb-263cce8f98f3.png) [Click here for code to the plot above](https://github.com/davidsjoberg/ggbump/wiki/geom_sigmoid) With `geom_sigmoid` you have the flexibility to make more complex plots: ![Example5](man/figures/ranking_gdpr.png?raw=true) [Click here for code to the plot above](https://github.com/davidsjoberg/tidytuesday/blob/master/2020w17/2020w17_skript.R) # Tutorial ## Prep Load packages and get some data with rank: ``` r if(!require(pacman)) install.packages("pacman") library(ggbump) pacman::p_load(tidyverse, cowplot, wesanderson) df <- tibble(country = c("India", "India", "India", "Sweden", "Sweden", "Sweden", "Germany", "Germany", "Germany", "Finland", "Finland", "Finland"), year = c(2011, 2012, 2013, 2011, 2012, 2013, 2011, 2012, 2013, 2011, 2012, 2013), value = c(492, 246, 246, 369, 123, 492, 246, 369, 123, 123, 492, 369)) knitr::kable(head(df)) ``` | country | year | value | | :------ | ---: | ----: | | India | 2011 | 492 | | India | 2012 | 246 | | India | 2013 | 246 | | Sweden | 2011 | 369 | | Sweden | 2012 | 123 | | Sweden | 2013 | 492 | To create a ranking column we use `rank` from base R. We specify `ties.method = "random"` to make sure that each country have different rankings if they have the same value. ``` r df <- df %>% group_by(year) %>% mutate(rank = rank(value, ties.method = "random")) %>% ungroup() knitr::kable(head(df)) ``` | country | year | value | rank | | :------ | ---: | ----: | ---: | | India | 2011 | 492 | 4 | | India | 2012 | 246 | 2 | | India | 2013 | 246 | 2 | | Sweden | 2011 | 369 | 3 | | Sweden | 2012 | 123 | 1 | | Sweden | 2013 | 492 | 4 | ## Make a bump chart Most simple use case: ``` r ggplot(df, aes(year, rank, color = country)) + geom_bump() ``` ## Pimp the bump chart\! Improve the bump chart by adding: - A point for each rank observation. - Choose a minimal theme, I use `theme_minimal_grid()` from `cowplot`. - Choose nice colors so it does not look generic ggplot. I use a palette from `wesanderson`. - Remove legend and add labels at the start and end of the bumpy ride. - Reverse the y-axis to get rank 1 at the top. - Adjust the ‘smoothness’ of the lines by setting `smooth` to 8. Higher means less smooth. ``` r ggplot(df, aes(year, rank, color = country)) + geom_point(size = 7) + geom_text(data = df %>% filter(year == min(year)), aes(x = year - .1, label = country), size = 5, hjust = 1) + geom_text(data = df %>% filter(year == max(year)), aes(x = year + .1, label = country), size = 5, hjust = 0) + geom_bump(size = 2, smooth = 8) + scale_x_continuous(limits = c(2010.6, 2013.4), breaks = seq(2011, 2013, 1)) + theme_minimal_grid(font_size = 14, line_size = 0) + theme(legend.position = "none", panel.grid.major = element_blank()) + labs(y = "RANK", x = NULL) + scale_y_reverse() + scale_color_manual(values = wes_palette(n = 4, name = "GrandBudapest1")) ``` ## geom\_bump with factors (development version only) You can use `geom_bump` with factors or character as x axis. Just remember to keep an eye on factor order. ``` r # Original df df <- tibble(season = c("Spring", "Pre-season", "Summer", "Season finale", "Autumn", "Winter", "Spring", "Pre-season", "Summer", "Season finale", "Autumn", "Winter", "Spring", "Pre-season", "Summer", "Season finale", "Autumn", "Winter", "Spring", "Pre-season", "Summer", "Season finale", "Autumn", "Winter"), rank = c(1, 3, 4, 2, 1, 4, 2, 4, 1, 3, 2, 3, 4, 1, 2, 4, 4, 1, 3, 2, 3, 1, 3, 2), player = c(rep("David", 6), rep("Anna", 6), rep("Franz", 6), rep("Ika", 6))) # Create factors and order factor df <- df %>% mutate(season = factor(season, levels = unique(season))) # Add manual axis labels to plot ggplot(df, aes(season, rank, color = player)) + geom_bump(size = 2, smooth = 20, show.legend = F) + geom_point(size = 5, aes(shape = player)) + theme_minimal_grid(font_size = 10, line_size = 0) + theme(panel.grid.major = element_blank(), axis.ticks = element_blank()) + scale_color_manual(values = wes_palette(n = 4, name = "IsleofDogs1")) ``` ## Feedback If you find any error or have suggestions for improvements you are more than welcome to contact me :)