Runestone Interactive is a project that provides:
- Interactive, open source textbooks for computer science and programming content which you can use by creating an account and logging in
- Tools for writing your own interactive activities (or even your own book!)
- An application server for hosting your own content on the web. We also use this server to provide textbooks as a service!
In order to see how the special tools for writing interactive activities work, and examine the type of special content that’s used in our interactive textbooks, the following sections will show a few of them in action. For more detailed documentation and information about the Runestone community and project, please see the main Runestone Interactive website.
There are several ways that you might want to use Runestone in your own classroom. The most common way is to choose one of our textbooks, and allow us to serve that book to your students. We call this building a custom course. Hundreds of high schools and colleges use our service to provide their students great content for learning computer science. Its free, and you don’t have to install any additional software on your school computers to get going. In the sections below you will see examples of the kinds of interactive components that are embedded in our textbooks, that enhance the learning of your students.
If you decide to use one of our books, you can customize the book in a couple of different ways.
- You can create your own assignments, by combining end of the chapter exercises or review questions that are right in each section of the book. We have a grading interface that allows you to grade these assignments and provide students feedback all within the textbook.
- You can also customize which chapters you want to use, and the order that you teach them in. That takes a bit more work, but you can definitely do it.
Once you get going using one of our textbooks, you may decide that you want to create your own tutorials, lab exercises, or even make a short booklet to use as presentation materials. Using the runestone tools it is pretty easy to make your own materials. We have Documentation on how to do that
One of the key differences between an interactive textbook and a regular textbook is that with an interactive textbook your students do not need to switch back and forth between reading a book and interacting with a development environment. One of our primary motivations for creating an interactive book was to encourage students to experiment with examples as they are reading. To do this we developed the idea of an activecode example. This led to the development of many other interactive components. In the following sections you can explore each of them from the perspective of a reader. At the end, we have some information on where to go if you want to write your own materials.
One of the most important things that you can do when you are learning a programming language is to write programs. Unfortunately, typical textbooks allow you to read about programming but don’t allow you to practice. We have created a unique tool called activecode that allows you to write, modify, and execute programs right in the text itself (right from the web browser). Although this is certainly not the way real programs are written, it provides an excellent environment for learning a programming language like Python since you can experiment with the language as you are reading.
Take a look at the activecode interpreter in action. If we take a simple Python program and make it active, you will see that it can be executed directly by pressing the run button. Try pressing the run button below.
Now try modifying the activecode program shown above. First, modify the string in the first print statement by changing the word adds to the word multiplies. Now press run. You can see that the result of the program has changed. However, it still prints “30” as the answer. Modify the total calculation by changing the addition symbol, the “+”, to the multiplication symbol, “*”. Press run to see the new results (note that you should also fix the total initialization for a correct claculation). You can do this as many times as you like. You can even start completely over by simply deleting all the code from the window.
If you are a registered user and have logged in, any changes you make are automatically saved, and the history slider allows you to go back to any previous version of your program. Note that these saved programs can be accessed from anywhere if you have logged in. However, if you are working anonymously, then you will lose your work at the end of the session.
Activecode is even capable of executing graphical programs that use the built in Python turtle module. The program shown below is a very interesting graphics program that uses the turtle and the idea of recursion to construct a type of fractal called a Sierpinski Triangle. Once you run the program, try experimenting with the number of triangle levels. You can find this on line 39 (it is currently set to 3). Try 4! Try some other changes and see what happens (maybe change a few of the colors or make the level 2). If you ever want to go back to the original example, simply reload the page in the browser. One of the great things about activecode is that you can experiment as much as you want. This can be very helpful as you are learning to program.
In addition to activecode, you can also execute Python code with the assistance of a unique visualization tool. This tool, known as codelens, allows you to control the step by step execution of a program. It also lets you see the values of all variables as they are created and modified. The following example shows codelens in action on the same simple program as we saw above. Remember that in activecode, the source code executes from beginning to end and you can see the final result. In codelens you can see and control the step by step progress. Try clicking on the forward button below.
Note that you can control the step by step execution and you can even move forward and backward thru the statements as they execute. The following example shows a more sophisticated program using Python lists. The codelens tool draws very useful pictures as the statements are being executed. These pictures, called reference diagrams, are very helpful as you learn about the more complex aspects of Python.
It is also possible to embed simple questions into the text. These questions provide a way for the students to check themselves as they go along. The questions also provide feedback so that you can understand why an answer may or may not be correct.
Check your understanding
sc-1-1: What programming language does this site help you to learn?
- (A) Python
- Yes, Python is a great language to learn, whether you are a beginner or an experienced programmer.
- (B) Java
- Java is a good object oriented language but it has some details that make it hard for the beginner.
- (C) C
- C is an imperative programming language that has been around for a long time, but it is not the one that we use.
- (D) ML
- No, ML is a functional programming language. You can use Python to write functional programs as well.
This next type of question allows more than one correct answer to be required. The feedback will tell you whether you have the correct number as well as the feedback for each.
sc-1-2: Which colors might be found in a rainbow? (choose all that are correct)
- (A) red
- Red is a definitely on of the colors.
- (B) yellow
- Yes, yellow is correct.
- (C) black
- Remember the acronym...ROY G BIV. B stands for blue.
- (D) green
- Yes, green is one of the colors.
Another type of question allows you as the instructor to ask for a value. You can test for the value using Pythons regular expressions. For example:
What is the value of 25 expressed as an octal number (base 8)? \b25\b That's base 10! .* 25 in octal please! \\b31\\b
There is also a way of giving your students some simple programming problems where the code is already there for them but not indented or in the correct order. Think of it like coding with refrigerator magnets! Use drag-and-drop to get everything right.
sc-1-3: Construct a block of code that correctly implements the accumulator pattern.x = 0 for i in range(10) x = x + 1
Here is a different sort of CodeLens visualization. Some CodeLens blocks can have
questions embedded in them that will ask you a question about the value of a
variable, or which line will be the next line to execute. This example asks you
to keep track of the
tot variable as you step through the loop.
Here’s another example that asks the student to predict which line will be the next line executed.
You can add a Drag n drop matching question to your page simply by defining the pairs of matchable elements within a dragndrop directive. The order of draggable elements and their respective dropzones will be randomized so the pairs aren’t always side-by-side.
This is a drag n drop question.
This is feedback.
- Drag me to 1
- I am 1
- Drag me to 2
- I am 2
- Drag me to 3
- I am 3
Clickable area is another type of assess question you can use. All you need to do is write the code you wish to be in the question, and wrap the parts that you would like to be clickable in either a click-correct tag or a click-incorrect tag. The students can click on all elements you defined as being clickable, and will be evaluated once they click the ‘Check Me’ button.
def main(): x = 4 for i in range(5): y = i if y > 2: print(y)
sc-1-4: You can ask your students to answer reflective questions or short essays in the box provided.
You can add a timed exam of any of the assessments described so far. You can specify the maximum duration of the exam in minutes and it will display the time remaining. If you don’t include a duration it will keep track of the amount of time used and give the user unlimited time to finish the exam. To start the exam click on the “Start” button. You can pause the time by clicking on the “Pause” button and start it again by clicking on the “Resume” button. When you pause the exam the questions will be hidden. There is also a clock icon that will display the time remaining if it is a timed exam and the time used otherwise when the reader hovers over it.
Please note that you can currently only have one timed exam per html page. By default the feedback will be shown after the user clicks the “Submit Answer” button or also after the time runs out for an exam with a specified duration.
- (A) The value you are searching for is the first element in the array.
- Only when the search value is the first item in the array, and thus the first value encountered in sequential search, will sequential be faster than binary.
- (B) The value you are searching for is the last element in the array
- In this case a sequential search will have to check every element before finding the correct one, whereas a binary search will not.
- (C) The value you are searching for is in the middle of the array.
- Results will differ depending on the exact location of the element, but Binary Search will still find the element faster while Sequential will have to check more elements.
- (D) The value you are searching for is not in the array
- If the search value is not in the array, a sequential search will have to check every item in the array before failing, a binary search will be faster.
- (E) Sequential Search can never be faster than Binary Search.
- When the search value is the first element, Sequential will always be faster, as it will only need to check one element.
- Drag to Answer A
- Answer A
- Drag me Answer B
- Answer B
- Drag to Answer C
- Answer C
sc-1-5: Under which of these conditions will a sequential search be faster than a binary search?
|This row is incorrect||...||...||...|
This is a drag n drop question.
This is feedback.
Fill in the blanks to make the following sentence: “The red car drove away” The .* Try 'red' \\bred\\b car drove .* Try 'away' \\baway\\b
Our toolset provides a number of different things that will help you to learn to program in the Python programming language. Aside from reading the text, it is sometimes useful to hear someone tell you about different aspects of the topic being discussed. In order to accomplish this, we provide a way to integrate simple, short videos into the text. For example, if you click on the video shown below, you will hear us talk about the tools that will be described shortly.
Its nice to be able to have students solve a particular problem by writing some code, its even better if you can give them some feedback and provide some tests for them. Much of the
unittest module from Python is available in the
unittest module for activecode. Take a look:
Before you go on, fix the add function in the activecode box. The full complement of assertXXX functions is available. You can see the list Here. Now, for an introductory course exposing the inner workings of the unittest class may lead to more confusion that anything. But, you can still get the benefit of the unittest module with activecode by placing it in the hidden code at the end. You can hide the code by placing it after a line that contains
====. The source code for the above example with the unit tests hidden would look like this:
.. activecode:: units1 def add(a,b): return 4 ==== from unittest.gui import TestCaseGui class myTests(TestCaseGui): def testOne(self): self.assertEqual(add(2,2),4,"A feedback string when the test fails") self.assertAlmostEqual(add(2.0,3.0),5.0,"Your function failed on inputs of 2.0 and 3.0") myTests().main()
A comment box allowing users to add comments and start discussions can be added. A comment box can be added at the page level, but also for an individual section or question, allowing discussion of that particular content.Show Comments
Any of the existing components can be placed in a tabbed exhibit-style question. This may be used to provide an possible answer or a Disqus discussion box specifically related to a certain question.
Write a program that prints “Hello, world”.
We are working on additional question types as well. Give us your feedback on our Facebook page.
- On a scale from 1 to 10, how important do you think it is to have a polling directive in the Runestone Tools?
This content starts out hidden. It’s visibility can be toggled by using the Show/Hide button.
The reveal block can also contain other directives (ActiveCode, Disqus block, etc):
Python programs written in activecode windows can now import the
document module. This document module
allows access to basic elements of the web page, including the new text entry box called
text1 like this one. Try running the program, then change
the value in the text entry box and run it again.
parameter to the activecode directive.
Teaching a class on HTML and simple web design? Why not use activecode for HTML too? Although you don’t run HTML, clicking the run button will cause the HTML to be rendered.
Add a print statement after the set X to 10. Click on text and drag out a print block; connect it to the set block. Then click on variables and drag out the X block and connect it to the print block. Now click the run button and you should see 10 printed in the gray output area.
Activecode now supports Java, C++ and C through a backend server, not in the browser. You can use them by specifying the language to be java, cpp or c In addition it supports either Python3 or Python2 outside of the browser using python3 or python2 as the language. You are limited to non-graphical programs in any of these options.
Now that you have seen some of these tools in action, you can do more exploration by going to Runestone library and browsing through some of our existing books.
We hope you will find these tools and materials useful. If you want to get more involved, feel free to download the tools and write your own materials. Everything you need, instructions and help for contributing or writing your own materials, and links to our GitHub repositories, can be found here