Data Science Stream

Topic 4B: Data Visualisation III


Example R code solutions for the Data Science Computer Lab 4, which uses data from the palmerpenguins package (Horst, Hill, and Gorman 2020), and the plotly (Sievert 2020), are presented below.

This computer lab was designed to run alongside the content in Section 5 of the Data Visualisation in R supplement. It might be helpful to have this content open while you look through these solutions.

1 Preparation

1.1

library(palmerpenguins)
library(plotly)

1.2

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)"))

2 Adding Range Sliders to plotly Plots

2.1

penguins_scatter %>% rangeslider()

2.2

No answer required.

2.3

No answer required.

3 Creating animated plotly Plots in RStudio

3.1

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

3.2

No answer required.

3.3

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.

4 Creating Combined plotly Plots in RStudio

4.1

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")

4.2

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

4.3

Example code and output is shown below:

penguin_combined_plots %>% layout(legend = list(title = list(
                                    text ="Sex and Island Information")))

4.4

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.

5 Extension: Adding Buttons to plotly Plots

5.1

No answer required.

5.2

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

5.3

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 = "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 

5.4

No answer required.

5.5

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 

5.6

penguins_plots %>% layout(barmode ="overlay")

5.7

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")

5.8

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()

5.9

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>