Lesson 5: Variables
Overview
In this lesson students learn how to use variables to label a number in their program or save a randomly generated value. Students begin the lesson with a very basic description of the purpose of a variable. Students then complete a level progression that reinforces the model of a variable as a way to label or name a number. Students use variables to save a random number to see that variables actually store or save their values, allowing them to use the same random number multiple times in their programs.
Purpose
This lesson is the first time students will see variables in the course, and they are not expected to fully understand how variables work by its conclusion. Students should therefore leave this lesson knowing that variables are a way to label a value in their programs so that they can be reused or referenced later. In the following lesson students will be introduced to sprites, which need to be referenced by a variable.
Using variables to manipulate drawings is a surprisingly challenging skill that requires a great deal of forethought and planning. While students will use or modify many programs in this lesson, they are not expected to compose programs that use variables to modify the features of a drawing. In later lessons, students will expand their understanding of variables and more advanced ways they can be used.
Assessment Opportunities
-
Identify a variable as a way to label and reference a value in a program
See the reflection prompt in the Wrap Up.
-
Use variables in a program to store a piece of information that is used multiple times
See Level 9 in Code Studio.
Agenda
Warm Up (10 Mins)
Activity (30 Mins)
Wrap Up (5 Mins)
View on Code Studio
Objectives
Students will be able to:
- Identify a variable as a way to label and reference a value in a program
- Use variables in a program to store a piece of information that is used multiple times
Preparation
- Review the level progression in Code Studio
Links
Heads Up! Please make a copy of any documents you plan to share with students.
For the Students
- Introduction to Variables - Video (download)
Vocabulary
- Variable - A label for a piece of information used in a program.
Introduced Code
Teaching Guide
Warm Up (10 Mins)
Labels and Values
Teaching Tip
Avoiding Frontloading: While this lesson begins with two resources that explain how variables work, they'll likely be more meaningful to students once they have used variables in the drawing programs. Make sure students know these resources are available, and then return to them if you like at the end of the lesson to help in sense-making.
Video: As a class watch the video introducing variables.
Review: Students can review the most important points from the video on the map level in Level 4. Students don't need to understand all of these ideas right now, but they can use this level as a reference throughout the lesson.
Remarks
There's a lot to learn about variables and we'll be seeing them throughout this unit. Today we're going to see them used to help us draw pictures. The most important thing we care about today, though, is just seeing how giving a label to a value helps us write programs.
Activity (30 Mins)
Programming with Variables
Wrap Up (5 Mins)
Reflection
Assessment Opportunity
Use this discussion to assess students' mental models of a variable. You may wish to have students write their responses so you can collect them to review later. You should be looking to see primarily that they understand that variables can label or name a number so that it can be used later in their programs. While there are other properties of a variable students may have learned, this is the most important before moving on to the next lesson.
Prompt: Give students the following prompts
- What is your own definition of a variable?
- Why are variables useful in programs?
Discuss: Have students silently write their ideas before sharing in pairs and then as a whole group.
Teaching Tip
Input-Output-Store-Process: The model students learned in Unit 1 might be nice to reference here. Students are storing information in a variable which means they are saving that information in memory.
CSS Classes: If students studied CSS classes in Unit 2 then they may be familiar with the act of creating a name for something in their programs in order to be able to reference it. While the context here is different, the idea of naming remains the same.
Journal: What connections do you see between variables and what you learned about the Input-Output-Store-Process model of a computer?
- Lesson Overview
- Student Overview
- Introduction to Variables
- Teacher Overview
- Student Overview
Discussion Goals
Students should understand that variables hold information and an be accessed using their labels. With simple drawings, students may not see the power of variables, so you may want them to think of some different apps that they use and what information needs to be stored for the app to work, or think about a more complex program that they want to use variables for.
Numbers, text, and colors can all go into variables, as well as more complicated data structures that students will see later in the course.
Questions to Consider
- What are variables used to do?
- How do you create a variable and assign it a value?
- What can go into a variable?
Student Instructions
Using Variables
In this program, the variable xPosition
is used to store the x-coordinate of the circle.
Do This
- Run the program to see how it works.
- Change the number that is stored into the variable (Show me where) and run the code again.
Student Instructions
Predict
In which corner of the screen will the circle be drawn?
Hint: Click the "Show grid" box to help you find the exact coordinates on the screen.
Student Instructions
Debug: Using Variables
This program uses the variable circleSize
to control the width and height of a circle. If you make the circle big enough, it will fill up the entire screen, as in the picture on the right.
Do This
- Change the value assigned to
circleSize
so that the circle takes up the entire screen.
Student Instructions
Using a Variable Many Times
This program has only one variable called petalSize
but it uses it 8 different times. This makes it easy to quickly make lots of changes to how your picture is drawn.
Do This
- Change the number assigned to
petalSize
so the red petals touch one another. - Try to find the size that makes the most sense. Compare your answer with someone around you.
- Variables
- Student Overview
Teaching Tip
If students use variable names that start with numbers, include spaces, or break other rules, the code may be forced into text mode the next time that they go to that level or refresh the page. To get back into block mode, students will first need to fix the problem with the variable names. Use the red error squares to see where the bugs most likely are, and once they are gone, click the "block mode" button at the top right of the workspace.
Student Instructions
Debug: Naming Variables
This program has multiple errors caused by bad label names. The errors prevent the program from being viewed in block mode, so the code is in text.
Do This
- Find the rule each variable label violates.
- Correct the errors by picking new names that follow the rules you learned in the last level.
- If your program works it should draw the image on the right.
- Labels can't have spaces.
- Labels can't start with a number.
- Capitalization and spelling must be exactly the same.
Assessment Opportunities
Use variables to store and update information
Extensive Evidence
The eyeSize variable is used such that the two eyes have the same random size as instructed, with no other unexpected changes.
Convincing Evidence
The eyeSize variable is used such that the two eyes have the same random size, but other changes to the code may have introduced other unexpected behaviors.
Limited Evidence
The eyeSize variable has been used somewhere in the program, but not such that it runs as instructed.
No Evidence
There are no changes to the code, or the changes appear unrelated to the eyeSize variable, or the variable is used in a way that prevents the program from running.
Student Instructions
Debug: Variables and Random Numbers
Variables can be assigned a random number too. This lets you save a single random value so that you can use it as many times as you want in your program.
Do This
eyeSize
is assigned a random number. Unfortunately only one of the eyes is currently using it.
- Run the program to see how it works.
- Change the program so that both eyes are always the same random size. Hint: you'll only need to make changes to one line of code.
- Naming Variables
- Student Overview
Student Instructions
Challenge: Draw an Image
Check with your teacher before tackling this challenge level.
Using variables, draw an image where many of the items rely on a common variable for size or placement. For example, draw a face with variables controlling the size and/or placement of both eyes, ears, and nostrils. Once you have your drawing completed, try changing the values of your variables to make sure that the whole image changes together.
Student Instructions
Challenge: Updating Variables
Check with your teacher before tackling this challenge level.
So far we've only ever assigned a value to a variable once, but did you know you can update a variable during a program? Read through the example program we've provided, run it a few times to understand how it works, and then attempt to modify the program to draw one of the following images.
Student Instructions
Free Play
Use what you've learned to create whatever you like. When you're finished, you can click to send your creation to a friend, or to send it to your Projects Gallery.
Standards Alignment
View full course alignment
CSTA K-12 Computer Science Standards (2017)
AP - Algorithms & Programming
- 2-AP-11 - Create clearly named variables that represent different data types and perform operations on their values.
- 2-AP-13 - Decompose problems and subproblems into parts to facilitate the design, implementation, and review of programs.
- 2-AP-17 - Systematically test and refine programs using a range of test cases.
- 2-AP-19 - Document programs in order to make them easier to follow, test, and debug.