library(tidyverse)
library(learnr)

Introduction

Hello! I know this is going to seem intimidating, but you get the hang of it very quickly. Before going through this document, open up the tutorial Visualization 1A in RStudio and scroll through to see what the layout of a tutorial looks like.

Also, if you are still confused after reading this document, a great way to learn and familiarize yourself is to actually open up a tutorial file ( go into PPBDS.data, click on the "inst" folder, then open up the "tutorials" folder). If you press "run document" or "knit" in the menu bar of the file, you can then see what the code does visually.

Basic Structure Overview

As you should have seen in Visualization 1A, the beginning of a tutorial requires providing your name and email. The tutorial is then divided into sections that you see as side panels. Within these sections, there are a series of exercises which could include writing code, writing text, or answering multiple choice questions. At the end of the tutorial, there is a submission section that provides students with instructions to submit their work.

Before You Start

  1. Click on "File" in the top menu of your computer, go to 'New File", and click "R Markdown".
  2. Name your tutorial file “tutorial.Rmd”. We name all tutorials this.

Initial Tutorial Set-up

  1. The top of your file should look like the text below (obviously you would change the title, Id, and description parts to correspond with whatever you tutorial is):

Ex. This is what the top of the Chapter 4 tutorial looks like:


title: "Functions" Tutorial: Id: “04-functions” output: learnr:: tutorial: progressive: true allow_skip: true runtime: shiny_prerendered description: "Chapter 4 tutorial"


  1. Next, you want to insert an "r-chunk" ( you do this by going to the menu bar of the file and clicking on "Insert", which has a green square next to it. Copy/ paste all the text below (from 'r-setup' to the last parentheses) into your r-chunk. This sets up the packages to make sure the tutorial functions appropriately.

This is what it should look like:

library(tidyverse)
library(learnr)
library(shiny)
library(PPBDS.data)
knitr::opts_chunk$set(echo = FALSE, message = FALSE)
options(tutorial.exercise.timelimit = 60)  

First Question

Okay, you are all set up. The first question should ask students to give us their name. (This way, when we generate a hash of a student's responses, their name is included in the hash).

You want an r-chunk that looks like this below. (Note: Follow the same steps in #2 for creating an r-chunk!)

Ex.

## Name
``` {r name}
question_text(
  "Student Name:",
  answer(NULL, correct = TRUE),
  allow_retry = TRUE,
  try_again_button = "Modify your answer",
  incorrect = "Ok"
)
```

Second Question

After the name section, the second question should be like the one above, but instead asking for an email.

Ex.

##Email
``` {r email}
question_text(
  "Student Email:”,
  answer(NULL, correct = TRUE),
  allow_retry = TRUE,
  try_again_button = "Modify your answer",
  incorrect = "Ok"
)
```

NOTE: notice how above both r-chunks there is a double hash with text. This causes the text following the hashes to show up as side panels. (this is explained next).

Otherwise....Congrats! You are all done setting up the tutorial. It’s now time to create content.

Writing the Tutorial

Creating Side Panels

Tutorials are divided into sections that are seen on the side panel. To create these sections, we include a double hash before the text for it to show up as a side panel. This is also called the Group Title. There should be a direct mapping of these headers to the subpart of the chapter which they cover. (Ex. If there is an “Basic Commands” section within the chapter, you make this into a Group Title (## Basic Commands).

Making Sub-sections

The hashes work like a sizing system. The group title (double hash ##) is the largest. When you want to make a header within that panel you increase the hash count by 1.

Triple Hash Rule**

Always place a ‘###”’ on the line below of your Group Title (##). This is a bug issue and the computer needs this to function properly.

Ex. ## Basic Commands ###

Exercises

To create the exercise headers, you use three hashes. Make sure you number your exercises. This makes it easy for students to refer to a specific location when they have a question. ( Ex. "### Exercise 1", "### Exercise 2" and so on )

Writing Exercises

You want to think about making questions a series of exercises. Designate each step to a specific exercise. Build multi-part questions slowly and always include earlier parts of the answer in later questions.

Rules:

  1. Make them build step by step, one line after the other. Setting up interim results is confusing. Set up chunks are a bad idea. Get rid of all of them!

  2. Never instruct a student to replace an object with a different one with the same name.

Structure:

When you structure your exercises, you want to show the graph/plot (if applicable) that you will end up creating. You show it once before at the start of the section and before the last exercise (as a reminder of what the graph/plot should look like so students do not need to scroll all the way back up).

You should put the code for the graph in the code chunk at the start of the section. Save the code to an object. The name of the object should have a _p suffix. This way, you only have to put the object in the code chunk at the end of the section rather than typing out the code.

of the

Don't Assume Rule

Be careful about defining an object in one question (this won't make sense if you haven't read chapter 1) and then assuming that it will be available in subsequent questions. For example, if you ask students to create a function five_flips() that flips a coin five times, you need to be careful about assuming that that function is around later for students to use. If you need a function like that later, just define, at the start of this new question. Then ask the student to use that.

Continue Button

Use ### with no text after a question to create a "Continue" button. This allows students to not be overwhelmed with all the questions they need to do. This will cause R not to show students the next set of questions until they have finished the current set and hit Continue. If you want a "Continue" button to appear after the first question in a given section, you must place ### below AND above the question (for all other questions, just put it below).

Using Hints

Hints allow students to catch up. Every few questions, have a "hint" which shows all the code up till now, and then also a part of the current step.

When you create a hint, you will often need eval=FALSE within the parentheses in the r-chunk. This is because hints will often include "..." and other symbols which do not run as correct R code. So, we need to tell R not to run it or an error will occur. All code in a tutorial must work unless it has eval=FALSE as a code chunk option. If you give a hint which is mostly text, use a single hash mark to specify it as a code comment within the hint code chunk. This causes it to print out more nicely.

Ex:

 # Note that this is a bit tricky. There are two --- completely separate! ---
 # meanings of `x` in this problem. First, `x` is the name of a variable in the
 # `diamonds` dataset which measures the length of each diamond.

R Chunks

By now, you have been exposed briefly to r-chunks (that grey space bove with the green text). These code chunks create the space where the students enter the code within the tutorial.

R-Chunk Rules

Example:

qscores %>% 
  ggplot(aes(...)) + 
      geom_histogram()

(The question would tell the student to replace ... with hours in order to construct a histogram)

``` {r name}
question_text(
  "Student Name:",
  answer(NULL, correct = TRUE),
  allow_retry = TRUE,
  try_again_button = "Modify your answer",
  incorrect = "Ok"
)
```

Using Data

Use built-in data sets in constructing tutorial questions, or use data sets which you create yourself in the tutorial. Note that several packages from the tidyverse have built in data, although it is worth making sure that they are tibbles rather than data frames. To see all the data sets in the Tidyverse, type library(tidyverse) first. Then, you can look at these with --- data() --- and then looking for data sets associated with tidyverse packages. You can also use data sets from PPBDS.data.

Submit Section

The last section/ panel of your tutorial must be the Submit section. This prints out instructions for students to generate a hash of their submissions, enter it, and download an .rds file containing their hash to be uploaded to Canvas. As you can see, Shiny UI elements are incorporated along with the learnrhash package.

submission_ui
submission_server()

Checking Tutorial Functionality

Once you are done writing your tutorial, you need to make sure it works before you submit a Pull Request.

  1. Hit Run Document. This mimics the experience that users will have. This will catch some common errors, like having two code chunks with the same name.

  2. Do a full test, which is an R CMD check. Go to the top right window of RStudio. Click the Build pane and hit the "Check" button (with the green check mark). You will then see a bunch of code and tests running. The most important is to make sure it says "OK" next to “testthat”. You should always run this before submitting a pull request.

What To Do If Check Fails

  1. Read the error message at the bottom of the Build pane. You want to see "R CMD check succeeded." If not, there is a problem. The error message will often provide a clue as to where in your code the error occurred.

  2. If that error message is not detailed enough, go to the "PPBDS.data.rcheck" folder, which should be located in the same directory as PPBDS.data. This is a folder created by the R CMD check process, and it will delete when the check process succeeds. If the process fails, the .rcheck folder stays around so that you can examine it. The key file in there is testthat.Rout.fail, which should be in the tests directory. It has more details.

The most common source of errors is something wrong with the hint code chuncks, which are not evaluated when you just Run Document. Make sure the eval=FALSE is set in the code chunk for all hints.

Miscellaneous

Suggestions from Allison Horst

The main question was: How do we incorporate tutorial questions directly into the chapter itself? Allison is the world expert on this topic.

Other Items

**Hint:** You may want to use the dplyr `filter` function.

Maybe this is how we should do all hints, so as to avoid the compile error issue.

https://github.com/tinystats/teacups-giraffes-and-statistics



davidkane9/PPBDS.data documentation built on Nov. 18, 2020, 1:17 p.m.