Data Science Stream
Preparation
library(palmerpenguins)
library(plotly)
R code is provided in the code chunk below.
penguins_scatter <- plot_ly(data = penguins,
x = ~body_mass_g, y = ~flipper_length_mm,
color = ~sex, colors = "Set1",
type = "scatter", mode = "markers")
penguins_scatter <- penguins_scatter %>%
layout(title = "Scatter Plot of Penguin Data",
legend=list(title=list(text='Sex')),
xaxis = list(title = "Penguin Body Mass (grams)"),
yaxis = list(title = "Penguin Flipper Length (mm)"))
Adding Range Sliders to plotly
Plots
penguins_scatter %>% rangeslider()
Creating animated plotly
Plots in RStudio
Example code and output is shown below:
penguins_scatter_anim <- plot_ly(data = penguins,
x = ~body_mass_g, y = ~flipper_length_mm,
frame = ~year,
color = ~sex, colors = "Set1",
type = "scatter", mode = "markers")
penguins_scatter_anim <- penguins_scatter_anim %>%
layout(title = "Animated Scatter Plot of Penguin Data",
legend=list(title=list(text='Sex')),
xaxis = list(title = "Penguin Body Mass (grams)"),
yaxis = list(title = "Penguin Flipper Length (mm)"))
penguins_scatter_anim
Example code and output is shown below:
penguins_scatter_anim2 <- plot_ly(data = penguins,
x = ~body_mass_g, y = ~flipper_length_mm,
frame = ~species, text = ~year,
color = ~sex, colors = "Set1",
type = "scatter", mode = "markers")
penguins_scatter_anim2 <- penguins_scatter_anim2 %>%
layout(title = "Animated Scatter Plot of Penguin Data",
legend=list(title=list(text='Sex')),
xaxis = list(title = "Penguin Body Mass (grams)"),
yaxis = list(title = "Penguin Flipper Length (mm)"))
penguins_scatter_anim2
We notice that the Adelie and Chinstrap penguins have a similar range of body_mass_g
values, while the Gentoo penguins are typically much heavier.
Creating Combined plotly
Plots in RStudio
R code is provided in the code chunk below.
penguin_hist <- plot_ly(data = penguins,
x = ~body_mass_g,
color = ~island,
type = "histogram", alpha = 0.6)
penguin_hist <- penguin_hist %>% layout(yaxis = list(title = 'count'),
barmode ="overlay")
penguin_combined_plots <- subplot(penguins_scatter, penguin_hist,
nrows = 2, margin = 0.05)
penguin_combined_plots <- penguin_combined_plots %>%
layout(title = "Palmer Penguin Data",
xaxis = list(title = 'body_mass_g'),
yaxis = list(title = "flipper_length_mm"),
xaxis2 = list(title = 'body_mass_g'),
yaxis2 = list(title = "count"))
penguin_combined_plots
Example code and output is shown below:
penguin_combined_plots %>% layout(legend = list(title = list(
text ="Sex and Island Information")))
Example code and output is shown below:
penguin_box <- plot_ly(data = penguins,
x = ~species,
y = ~body_mass_g,
color = ~sex, colors = "Set1",
type = "box") %>% layout(boxmode = "group")
penguin_combined_plots2 <- subplot(penguins_scatter,
penguin_hist,
penguin_box,
nrows = 3, margin = 0.05)
penguin_combined_plots2 <- penguin_combined_plots2 %>%
layout(title = "Palmer Penguin Data",
legend = list(title = list(
text ="Sex and Island Information")),
xaxis = list(title = 'body_mass_g'),
yaxis = list(title = "flipper_length_mm"),
xaxis2 = list(title = 'body_mass_g'),
yaxis2 = list(title = "count"),
xaxis3 = list(title = 'species'),
yaxis3 = list(title = "body_mass_g"))
penguin_combined_plots2
Note that the colours have been specified to match those in the scatter plot, for consistency.
Extension: Adding Buttons to plotly
Plots
Example code and output is shown below:
penguins_plots <- plot_ly(data = penguins,
x = ~body_mass_g,
color = ~sex,
colors = "Set1",
opacity = 0.6) %>%
layout(
title = "Penguin's Body Mass Data",
updatemenus = list(
list(x = 1.2, y = 0.7, type = "dropdown",
# We really just have to focus on the code below
buttons = list(
list(method = "restyle",
label = "Histogram", # The button label
args = list(
list(type = list("histogram")))), # The plot type
list(method = "restyle",
label = "Box Plots",
args = list(
list(type = list("box"))))
))))
penguins_plots
penguins_plots %>% layout(barmode ="overlay")
Example code and output is shown below:
penguins_plots <- plot_ly(data = penguins,
x = ~body_mass_g,
color = ~sex,
colors = "Set1",
opacity = 0.6) %>%
layout(
title = "Penguin's Body Mass Data",
updatemenus = list(
list(x = 1.2, y = 0.7, type = "dropdown",
# We really just have to focus on the code below
buttons = list(
list(method = "restyle",
label = "Histogram", # The button label
args = list(
list(type = list("histogram")))), # The plot type
list(method = "restyle",
label = "Box Plots",
args = list(
list(type = list("box")))),
list(method = "restyle",
label = "Violin Plots",
args = list(
list(type = list("violin"),
box = list(visible = T ))))
))))
penguins_plots %>% layout(barmode ="overlay")
Example code and output is shown below:
penguins_plots2 <- plot_ly(data = penguins,
x = ~bill_length_mm,
color = ~species,
colors = "Set1",
opacity = 0.6) %>%
layout(
title = "Penguin's Bill Length Data",
updatemenus = list(
list(x = 1.2, y = 0.7, type = "dropdown",
# We really just have to focus on the code below
buttons = list(
list(method = "restyle",
label = "Violin Plots",
args = list(
list(type = list("violin"),
box = list(visible = T )))),
list(method = "restyle",
label = "Box Plots",
args = list(
list(type = list("box")))),
list(method = "restyle",
label = "Histogram",
args = list(
list(type = list("histogram"))))
))))
penguins_plots2 %>% layout(barmode ="overlay") %>% rangeslider()
No answer required.
That’s everything covered, well done!
References
Horst, Allison Marie, Alison Presmanes Hill, and Kristen B Gorman. 2020.
Palmerpenguins: Palmer Archipelago (Antarctica) Penguin Data.
https://doi.org/10.5281/zenodo.3960218.
Sievert, Carson. 2020.
Interactive Web-Based Data Visualization with r, Plotly, and Shiny. Chapman; Hall/CRC.
https://plotly-r.com.
These notes have been prepared by Rupert Kuveke. The copyright for the material in these notes resides with the author named above, with the Department of Mathematical and Physical Sciences and with La Trobe University. Copyright in this work is vested in La Trobe University including all La Trobe University branding and naming. Unless otherwise stated, material within this work is licensed under a Creative Commons Attribution-Non Commercial-Non Derivatives License
BY-NC-ND.
---
title: "STM1001: Computer Lab 4B Solutions"
output:
  bookdown::html_document2: 
    toc: true
    toc_float: true
    code_download: true
    theme: readable
    code_folding: show
bibliography: STM1001_DS_CL_references.bib 
link-citations: yes
---

<style>
#TOC {
  background: url("https://www.latrobe.edu.au/_media/la-trobe-api/v5/img/logo.svg");
  background-size: contain;
  padding-top: 80px !important;
  background-repeat: no-repeat;
}
</style>

### Data Science Stream {-}

### Topic 4B: Data Visualisation III {-}

<br>

Example R code solutions for the [Data Science Computer Lab 4](https://rpubs.com/LTU_STM1001/DSMCL4), which uses data from the `palmerpenguins` package [@penguins], and the `plotly` [@plotly], are presented below.

This computer lab was designed to run alongside the content in [Section 5 of the Data Visualisation in R supplement](https://bookdown.org/rehk/stm1001_dsm_data_visualisation_in_r/advanced-plotly-computer-lab-4b.html). It might be helpful to have this content open while you look through these solutions.

# Preparation

##

```{r class.source = "fold-show", eval = F, echo = T}
library(palmerpenguins)
library(plotly)
```

```{r class.source = "fold-show", eval = T, include = F}
library(palmerpenguins)
library(plotly)
```


```{r class.source = "fold-show", eval = T, include = F}
penguins <- na.omit(penguins)
```

##

R code is provided in the code chunk below.

```{r class.source = "fold-hide", eval = T, echo = T}
penguins_scatter <- plot_ly(data = penguins, 
                            x = ~body_mass_g, y = ~flipper_length_mm, 
                            color = ~sex, colors = "Set1",
                            type = "scatter", mode = "markers")

penguins_scatter <- penguins_scatter %>% 
                        layout(title = "Scatter Plot of Penguin Data", 
                               legend=list(title=list(text='Sex')),
                               xaxis = list(title = "Penguin Body Mass (grams)"),
                               yaxis = list(title = "Penguin Flipper Length (mm)"))
```

# Adding Range Sliders to `plotly` Plots {#slider} 

## {#sliderstart}

```{r class.source = "fold-show", eval = T, echo = T}
penguins_scatter %>% rangeslider()
```

##

No answer required.

##

No answer required.

# Creating animated `plotly` Plots in RStudio {#animations}

##

Example code and output is shown below:

```{r class.source = "fold-show", eval = T, echo = T}
penguins_scatter_anim <- plot_ly(data = penguins, 
                            x = ~body_mass_g, y = ~flipper_length_mm, 
                            frame = ~year,
                            color = ~sex, colors = "Set1",
                            type = "scatter", mode = "markers")

penguins_scatter_anim <- penguins_scatter_anim %>% 
                        layout(title = "Animated Scatter Plot of Penguin Data", 
                               legend=list(title=list(text='Sex')),
                               xaxis = list(title = "Penguin Body Mass (grams)"),
                               yaxis = list(title = "Penguin Flipper Length (mm)"))

penguins_scatter_anim
```

##

No answer required.

##

Example code and output is shown below:

```{r class.source = "fold-show", eval = T, echo = T}
penguins_scatter_anim2 <- plot_ly(data = penguins, 
                            x = ~body_mass_g, y = ~flipper_length_mm, 
                            frame = ~species, text = ~year,
                            color = ~sex, colors = "Set1",
                            type = "scatter", mode = "markers")

penguins_scatter_anim2 <- penguins_scatter_anim2 %>% 
                        layout(title = "Animated Scatter Plot of Penguin Data", 
                               legend=list(title=list(text='Sex')),
                               xaxis = list(title = "Penguin Body Mass (grams)"),
                               yaxis = list(title = "Penguin Flipper Length (mm)"))

penguins_scatter_anim2
```

We notice that the Adelie and Chinstrap penguins have a similar range of `body_mass_g` values, while the Gentoo penguins are typically much heavier.

# Creating Combined `plotly` Plots in RStudio {#subplots}

## {#subplotwalkthrough}

R code is provided in the code chunk below.

```{r class.source = "fold-hide", eval = T, echo = T, warning = F, message = F, fig.align = "center"}
penguin_hist <- plot_ly(data = penguins, 
                        x = ~body_mass_g, 
                        color = ~island, 
                        type = "histogram", alpha = 0.6)

penguin_hist <- penguin_hist %>% layout(yaxis = list(title = 'count'), 
                                        barmode ="overlay")
```

## {#combined}

```{r class.source = "fold-show", eval = T, echo = T, warning = F, message = F, fig.align = "center", fig.dim = c(8, 8)}
penguin_combined_plots <- subplot(penguins_scatter, penguin_hist, 
                                  nrows = 2, margin = 0.05) 
penguin_combined_plots <- penguin_combined_plots %>% 
                            layout(title = "Palmer Penguin Data",
                                   xaxis = list(title = 'body_mass_g'), 
                                   yaxis = list(title = "flipper_length_mm"),
                                   xaxis2 = list(title = 'body_mass_g'), 
                                   yaxis2 = list(title = "count"))
penguin_combined_plots
```

##

Example code and output is shown below:

```{r class.source = "fold-show", eval = T, echo = T, warning = F, message = F, fig.align = "center", fig.dim = c(8, 8)}
penguin_combined_plots %>% layout(legend = list(title = list(
                                    text ="Sex and Island Information")))
```

## {#boxplotsubplot}

Example code and output is shown below:

```{r class.source = "fold-show", eval = T, echo = T, warning = F, message = F, fig.align = "center", fig.dim = c(8, 12)}

penguin_box <- plot_ly(data = penguins, 
                        x = ~species,
                       y = ~body_mass_g,
                        color = ~sex, colors = "Set1",
                        type = "box") %>% layout(boxmode = "group")

penguin_combined_plots2 <- subplot(penguins_scatter, 
                                   penguin_hist, 
                                   penguin_box,
                                  nrows = 3, margin = 0.05) 
penguin_combined_plots2 <- penguin_combined_plots2 %>% 
                            layout(title = "Palmer Penguin Data",
                                   legend = list(title = list(
                                    text ="Sex and Island Information")),
                                   xaxis = list(title = 'body_mass_g'), 
                                   yaxis = list(title = "flipper_length_mm"),
                                   xaxis2 = list(title = 'body_mass_g'), 
                                   yaxis2 = list(title = "count"), 
                                   
                                   xaxis3 = list(title = 'species'), 
                                   yaxis3 = list(title = "body_mass_g"))

penguin_combined_plots2 
```

Note that the colours have been specified to match those in the scatter plot, for consistency.

# Extension: Adding Buttons to `plotly` Plots {#button}

##

No answer required.

## {#buttonsplot}

```{r class.source = "fold-show", eval = T, echo = T, warning = F, message = F}
penguins_plots <- plot_ly(data = penguins, 
                          x = ~body_mass_g, 
                          color = ~sex, 
                          colors = "Set1", 
                          opacity = 0.6) %>% 
  layout(
    title = "Penguin's Body Mass Data",
    updatemenus = list(
      list(x = 1.2, y = 0.7, type = "buttons", 
         
           # We really just have to focus on the code below   
         buttons = list(
           
          list(method = "restyle",
               label = "Histogram", # The button label
               args = list(
                list(type = list("histogram")))) # The plot type
    ))))

penguins_plots
```
 
## {#addbutton}

Example code and output is shown below:

```{r class.source = "fold-show", eval = T, echo = T, warning = F, message = F}
penguins_plots <- plot_ly(data = penguins, 
                          x = ~body_mass_g, 
                          color = ~sex, 
                          colors = "Set1", 
                          opacity = 0.6) %>% 
  layout(
    title = "Penguin's Body Mass Data",
    updatemenus = list(
      list(x = 1.2, y = 0.7, type = "buttons", 
           
         # We really just have to focus on the code below   
         buttons = list(
           
          list(method = "restyle",
               label = "Histogram", # The button label
               args = list(
                list(type = list("histogram")))), # The plot type
          
          list(method = "restyle",
               label = "Box Plots",
               args = list(
                list(type = list("box"))))
    ))))

penguins_plots 
```

## {#twobuttons}

No answer required.

##

Example code and output is shown below:

```{r class.source = "fold-show", eval = T, echo = T, warning = F, message = F}
penguins_plots <- plot_ly(data = penguins, 
                          x = ~body_mass_g, 
                          color = ~sex, 
                          colors = "Set1", 
                          opacity = 0.6) %>% 
  layout(
    title = "Penguin's Body Mass Data",
    updatemenus = list(
      list(x = 1.2, y = 0.7, type = "dropdown", 
           
         # We really just have to focus on the code below   
         buttons = list(
           
          list(method = "restyle",
               label = "Histogram", # The button label
               args = list(
                list(type = list("histogram")))), # The plot type
          
          list(method = "restyle",
               label = "Box Plots",
               args = list(
                list(type = list("box"))))
    ))))

penguins_plots 
```

##

```{r class.source = "fold-show", eval = T, echo = T, warning = F, message = F}
penguins_plots %>% layout(barmode ="overlay")
```

##

Example code and output is shown below:

```{r class.source = "fold-show", eval = T, echo = T, warning = F, message = F}
penguins_plots <- plot_ly(data = penguins, 
                          x = ~body_mass_g, 
                          color = ~sex, 
                          colors = "Set1", 
                          opacity = 0.6) %>% 
  layout(
    title = "Penguin's Body Mass Data",
    updatemenus = list(
      list(x = 1.2, y = 0.7, type = "dropdown", 
           
         # We really just have to focus on the code below   
         buttons = list(
           
          list(method = "restyle",
               label = "Histogram", # The button label
               args = list(
                list(type = list("histogram")))), # The plot type
          
          list(method = "restyle",
               label = "Box Plots",
               args = list(
                list(type = list("box")))),
          
          list(method = "restyle",
               label = "Violin Plots",
               args = list(
                list(type = list("violin"),
                     box = list(visible = T ))))
    ))))

penguins_plots %>% layout(barmode ="overlay")
```

##

Example code and output is shown below:

```{r class.source = "fold-show", eval = T, echo = T, warning = F, message = F}
penguins_plots2 <- plot_ly(data = penguins, 
                           x = ~bill_length_mm, 
                           color = ~species, 
                           colors = "Set1", 
                           opacity = 0.6) %>% 
  layout(
    title = "Penguin's Bill Length Data",
    updatemenus = list(
      list(x = 1.2, y = 0.7, type = "dropdown", 
           
         # We really just have to focus on the code below   
         buttons = list(
           
          list(method = "restyle",
               label = "Violin Plots",
               args = list(
                list(type = list("violin"),
                     box = list(visible = T )))),
          
          list(method = "restyle",
               label = "Box Plots",
               args = list(
                list(type = list("box")))),
          
          list(method = "restyle",
               label = "Histogram", 
               args = list(
                list(type = list("histogram"))))
    ))))

penguins_plots2 %>% layout(barmode ="overlay") %>% rangeslider()
```

##

No answer required.

<br>


#### That's everything covered, well done! #### {-}

<br>

# References {- #Ref}
<div id="refs"></div>

<br>

<font color = "grey">
These notes have been prepared by Rupert Kuveke. The copyright for the material in these notes resides with the author named above, with the Department of Mathematical and Physical Sciences and with La Trobe University. Copyright in this work is vested in La Trobe University including all La Trobe University branding and naming. Unless otherwise stated, material within this work is licensed under a Creative Commons Attribution-Non Commercial-Non Derivatives License 
<a href = "https://creativecommons.org/licenses/by-nc-nd/4.0/CC" target="_blank"> BY-NC-ND. </a>
</font>